qapi: Consolidate QMP input visitor creation
Rather than having two separate ways to create a QMP input visitor, where the safer approach has the more verbose name, it is better to consolidate things into a single function where the caller must explicitly choose whether to be strict or to ignore excess input. This patch is the strictly mechanical conversion; the next patch will then audit which uses can be made stricter. Signed-off-by: Eric Blake <eblake@redhat.com> Message-Id: <1461879932-9020-6-git-send-email-eblake@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
b471d012e5
commit
fc471c18d5
@ -996,7 +996,7 @@ Example:
|
|||||||
{
|
{
|
||||||
Error *err = NULL;
|
Error *err = NULL;
|
||||||
UserDefOne *retval;
|
UserDefOne *retval;
|
||||||
QmpInputVisitor *qiv = qmp_input_visitor_new_strict(QOBJECT(args));
|
QmpInputVisitor *qiv = qmp_input_visitor_new(QOBJECT(args), true);
|
||||||
QapiDeallocVisitor *qdv;
|
QapiDeallocVisitor *qdv;
|
||||||
Visitor *v;
|
Visitor *v;
|
||||||
UserDefOneList *arg1 = NULL;
|
UserDefOneList *arg1 = NULL;
|
||||||
|
@ -19,8 +19,13 @@
|
|||||||
|
|
||||||
typedef struct QmpInputVisitor QmpInputVisitor;
|
typedef struct QmpInputVisitor QmpInputVisitor;
|
||||||
|
|
||||||
QmpInputVisitor *qmp_input_visitor_new(QObject *obj);
|
/*
|
||||||
QmpInputVisitor *qmp_input_visitor_new_strict(QObject *obj);
|
* Return a new input visitor that converts QMP to QAPI.
|
||||||
|
*
|
||||||
|
* Set @strict to reject a parse that doesn't consume all keys of a
|
||||||
|
* dictionary; otherwise excess input is ignored.
|
||||||
|
*/
|
||||||
|
QmpInputVisitor *qmp_input_visitor_new(QObject *obj, bool strict);
|
||||||
|
|
||||||
void qmp_input_visitor_cleanup(QmpInputVisitor *v);
|
void qmp_input_visitor_cleanup(QmpInputVisitor *v);
|
||||||
|
|
||||||
|
@ -356,7 +356,7 @@ void qmp_input_visitor_cleanup(QmpInputVisitor *v)
|
|||||||
g_free(v);
|
g_free(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
QmpInputVisitor *qmp_input_visitor_new(QObject *obj)
|
QmpInputVisitor *qmp_input_visitor_new(QObject *obj, bool strict)
|
||||||
{
|
{
|
||||||
QmpInputVisitor *v;
|
QmpInputVisitor *v;
|
||||||
|
|
||||||
@ -376,19 +376,10 @@ QmpInputVisitor *qmp_input_visitor_new(QObject *obj)
|
|||||||
v->visitor.type_number = qmp_input_type_number;
|
v->visitor.type_number = qmp_input_type_number;
|
||||||
v->visitor.type_any = qmp_input_type_any;
|
v->visitor.type_any = qmp_input_type_any;
|
||||||
v->visitor.optional = qmp_input_optional;
|
v->visitor.optional = qmp_input_optional;
|
||||||
|
v->strict = strict;
|
||||||
|
|
||||||
qmp_input_push(v, obj, NULL);
|
qmp_input_push(v, obj, NULL);
|
||||||
qobject_incref(obj);
|
qobject_incref(obj);
|
||||||
|
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
QmpInputVisitor *qmp_input_visitor_new_strict(QObject *obj)
|
|
||||||
{
|
|
||||||
QmpInputVisitor *v;
|
|
||||||
|
|
||||||
v = qmp_input_visitor_new(obj);
|
|
||||||
v->strict = true;
|
|
||||||
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
2
qmp.c
2
qmp.c
@ -663,7 +663,7 @@ void qmp_object_add(const char *type, const char *id,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
qiv = qmp_input_visitor_new(props);
|
qiv = qmp_input_visitor_new(props, false);
|
||||||
obj = user_creatable_add_type(type, id, pdict,
|
obj = user_creatable_add_type(type, id, pdict,
|
||||||
qmp_input_get_visitor(qiv), errp);
|
qmp_input_get_visitor(qiv), errp);
|
||||||
qmp_input_visitor_cleanup(qiv);
|
qmp_input_visitor_cleanup(qiv);
|
||||||
|
@ -22,7 +22,7 @@ void object_property_set_qobject(Object *obj, QObject *value,
|
|||||||
const char *name, Error **errp)
|
const char *name, Error **errp)
|
||||||
{
|
{
|
||||||
QmpInputVisitor *qiv;
|
QmpInputVisitor *qiv;
|
||||||
qiv = qmp_input_visitor_new(value);
|
qiv = qmp_input_visitor_new(value, false);
|
||||||
object_property_set(obj, qmp_input_get_visitor(qiv), name, errp);
|
object_property_set(obj, qmp_input_get_visitor(qiv), name, errp);
|
||||||
|
|
||||||
qmp_input_visitor_cleanup(qiv);
|
qmp_input_visitor_cleanup(qiv);
|
||||||
|
@ -37,7 +37,7 @@ static InputEvent *qapi_clone_InputEvent(InputEvent *src)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
qiv = qmp_input_visitor_new(obj);
|
qiv = qmp_input_visitor_new(obj, false);
|
||||||
iv = qmp_input_get_visitor(qiv);
|
iv = qmp_input_get_visitor(qiv);
|
||||||
visit_type_InputEvent(iv, NULL, &dst, &error_abort);
|
visit_type_InputEvent(iv, NULL, &dst, &error_abort);
|
||||||
qmp_input_visitor_cleanup(qiv);
|
qmp_input_visitor_cleanup(qiv);
|
||||||
|
@ -115,7 +115,7 @@ def gen_marshal(name, arg_type, ret_type):
|
|||||||
|
|
||||||
if arg_type and arg_type.members:
|
if arg_type and arg_type.members:
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
QmpInputVisitor *qiv = qmp_input_visitor_new_strict(QOBJECT(args));
|
QmpInputVisitor *qiv = qmp_input_visitor_new(QOBJECT(args), true);
|
||||||
QapiDeallocVisitor *qdv;
|
QapiDeallocVisitor *qdv;
|
||||||
Visitor *v;
|
Visitor *v;
|
||||||
%(c_name)s arg = {0};
|
%(c_name)s arg = {0};
|
||||||
|
@ -222,7 +222,7 @@ static void test_dealloc_partial(void)
|
|||||||
ud2_dict = qdict_new();
|
ud2_dict = qdict_new();
|
||||||
qdict_put_obj(ud2_dict, "string0", QOBJECT(qstring_from_str(text)));
|
qdict_put_obj(ud2_dict, "string0", QOBJECT(qstring_from_str(text)));
|
||||||
|
|
||||||
qiv = qmp_input_visitor_new(QOBJECT(ud2_dict));
|
qiv = qmp_input_visitor_new(QOBJECT(ud2_dict), false);
|
||||||
visit_type_UserDefTwo(qmp_input_get_visitor(qiv), NULL, &ud2, &err);
|
visit_type_UserDefTwo(qmp_input_get_visitor(qiv), NULL, &ud2, &err);
|
||||||
qmp_input_visitor_cleanup(qiv);
|
qmp_input_visitor_cleanup(qiv);
|
||||||
QDECREF(ud2_dict);
|
QDECREF(ud2_dict);
|
||||||
|
@ -55,7 +55,7 @@ static Visitor *validate_test_init_internal(TestInputVisitorData *data,
|
|||||||
data->obj = qobject_from_jsonv(json_string, ap);
|
data->obj = qobject_from_jsonv(json_string, ap);
|
||||||
g_assert(data->obj);
|
g_assert(data->obj);
|
||||||
|
|
||||||
data->qiv = qmp_input_visitor_new_strict(data->obj);
|
data->qiv = qmp_input_visitor_new(data->obj, true);
|
||||||
g_assert(data->qiv);
|
g_assert(data->qiv);
|
||||||
|
|
||||||
v = qmp_input_get_visitor(data->qiv);
|
v = qmp_input_get_visitor(data->qiv);
|
||||||
|
@ -51,7 +51,7 @@ static Visitor *visitor_input_test_init_internal(TestInputVisitorData *data,
|
|||||||
data->obj = qobject_from_jsonv(json_string, ap);
|
data->obj = qobject_from_jsonv(json_string, ap);
|
||||||
g_assert(data->obj);
|
g_assert(data->obj);
|
||||||
|
|
||||||
data->qiv = qmp_input_visitor_new(data->obj);
|
data->qiv = qmp_input_visitor_new(data->obj, false);
|
||||||
g_assert(data->qiv);
|
g_assert(data->qiv);
|
||||||
|
|
||||||
v = qmp_input_get_visitor(data->qiv);
|
v = qmp_input_get_visitor(data->qiv);
|
||||||
|
@ -1038,7 +1038,7 @@ static void qmp_deserialize(void **native_out, void *datap,
|
|||||||
obj = qobject_from_json(qstring_get_str(output_json));
|
obj = qobject_from_json(qstring_get_str(output_json));
|
||||||
|
|
||||||
QDECREF(output_json);
|
QDECREF(output_json);
|
||||||
d->qiv = qmp_input_visitor_new(obj);
|
d->qiv = qmp_input_visitor_new(obj, false);
|
||||||
qobject_decref(obj_orig);
|
qobject_decref(obj_orig);
|
||||||
qobject_decref(obj);
|
qobject_decref(obj);
|
||||||
visit(qmp_input_get_visitor(d->qiv), native_out, errp);
|
visit(qmp_input_get_visitor(d->qiv), native_out, errp);
|
||||||
|
@ -1145,7 +1145,7 @@ void qapi_copy_SocketAddress(SocketAddress **p_dest,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
qiv = qmp_input_visitor_new(obj);
|
qiv = qmp_input_visitor_new(obj, false);
|
||||||
iv = qmp_input_get_visitor(qiv);
|
iv = qmp_input_get_visitor(qiv);
|
||||||
visit_type_SocketAddress(iv, NULL, p_dest, &error_abort);
|
visit_type_SocketAddress(iv, NULL, p_dest, &error_abort);
|
||||||
qmp_input_visitor_cleanup(qiv);
|
qmp_input_visitor_cleanup(qiv);
|
||||||
|
Loading…
Reference in New Issue
Block a user