From: Stefan Hajnoczi Date: Wed, 29 Jan 2014 11:17:31 +0000 (+0100) Subject: QMP: allow JSON dict arguments in qmp-shell X-Git-Tag: Tizen_Studio_1.3_Release_p2.3.1~386^2~42^2~168^2~6 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ff9ec34de8f6a37bd29ac72c0c4c94bd5d43d7b0;p=sdk%2Femulator%2Fqemu.git QMP: allow JSON dict arguments in qmp-shell qmp-shell hides the QMP wire protocol JSON encoding from the user. Most of the time this is helpful and makes the command-line human-friendly. Some QMP commands take a dict as an argument. In order to express this we need to revert back to JSON notation. This patch allows JSON dict arguments in qmp-shell so commands like blockdev-add and nbd-server-start can be invoked: (QEMU) blockdev-add options={"driver":"file","id":"drive1",...} Note that spaces are not allowed since str.split() is used to break up the command-line arguments first. Signed-off-by: Stefan Hajnoczi Reviewed-by: Eric Blake Reviewed-by: Benoit Canet Signed-off-by: Luiz Capitulino --- diff --git a/scripts/qmp/qmp-shell b/scripts/qmp/qmp-shell index d6b420f18a..d374b357aa 100755 --- a/scripts/qmp/qmp-shell +++ b/scripts/qmp/qmp-shell @@ -31,6 +31,7 @@ # (QEMU) import qmp +import json import readline import sys import pprint @@ -107,6 +108,8 @@ class QMPShell(qmp.QEMUMonitorProtocol): value = True elif opt[1] == 'false': value = False + elif opt[1].startswith('{'): + value = json.loads(opt[1]) else: value = opt[1] qmpcmd['arguments'][opt[0]] = value