qom: Don't use 'gen': false for qom-get, qom-set, object-add

With the previous commit, the generated marshalers just work, and save
us a bit of handwritten code.

Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Daniel P. Berrange <berrange@redhat.com>
Message-Id: <1442401589-24189-23-git-send-email-armbru@redhat.com>
This commit is contained in:
Markus Armbruster 2015-09-16 13:06:25 +02:00
parent 28770e057f
commit 6eb3937e9b
5 changed files with 14 additions and 26 deletions

View File

@ -42,9 +42,6 @@ void monitor_read_command(Monitor *mon, int show_prompt);
int monitor_read_password(Monitor *mon, ReadLineFunc *readline_func, int monitor_read_password(Monitor *mon, ReadLineFunc *readline_func,
void *opaque); void *opaque);
void qmp_qom_set(QDict *qdict, QObject **ret, Error **errp);
void qmp_qom_get(QDict *qdict, QObject **ret, Error **errp);
void qmp_object_add(QDict *qdict, QObject **ret, Error **errp);
void object_add(const char *type, const char *id, const QDict *qdict, void object_add(const char *type, const char *id, const QDict *qdict,
Visitor *v, Error **errp); Visitor *v, Error **errp);

View File

@ -1698,8 +1698,7 @@
## ##
{ 'command': 'qom-get', { 'command': 'qom-get',
'data': { 'path': 'str', 'property': 'str' }, 'data': { 'path': 'str', 'property': 'str' },
'returns': '**', 'returns': 'any' }
'gen': false }
## ##
# @qom-set: # @qom-set:
@ -1716,8 +1715,7 @@
# Since: 1.2 # Since: 1.2
## ##
{ 'command': 'qom-set', { 'command': 'qom-set',
'data': { 'path': 'str', 'property': 'str', 'value': '**' }, 'data': { 'path': 'str', 'property': 'str', 'value': 'any' } }
'gen': false }
## ##
# @set_password: # @set_password:
@ -2127,8 +2125,7 @@
# Since: 2.0 # Since: 2.0
## ##
{ 'command': 'object-add', { 'command': 'object-add',
'data': {'qom-type': 'str', 'id': 'str', '*props': '**'}, 'data': {'qom-type': 'str', 'id': 'str', '*props': 'any'} }
'gen': false }
## ##
# @object-del: # @object-del:

View File

@ -953,7 +953,7 @@ EQMP
{ {
.name = "object-add", .name = "object-add",
.args_type = "qom-type:s,id:s,props:q?", .args_type = "qom-type:s,id:s,props:q?",
.mhandler.cmd_new = qmp_object_add, .mhandler.cmd_new = qmp_marshal_object_add,
}, },
SQMP SQMP
@ -3575,13 +3575,13 @@ EQMP
{ {
.name = "qom-set", .name = "qom-set",
.args_type = "path:s,property:s,value:q", .args_type = "path:s,property:s,value:q",
.mhandler.cmd_new = qmp_qom_set, .mhandler.cmd_new = qmp_marshal_qom_set,
}, },
{ {
.name = "qom-get", .name = "qom-get",
.args_type = "path:s,property:s", .args_type = "path:s,property:s",
.mhandler.cmd_new = qmp_qom_get, .mhandler.cmd_new = qmp_marshal_qom_get,
}, },
{ {

21
qmp.c
View File

@ -234,12 +234,9 @@ ObjectPropertyInfoList *qmp_qom_list(const char *path, Error **errp)
return props; return props;
} }
/* FIXME: teach qapi about how to pass through Visitors */ void qmp_qom_set(const char *path, const char *property, QObject *value,
void qmp_qom_set(QDict *qdict, QObject **ret, Error **errp) Error **errp)
{ {
const char *path = qdict_get_str(qdict, "path");
const char *property = qdict_get_str(qdict, "property");
QObject *value = qdict_get(qdict, "value");
Object *obj; Object *obj;
obj = object_resolve_path(path, NULL); obj = object_resolve_path(path, NULL);
@ -252,20 +249,18 @@ void qmp_qom_set(QDict *qdict, QObject **ret, Error **errp)
object_property_set_qobject(obj, value, property, errp); object_property_set_qobject(obj, value, property, errp);
} }
void qmp_qom_get(QDict *qdict, QObject **ret, Error **errp) QObject *qmp_qom_get(const char *path, const char *property, Error **errp)
{ {
const char *path = qdict_get_str(qdict, "path");
const char *property = qdict_get_str(qdict, "property");
Object *obj; Object *obj;
obj = object_resolve_path(path, NULL); obj = object_resolve_path(path, NULL);
if (!obj) { if (!obj) {
error_set(errp, ERROR_CLASS_DEVICE_NOT_FOUND, error_set(errp, ERROR_CLASS_DEVICE_NOT_FOUND,
"Device '%s' not found", path); "Device '%s' not found", path);
return; return NULL;
} }
*ret = object_property_get_qobject(obj, property, errp); return object_property_get_qobject(obj, property, errp);
} }
void qmp_set_password(const char *protocol, const char *password, void qmp_set_password(const char *protocol, const char *password,
@ -661,11 +656,9 @@ out:
object_unref(obj); object_unref(obj);
} }
void qmp_object_add(QDict *qdict, QObject **ret, Error **errp) void qmp_object_add(const char *type, const char *id,
bool has_props, QObject *props, Error **errp)
{ {
const char *type = qdict_get_str(qdict, "qom-type");
const char *id = qdict_get_str(qdict, "id");
QObject *props = qdict_get(qdict, "props");
const QDict *pdict = NULL; const QDict *pdict = NULL;
QmpInputVisitor *qiv; QmpInputVisitor *qiv;

View File

@ -40,6 +40,7 @@ builtin_types = {
returns_whitelist = [ returns_whitelist = [
# From QMP: # From QMP:
'human-monitor-command', 'human-monitor-command',
'qom-get',
'query-migrate-cache-size', 'query-migrate-cache-size',
'query-tpm-models', 'query-tpm-models',
'query-tpm-types', 'query-tpm-types',