From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1Nu1SJ-0007ry-VX for qemu-devel@nongnu.org; Tue, 23 Mar 2010 06:35:28 -0400 Received: from [199.232.76.173] (port=60119 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1Nu1SJ-0007rW-HN for qemu-devel@nongnu.org; Tue, 23 Mar 2010 06:35:27 -0400 Received: from Debian-exim by monty-python.gnu.org with spam-scanned (Exim 4.60) (envelope-from ) id 1Nu1SI-0005MG-2A for qemu-devel@nongnu.org; Tue, 23 Mar 2010 06:35:27 -0400 Received: from oxygen.pond.sub.org ([213.239.205.148]:44101) by monty-python.gnu.org with esmtps (TLS-1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.60) (envelope-from ) id 1Nu1SG-0005Lt-UR for qemu-devel@nongnu.org; Tue, 23 Mar 2010 06:35:25 -0400 Received: from blackfin.pond.sub.org (pD951AFA7.dip.t-dialin.net [217.81.175.167]) by oxygen.pond.sub.org (Postfix) with ESMTPA id 7CD9B276DA6 for ; Tue, 23 Mar 2010 11:27:59 +0100 (CET) From: Markus Armbruster Date: Tue, 23 Mar 2010 11:27:56 +0100 Message-Id: <1269340078-16446-3-git-send-email-armbru@redhat.com> In-Reply-To: <1269340078-16446-1-git-send-email-armbru@redhat.com> References: <1269340078-16446-1-git-send-email-armbru@redhat.com> Subject: [Qemu-devel] [PATCH 2/4] monitor: New argument type 'b' List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: lcapitulino@redhat.com This is a boolean value. Human monitor accepts "on" or "off". Consistent with option parsing (see parse_option_bool()). Signed-off-by: Markus Armbruster --- monitor.c | 31 +++++++++++++++++++++++++++++++ 1 files changed, 31 insertions(+), 0 deletions(-) diff --git a/monitor.c b/monitor.c index 3ce9a4e..47b68a2 100644 --- a/monitor.c +++ b/monitor.c @@ -85,6 +85,8 @@ * * '?' optional type (for all types, except '/') * '.' other form of optional type (for 'i' and 'l') + * 'b' boolean + * user mode accepts "on" or "off" * '-' optional parameter (eg. '-f') * */ @@ -3841,6 +3843,29 @@ static const mon_cmd_t *monitor_parse_command(Monitor *mon, qdict_put(qdict, key, qfloat_from_double(val)); } break; + case 'b': + { + const char *beg; + int val; + + while (qemu_isspace(*p)) { + p++; + } + beg = p; + while (qemu_isgraph(*p)) { + p++; + } + if (!strncmp(beg, "on", p - beg)) { + val = 1; + } else if (!strncmp(beg, "off", p - beg)) { + val = 0; + } else { + monitor_printf(mon, "Expected 'on' or 'off'\n"); + goto fail; + } + qdict_put(qdict, key, qbool_from_int(val)); + } + break; case '-': { const char *tmp = p; @@ -4322,6 +4347,12 @@ static int check_arg(const CmdArgs *cmd_args, QDict *args) return -1; } break; + case 'b': + if (qobject_type(value) != QTYPE_QBOOL) { + qerror_report(QERR_INVALID_PARAMETER_TYPE, name, "bool"); + return -1; + } + break; case '-': if (qobject_type(value) != QTYPE_QINT && qobject_type(value) != QTYPE_QBOOL) { -- 1.6.6.1