All of lore.kernel.org
 help / color / mirror / Atom feed
From: Alon Levy <alevy@redhat.com>
To: qemu-devel@nongnu.org
Subject: [Qemu-devel] [PATCH 01/17] qdev: add print_options callback
Date: Thu,  3 Feb 2011 23:06:58 +0200	[thread overview]
Message-ID: <1296767234-9480-2-git-send-email-alevy@redhat.com> (raw)
In-Reply-To: <1296767234-9480-1-git-send-email-alevy@redhat.com>

another callback added to PropertyInfo, for later use by PROP_TYPE_ENUM.
Allows printing of runtime computed options when doing:
 qemu -device foo,?

Signed-off-by: Alon Levy <alevy@redhat.com>
---
 hw/qdev.c |   10 +++++++++-
 hw/qdev.h |    1 +
 2 files changed, 10 insertions(+), 1 deletions(-)

diff --git a/hw/qdev.c b/hw/qdev.c
index c7fec44..0b2ad3d 100644
--- a/hw/qdev.c
+++ b/hw/qdev.c
@@ -187,7 +187,15 @@ int qdev_device_help(QemuOpts *opts)
         if (!prop->info->parse) {
             continue;           /* no way to set it, don't show */
         }
-        error_printf("%s.%s=%s\n", info->name, prop->name, prop->info->name);
+        if (prop->info->print_options) {
+            char buf[256];
+            int ret;
+            ret = prop->info->print_options(info, prop, buf, sizeof(buf) - 3);
+            error_printf("%s.%s=%s%s\n", info->name, prop->name, buf,
+                ret == sizeof(buf) - 3 ? "..." : "" );
+        } else {
+            error_printf("%s.%s=%s\n", info->name, prop->name, prop->info->name);
+        }
     }
     return 1;
 }
diff --git a/hw/qdev.h b/hw/qdev.h
index 9808f85..fa3221b 100644
--- a/hw/qdev.h
+++ b/hw/qdev.h
@@ -109,6 +109,7 @@ struct PropertyInfo {
     enum PropertyType type;
     int (*parse)(DeviceState *dev, Property *prop, const char *str);
     int (*print)(DeviceState *dev, Property *prop, char *dest, size_t len);
+    int (*print_options)(DeviceInfo *info, Property *prop, char *dest, size_t len);
     void (*free)(DeviceState *dev, Property *prop);
 };
 
-- 
1.7.4

  reply	other threads:[~2011-02-03 21:07 UTC|newest]

Thread overview: 20+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-02-03 21:06 [Qemu-devel] [PATCH 00/20] usb-ccid (v17) Alon Levy
2011-02-03 21:06 ` Alon Levy [this message]
2011-02-03 21:06 ` [Qemu-devel] [PATCH 02/17] qdev: add data pointer to Property Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 03/17] qdev-properties: add PROP_TYPE_ENUM Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 04/17] qdev-properties: parse_enum: don't cast a void* Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 05/17] usb-ccid: add CCID bus Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 06/17] introduce libcacard/vscard_common.h Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 07/17] libcacard/vscard_common.h update (v15->v16) Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 08/17] ccid: add passthru card device Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 09/17] libcacard: initial commit Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 10/17] ccid: add ccid-card-emulated device (v2) Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 11/17] ccid: add docs Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 12/17] ccid: configure: add --enable/disable and nss only disable Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 13/17] ccid: add qdev description strings Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 14/17] smartcard, configure: add --enable-smartcard-nss, report only nss Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 15/17] smartcard,configure: " Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 16/17] ccid-card-emulated: don't link with NSS if --disable-smartcard-nss Alon Levy
2011-02-03 21:07 ` [Qemu-devel] [PATCH 17/17] ccid.h: add copyright, fix define and remove non C89 comments Alon Levy
2011-02-03 22:04 ` [Qemu-devel] [PATCH 00/20] usb-ccid (v17) Alon Levy
2011-02-03 22:41 ` Alon Levy

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1296767234-9480-2-git-send-email-alevy@redhat.com \
    --to=alevy@redhat.com \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.