|
@@ -51,27 +51,6 @@ def generate_visit_struct_fields(name, field_prefix, fn_prefix, members, base =
|
|
|
else:
|
|
|
full_name = "%s_%s" % (name, fn_prefix)
|
|
|
|
|
|
- for argname, argentry, optional, structured in parse_args(members):
|
|
|
- if structured:
|
|
|
- if not fn_prefix:
|
|
|
- nested_fn_prefix = argname
|
|
|
- else:
|
|
|
- nested_fn_prefix = "%s_%s" % (fn_prefix, argname)
|
|
|
-
|
|
|
- nested_field_prefix = "%s%s." % (field_prefix, argname)
|
|
|
- ret += generate_visit_struct_fields(name, nested_field_prefix,
|
|
|
- nested_fn_prefix, argentry)
|
|
|
- ret += mcgen('''
|
|
|
-
|
|
|
-static void visit_type_%(full_name)s_field_%(c_name)s(Visitor *m, %(name)s **obj, Error **errp)
|
|
|
-{
|
|
|
-''',
|
|
|
- name=name, full_name=full_name, c_name=c_var(argname))
|
|
|
- ret += generate_visit_struct_body(full_name, argname, argentry)
|
|
|
- ret += mcgen('''
|
|
|
-}
|
|
|
-''')
|
|
|
-
|
|
|
if base:
|
|
|
ret += generate_visit_implicit_struct(base)
|
|
|
|
|
@@ -94,7 +73,7 @@ def generate_visit_struct_fields(name, field_prefix, fn_prefix, members, base =
|
|
|
c_prefix=c_var(field_prefix),
|
|
|
type=type_name(base), c_name=c_var('base'))
|
|
|
|
|
|
- for argname, argentry, optional, structured in parse_args(members):
|
|
|
+ for argname, argentry, optional in parse_args(members):
|
|
|
if optional:
|
|
|
ret += mcgen('''
|
|
|
visit_optional(m, &(*obj)->%(c_prefix)shas_%(c_name)s, "%(name)s", &err);
|
|
@@ -104,18 +83,12 @@ def generate_visit_struct_fields(name, field_prefix, fn_prefix, members, base =
|
|
|
c_name=c_var(argname), name=argname)
|
|
|
push_indent()
|
|
|
|
|
|
- if structured:
|
|
|
- ret += mcgen('''
|
|
|
-visit_type_%(full_name)s_field_%(c_name)s(m, obj, &err);
|
|
|
-''',
|
|
|
- full_name=full_name, c_name=c_var(argname))
|
|
|
- else:
|
|
|
- ret += mcgen('''
|
|
|
+ ret += mcgen('''
|
|
|
visit_type_%(type)s(m, &(*obj)->%(c_prefix)s%(c_name)s, "%(name)s", &err);
|
|
|
''',
|
|
|
- c_prefix=c_var(field_prefix), prefix=field_prefix,
|
|
|
- type=type_name(argentry), c_name=c_var(argname),
|
|
|
- name=argname)
|
|
|
+ c_prefix=c_var(field_prefix), prefix=field_prefix,
|
|
|
+ type=type_name(argentry), c_name=c_var(argname),
|
|
|
+ name=argname)
|
|
|
|
|
|
if optional:
|
|
|
pop_indent()
|