qapi: Generate simpler marshalling code when no arguments

When command FOO has no arguments, its generated qmp_marshal_FOO() is
a bit confusing.  Make it simpler:

     visit_start_struct(v, NULL, NULL, 0, &err);
     if (err) {
         goto out;
     }
-
-    if (!err) {
-        visit_check_struct(v, &err);
-    }
+    visit_check_struct(v, &err);
     visit_end_struct(v, NULL);
     if (err) {
         goto out;
     }

Signed-off-by: Markus Armbruster <armbru@redhat.com>
Message-Id: <20200424084338.26803-16-armbru@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
Markus Armbruster 2020-04-24 10:43:38 +02:00
parent 2061487bdb
commit 89bf68f933

View file

@ -115,14 +115,10 @@ def gen_marshal(name, arg_type, boxed, ret_type):
c_type=ret_type.c_type()) c_type=ret_type.c_type())
if have_args: if have_args:
visit_members = ('visit_type_%s_members(v, &arg, &err);'
% arg_type.c_name())
ret += mcgen(''' ret += mcgen('''
%(c_name)s arg = {0}; %(c_name)s arg = {0};
''', ''',
c_name=arg_type.c_name()) c_name=arg_type.c_name())
else:
visit_members = ''
ret += mcgen(''' ret += mcgen('''
@ -131,16 +127,27 @@ def gen_marshal(name, arg_type, boxed, ret_type):
if (err) { if (err) {
goto out; goto out;
} }
%(visit_members)s ''')
if have_args:
ret += mcgen('''
visit_type_%(c_arg_type)s_members(v, &arg, &err);
if (!err) { if (!err) {
visit_check_struct(v, &err); visit_check_struct(v, &err);
} }
''',
c_arg_type=arg_type.c_name())
else:
ret += mcgen('''
visit_check_struct(v, &err);
''')
ret += mcgen('''
visit_end_struct(v, NULL); visit_end_struct(v, NULL);
if (err) { if (err) {
goto out; goto out;
} }
''', ''')
visit_members=visit_members)
ret += gen_call(name, arg_type, boxed, ret_type) ret += gen_call(name, arg_type, boxed, ret_type)
@ -151,20 +158,21 @@ out:
visit_free(v); visit_free(v);
''') ''')
if have_args:
visit_members = ('visit_type_%s_members(v, &arg, NULL);'
% arg_type.c_name())
else:
visit_members = ''
ret += mcgen(''' ret += mcgen('''
v = qapi_dealloc_visitor_new(); v = qapi_dealloc_visitor_new();
visit_start_struct(v, NULL, NULL, 0, NULL); visit_start_struct(v, NULL, NULL, 0, NULL);
%(visit_members)s ''')
if have_args:
ret += mcgen('''
visit_type_%(c_arg_type)s_members(v, &arg, NULL);
''',
c_arg_type=arg_type.c_name())
ret += mcgen('''
visit_end_struct(v, NULL); visit_end_struct(v, NULL);
visit_free(v); visit_free(v);
''', ''')
visit_members=visit_members)
ret += mcgen(''' ret += mcgen('''
} }