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:
parent
28770e057f
commit
6eb3937e9b
@ -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);
|
||||||
|
|
||||||
|
@ -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:
|
||||||
|
@ -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
21
qmp.c
@ -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;
|
||||||
|
|
||||||
|
@ -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',
|
||||||
|
Loading…
Reference in New Issue
Block a user