mirror of https://github.com/xemu-project/xemu.git
qapi: Add #if conditions to generated code members
Wrap generated enum and struct members and their supporting code with #if/#endif, using the .ifcond members added in the previous patches. We do enum and struct in a single patch because union tag enum and the associated variants tie them together, and dealing with that to split the patch doesn't seem worthwhile. Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Reviewed-by: Markus Armbruster <armbru@redhat.com> Message-Id: <20181213123724.4866-18-marcandre.lureau@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
3e270dcacc
commit
8ee06f61e1
|
@ -2078,11 +2078,13 @@ const QEnumLookup %(c_name)s_lookup = {
|
||||||
''',
|
''',
|
||||||
c_name=c_name(name))
|
c_name=c_name(name))
|
||||||
for m in members:
|
for m in members:
|
||||||
|
ret += gen_if(m.ifcond)
|
||||||
index = c_enum_const(name, m.name, prefix)
|
index = c_enum_const(name, m.name, prefix)
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
[%(index)s] = "%(name)s",
|
[%(index)s] = "%(name)s",
|
||||||
''',
|
''',
|
||||||
index=index, name=m.name)
|
index=index, name=m.name)
|
||||||
|
ret += gen_endif(m.ifcond)
|
||||||
|
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
},
|
},
|
||||||
|
@ -2104,10 +2106,12 @@ typedef enum %(c_name)s {
|
||||||
c_name=c_name(name))
|
c_name=c_name(name))
|
||||||
|
|
||||||
for m in enum_members:
|
for m in enum_members:
|
||||||
|
ret += gen_if(m.ifcond)
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
%(c_enum)s,
|
%(c_enum)s,
|
||||||
''',
|
''',
|
||||||
c_enum=c_enum_const(name, m.name, prefix))
|
c_enum=c_enum_const(name, m.name, prefix))
|
||||||
|
ret += gen_endif(m.ifcond)
|
||||||
|
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
} %(c_name)s;
|
} %(c_name)s;
|
||||||
|
|
|
@ -162,6 +162,8 @@ const QLitObject %(c_name)s = %(c_string)s;
|
||||||
ret = {'name': member.name, 'type': self._use_type(member.type)}
|
ret = {'name': member.name, 'type': self._use_type(member.type)}
|
||||||
if member.optional:
|
if member.optional:
|
||||||
ret['default'] = None
|
ret['default'] = None
|
||||||
|
if member.ifcond:
|
||||||
|
ret = (ret, {'if': member.ifcond})
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
def _gen_variants(self, tag_name, variants):
|
def _gen_variants(self, tag_name, variants):
|
||||||
|
@ -169,14 +171,17 @@ const QLitObject %(c_name)s = %(c_string)s;
|
||||||
'variants': [self._gen_variant(v) for v in variants]}
|
'variants': [self._gen_variant(v) for v in variants]}
|
||||||
|
|
||||||
def _gen_variant(self, variant):
|
def _gen_variant(self, variant):
|
||||||
return {'case': variant.name, 'type': self._use_type(variant.type)}
|
return ({'case': variant.name, 'type': self._use_type(variant.type)},
|
||||||
|
{'if': variant.ifcond})
|
||||||
|
|
||||||
def visit_builtin_type(self, name, info, json_type):
|
def visit_builtin_type(self, name, info, json_type):
|
||||||
self._gen_qlit(name, 'builtin', {'json-type': json_type}, [])
|
self._gen_qlit(name, 'builtin', {'json-type': json_type}, [])
|
||||||
|
|
||||||
def visit_enum_type(self, name, info, ifcond, members, prefix):
|
def visit_enum_type(self, name, info, ifcond, members, prefix):
|
||||||
self._gen_qlit(name, 'enum',
|
self._gen_qlit(name, 'enum',
|
||||||
{'values': [m.name for m in members]}, ifcond)
|
{'values':
|
||||||
|
[(m.name, {'if': m.ifcond}) for m in members]},
|
||||||
|
ifcond)
|
||||||
|
|
||||||
def visit_array_type(self, name, info, ifcond, element_type):
|
def visit_array_type(self, name, info, ifcond, element_type):
|
||||||
element = self._use_type(element_type)
|
element = self._use_type(element_type)
|
||||||
|
@ -192,8 +197,9 @@ const QLitObject %(c_name)s = %(c_string)s;
|
||||||
|
|
||||||
def visit_alternate_type(self, name, info, ifcond, variants):
|
def visit_alternate_type(self, name, info, ifcond, variants):
|
||||||
self._gen_qlit(name, 'alternate',
|
self._gen_qlit(name, 'alternate',
|
||||||
{'members': [{'type': self._use_type(m.type)}
|
{'members': [
|
||||||
for m in variants.variants]}, ifcond)
|
({'type': self._use_type(m.type)}, {'if': m.ifcond})
|
||||||
|
for m in variants.variants]}, ifcond)
|
||||||
|
|
||||||
def visit_command(self, name, info, ifcond, arg_type, ret_type, gen,
|
def visit_command(self, name, info, ifcond, arg_type, ret_type, gen,
|
||||||
success_response, boxed, allow_oob, allow_preconfig):
|
success_response, boxed, allow_oob, allow_preconfig):
|
||||||
|
|
|
@ -43,6 +43,7 @@ struct %(c_name)s {
|
||||||
def gen_struct_members(members):
|
def gen_struct_members(members):
|
||||||
ret = ''
|
ret = ''
|
||||||
for memb in members:
|
for memb in members:
|
||||||
|
ret += gen_if(memb.ifcond)
|
||||||
if memb.optional:
|
if memb.optional:
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
bool has_%(c_name)s;
|
bool has_%(c_name)s;
|
||||||
|
@ -52,6 +53,7 @@ def gen_struct_members(members):
|
||||||
%(c_type)s %(c_name)s;
|
%(c_type)s %(c_name)s;
|
||||||
''',
|
''',
|
||||||
c_type=memb.type.c_type(), c_name=c_name(memb.name))
|
c_type=memb.type.c_type(), c_name=c_name(memb.name))
|
||||||
|
ret += gen_endif(memb.ifcond)
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
|
|
||||||
|
@ -131,11 +133,13 @@ def gen_variants(variants):
|
||||||
for var in variants.variants:
|
for var in variants.variants:
|
||||||
if var.type.name == 'q_empty':
|
if var.type.name == 'q_empty':
|
||||||
continue
|
continue
|
||||||
|
ret += gen_if(var.ifcond)
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
%(c_type)s %(c_name)s;
|
%(c_type)s %(c_name)s;
|
||||||
''',
|
''',
|
||||||
c_type=var.type.c_unboxed_type(),
|
c_type=var.type.c_unboxed_type(),
|
||||||
c_name=c_name(var.name))
|
c_name=c_name(var.name))
|
||||||
|
ret += gen_endif(var.ifcond)
|
||||||
|
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
} u;
|
} u;
|
||||||
|
|
|
@ -54,6 +54,7 @@ void visit_type_%(c_name)s_members(Visitor *v, %(c_name)s *obj, Error **errp)
|
||||||
c_type=base.c_name())
|
c_type=base.c_name())
|
||||||
|
|
||||||
for memb in members:
|
for memb in members:
|
||||||
|
ret += gen_if(memb.ifcond)
|
||||||
if memb.optional:
|
if memb.optional:
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
if (visit_optional(v, "%(name)s", &obj->has_%(c_name)s)) {
|
if (visit_optional(v, "%(name)s", &obj->has_%(c_name)s)) {
|
||||||
|
@ -73,6 +74,7 @@ void visit_type_%(c_name)s_members(Visitor *v, %(c_name)s *obj, Error **errp)
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
}
|
}
|
||||||
''')
|
''')
|
||||||
|
ret += gen_endif(memb.ifcond)
|
||||||
|
|
||||||
if variants:
|
if variants:
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
|
@ -84,6 +86,7 @@ void visit_type_%(c_name)s_members(Visitor *v, %(c_name)s *obj, Error **errp)
|
||||||
case_str = c_enum_const(variants.tag_member.type.name,
|
case_str = c_enum_const(variants.tag_member.type.name,
|
||||||
var.name,
|
var.name,
|
||||||
variants.tag_member.type.prefix)
|
variants.tag_member.type.prefix)
|
||||||
|
ret += gen_if(var.ifcond)
|
||||||
if var.type.name == 'q_empty':
|
if var.type.name == 'q_empty':
|
||||||
# valid variant and nothing to do
|
# valid variant and nothing to do
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
|
@ -100,6 +103,7 @@ void visit_type_%(c_name)s_members(Visitor *v, %(c_name)s *obj, Error **errp)
|
||||||
case=case_str,
|
case=case_str,
|
||||||
c_type=var.type.c_name(), c_name=c_name(var.name))
|
c_type=var.type.c_name(), c_name=c_name(var.name))
|
||||||
|
|
||||||
|
ret += gen_endif(var.ifcond)
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
default:
|
default:
|
||||||
abort();
|
abort();
|
||||||
|
@ -190,6 +194,7 @@ void visit_type_%(c_name)s(Visitor *v, const char *name, %(c_name)s **obj, Error
|
||||||
c_name=c_name(name))
|
c_name=c_name(name))
|
||||||
|
|
||||||
for var in variants.variants:
|
for var in variants.variants:
|
||||||
|
ret += gen_if(var.ifcond)
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
case %(case)s:
|
case %(case)s:
|
||||||
''',
|
''',
|
||||||
|
@ -217,6 +222,7 @@ void visit_type_%(c_name)s(Visitor *v, const char *name, %(c_name)s **obj, Error
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
break;
|
break;
|
||||||
''')
|
''')
|
||||||
|
ret += gen_endif(var.ifcond)
|
||||||
|
|
||||||
ret += mcgen('''
|
ret += mcgen('''
|
||||||
case QTYPE_NONE:
|
case QTYPE_NONE:
|
||||||
|
|
Loading…
Reference in New Issue