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:
Eric Blake 2016-04-28 15:45:13 -06:00 committed by Markus Armbruster
parent b471d012e5
commit fc471c18d5
12 changed files with 19 additions and 23 deletions

View File

@ -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;

View File

@ -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);

View File

@ -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
View File

@ -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);

View File

@ -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);

View File

@ -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);

View File

@ -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};

View File

@ -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);

View File

@ -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);

View File

@ -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);

View File

@ -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);

View File

@ -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);