mirror of https://github.com/xemu-project/xemu.git
qapi: add 'ifcond' to visitor methods
Modify the test visitor to check correct passing of values. Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Reviewed-by: Markus Armbruster <armbru@redhat.com> Message-Id: <20180703155648.11933-5-marcandre.lureau@redhat.com> [Accidental change to roms/seabios dropped] Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
4fca21c1b0
commit
fbf09a2fa4
|
@ -277,7 +277,7 @@ void %(c_prefix)sqmp_init_marshal(QmpCommandList *cmds);
|
||||||
c_prefix=c_name(self._prefix, protect=False)))
|
c_prefix=c_name(self._prefix, protect=False)))
|
||||||
genc.add(gen_registry(self._regy, self._prefix))
|
genc.add(gen_registry(self._regy, self._prefix))
|
||||||
|
|
||||||
def visit_command(self, name, info, 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):
|
||||||
if not gen:
|
if not gen:
|
||||||
return
|
return
|
||||||
|
|
|
@ -1062,26 +1062,26 @@ class QAPISchemaVisitor(object):
|
||||||
def visit_builtin_type(self, name, info, json_type):
|
def visit_builtin_type(self, name, info, json_type):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def visit_enum_type(self, name, info, values, prefix):
|
def visit_enum_type(self, name, info, ifcond, values, prefix):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def visit_array_type(self, name, info, element_type):
|
def visit_array_type(self, name, info, ifcond, element_type):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def visit_object_type(self, name, info, base, members, variants):
|
def visit_object_type(self, name, info, ifcond, base, members, variants):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def visit_object_type_flat(self, name, info, members, variants):
|
def visit_object_type_flat(self, name, info, ifcond, members, variants):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def visit_alternate_type(self, name, info, variants):
|
def visit_alternate_type(self, name, info, ifcond, variants):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def visit_command(self, name, info, 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):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def visit_event(self, name, info, arg_type, boxed):
|
def visit_event(self, name, info, ifcond, arg_type, boxed):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
@ -1191,7 +1191,7 @@ class QAPISchemaEnumType(QAPISchemaType):
|
||||||
return 'string'
|
return 'string'
|
||||||
|
|
||||||
def visit(self, visitor):
|
def visit(self, visitor):
|
||||||
visitor.visit_enum_type(self.name, self.info,
|
visitor.visit_enum_type(self.name, self.info, self.ifcond,
|
||||||
self.member_names(), self.prefix)
|
self.member_names(), self.prefix)
|
||||||
|
|
||||||
|
|
||||||
|
@ -1225,7 +1225,8 @@ class QAPISchemaArrayType(QAPISchemaType):
|
||||||
return 'array of ' + elt_doc_type
|
return 'array of ' + elt_doc_type
|
||||||
|
|
||||||
def visit(self, visitor):
|
def visit(self, visitor):
|
||||||
visitor.visit_array_type(self.name, self.info, self.element_type)
|
visitor.visit_array_type(self.name, self.info, self.ifcond,
|
||||||
|
self.element_type)
|
||||||
|
|
||||||
|
|
||||||
class QAPISchemaObjectType(QAPISchemaType):
|
class QAPISchemaObjectType(QAPISchemaType):
|
||||||
|
@ -1307,9 +1308,9 @@ class QAPISchemaObjectType(QAPISchemaType):
|
||||||
return 'object'
|
return 'object'
|
||||||
|
|
||||||
def visit(self, visitor):
|
def visit(self, visitor):
|
||||||
visitor.visit_object_type(self.name, self.info,
|
visitor.visit_object_type(self.name, self.info, self.ifcond,
|
||||||
self.base, self.local_members, self.variants)
|
self.base, self.local_members, self.variants)
|
||||||
visitor.visit_object_type_flat(self.name, self.info,
|
visitor.visit_object_type_flat(self.name, self.info, self.ifcond,
|
||||||
self.members, self.variants)
|
self.members, self.variants)
|
||||||
|
|
||||||
|
|
||||||
|
@ -1462,7 +1463,8 @@ class QAPISchemaAlternateType(QAPISchemaType):
|
||||||
return 'value'
|
return 'value'
|
||||||
|
|
||||||
def visit(self, visitor):
|
def visit(self, visitor):
|
||||||
visitor.visit_alternate_type(self.name, self.info, self.variants)
|
visitor.visit_alternate_type(self.name, self.info, self.ifcond,
|
||||||
|
self.variants)
|
||||||
|
|
||||||
def is_empty(self):
|
def is_empty(self):
|
||||||
return False
|
return False
|
||||||
|
@ -1505,7 +1507,7 @@ class QAPISchemaCommand(QAPISchemaEntity):
|
||||||
assert isinstance(self.ret_type, QAPISchemaType)
|
assert isinstance(self.ret_type, QAPISchemaType)
|
||||||
|
|
||||||
def visit(self, visitor):
|
def visit(self, visitor):
|
||||||
visitor.visit_command(self.name, self.info,
|
visitor.visit_command(self.name, self.info, self.ifcond,
|
||||||
self.arg_type, self.ret_type,
|
self.arg_type, self.ret_type,
|
||||||
self.gen, self.success_response,
|
self.gen, self.success_response,
|
||||||
self.boxed, self.allow_oob,
|
self.boxed, self.allow_oob,
|
||||||
|
@ -1538,7 +1540,8 @@ class QAPISchemaEvent(QAPISchemaEntity):
|
||||||
raise QAPISemError(self.info, "Use of 'boxed' requires 'data'")
|
raise QAPISemError(self.info, "Use of 'boxed' requires 'data'")
|
||||||
|
|
||||||
def visit(self, visitor):
|
def visit(self, visitor):
|
||||||
visitor.visit_event(self.name, self.info, self.arg_type, self.boxed)
|
visitor.visit_event(self.name, self.info, self.ifcond,
|
||||||
|
self.arg_type, self.boxed)
|
||||||
|
|
||||||
|
|
||||||
class QAPISchema(object):
|
class QAPISchema(object):
|
||||||
|
|
|
@ -204,14 +204,14 @@ class QAPISchemaGenDocVisitor(qapi.common.QAPISchemaVisitor):
|
||||||
def write(self, output_dir):
|
def write(self, output_dir):
|
||||||
self._gen.write(output_dir, self._prefix + 'qapi-doc.texi')
|
self._gen.write(output_dir, self._prefix + 'qapi-doc.texi')
|
||||||
|
|
||||||
def visit_enum_type(self, name, info, values, prefix):
|
def visit_enum_type(self, name, info, ifcond, values, prefix):
|
||||||
doc = self.cur_doc
|
doc = self.cur_doc
|
||||||
self._gen.add(TYPE_FMT(type='Enum',
|
self._gen.add(TYPE_FMT(type='Enum',
|
||||||
name=doc.symbol,
|
name=doc.symbol,
|
||||||
body=texi_entity(doc, 'Values',
|
body=texi_entity(doc, 'Values',
|
||||||
member_func=texi_enum_value)))
|
member_func=texi_enum_value)))
|
||||||
|
|
||||||
def visit_object_type(self, name, info, base, members, variants):
|
def visit_object_type(self, name, info, ifcond, base, members, variants):
|
||||||
doc = self.cur_doc
|
doc = self.cur_doc
|
||||||
if base and base.is_implicit():
|
if base and base.is_implicit():
|
||||||
base = None
|
base = None
|
||||||
|
@ -220,13 +220,13 @@ class QAPISchemaGenDocVisitor(qapi.common.QAPISchemaVisitor):
|
||||||
body=texi_entity(doc, 'Members',
|
body=texi_entity(doc, 'Members',
|
||||||
base, variants)))
|
base, variants)))
|
||||||
|
|
||||||
def visit_alternate_type(self, name, info, variants):
|
def visit_alternate_type(self, name, info, ifcond, variants):
|
||||||
doc = self.cur_doc
|
doc = self.cur_doc
|
||||||
self._gen.add(TYPE_FMT(type='Alternate',
|
self._gen.add(TYPE_FMT(type='Alternate',
|
||||||
name=doc.symbol,
|
name=doc.symbol,
|
||||||
body=texi_entity(doc, 'Members')))
|
body=texi_entity(doc, 'Members')))
|
||||||
|
|
||||||
def visit_command(self, name, info, 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):
|
||||||
doc = self.cur_doc
|
doc = self.cur_doc
|
||||||
if boxed:
|
if boxed:
|
||||||
|
@ -240,7 +240,7 @@ class QAPISchemaGenDocVisitor(qapi.common.QAPISchemaVisitor):
|
||||||
name=doc.symbol,
|
name=doc.symbol,
|
||||||
body=body))
|
body=body))
|
||||||
|
|
||||||
def visit_event(self, name, info, arg_type, boxed):
|
def visit_event(self, name, info, ifcond, arg_type, boxed):
|
||||||
doc = self.cur_doc
|
doc = self.cur_doc
|
||||||
self._gen.add(MSG_FMT(type='Event',
|
self._gen.add(MSG_FMT(type='Event',
|
||||||
name=doc.symbol,
|
name=doc.symbol,
|
||||||
|
|
|
@ -184,7 +184,7 @@ class QAPISchemaGenEventVisitor(QAPISchemaModularCVisitor):
|
||||||
genh.add(gen_enum(self._enum_name, self._event_names))
|
genh.add(gen_enum(self._enum_name, self._event_names))
|
||||||
genc.add(gen_enum_lookup(self._enum_name, self._event_names))
|
genc.add(gen_enum_lookup(self._enum_name, self._event_names))
|
||||||
|
|
||||||
def visit_event(self, name, info, arg_type, boxed):
|
def visit_event(self, name, info, ifcond, arg_type, boxed):
|
||||||
self._genh.add(gen_event_send_decl(name, arg_type, boxed))
|
self._genh.add(gen_event_send_decl(name, arg_type, boxed))
|
||||||
self._genc.add(gen_event_send(name, arg_type, boxed, self._enum_name))
|
self._genc.add(gen_event_send(name, arg_type, boxed, self._enum_name))
|
||||||
self._event_names.append(name)
|
self._event_names.append(name)
|
||||||
|
|
|
@ -149,26 +149,26 @@ const QLitObject %(c_name)s = %(c_string)s;
|
||||||
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, values, prefix):
|
def visit_enum_type(self, name, info, ifcond, values, prefix):
|
||||||
self._gen_qlit(name, 'enum', {'values': values})
|
self._gen_qlit(name, 'enum', {'values': values})
|
||||||
|
|
||||||
def visit_array_type(self, name, info, element_type):
|
def visit_array_type(self, name, info, ifcond, element_type):
|
||||||
element = self._use_type(element_type)
|
element = self._use_type(element_type)
|
||||||
self._gen_qlit('[' + element + ']', 'array', {'element-type': element})
|
self._gen_qlit('[' + element + ']', 'array', {'element-type': element})
|
||||||
|
|
||||||
def visit_object_type_flat(self, name, info, members, variants):
|
def visit_object_type_flat(self, name, info, ifcond, members, variants):
|
||||||
obj = {'members': [self._gen_member(m) for m in members]}
|
obj = {'members': [self._gen_member(m) for m in members]}
|
||||||
if variants:
|
if variants:
|
||||||
obj.update(self._gen_variants(variants.tag_member.name,
|
obj.update(self._gen_variants(variants.tag_member.name,
|
||||||
variants.variants))
|
variants.variants))
|
||||||
self._gen_qlit(name, 'object', obj)
|
self._gen_qlit(name, 'object', obj)
|
||||||
|
|
||||||
def visit_alternate_type(self, name, info, 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': [{'type': self._use_type(m.type)}
|
||||||
for m in variants.variants]})
|
for m in variants.variants]})
|
||||||
|
|
||||||
def visit_command(self, name, info, 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):
|
||||||
arg_type = arg_type or self._schema.the_empty_object_type
|
arg_type = arg_type or self._schema.the_empty_object_type
|
||||||
ret_type = ret_type or self._schema.the_empty_object_type
|
ret_type = ret_type or self._schema.the_empty_object_type
|
||||||
|
@ -178,7 +178,7 @@ const QLitObject %(c_name)s = %(c_string)s;
|
||||||
'allow-oob': allow_oob,
|
'allow-oob': allow_oob,
|
||||||
'allow-preconfig': allow_preconfig})
|
'allow-preconfig': allow_preconfig})
|
||||||
|
|
||||||
def visit_event(self, name, info, arg_type, boxed):
|
def visit_event(self, name, info, ifcond, arg_type, boxed):
|
||||||
arg_type = arg_type or self._schema.the_empty_object_type
|
arg_type = arg_type or self._schema.the_empty_object_type
|
||||||
self._gen_qlit(name, 'event', {'arg-type': self._use_type(arg_type)})
|
self._gen_qlit(name, 'event', {'arg-type': self._use_type(arg_type)})
|
||||||
|
|
||||||
|
|
|
@ -208,16 +208,16 @@ class QAPISchemaGenTypeVisitor(QAPISchemaModularCVisitor):
|
||||||
self._genh.add(gen_type_cleanup_decl(name))
|
self._genh.add(gen_type_cleanup_decl(name))
|
||||||
self._genc.add(gen_type_cleanup(name))
|
self._genc.add(gen_type_cleanup(name))
|
||||||
|
|
||||||
def visit_enum_type(self, name, info, values, prefix):
|
def visit_enum_type(self, name, info, ifcond, values, prefix):
|
||||||
self._genh.preamble_add(gen_enum(name, values, prefix))
|
self._genh.preamble_add(gen_enum(name, values, prefix))
|
||||||
self._genc.add(gen_enum_lookup(name, values, prefix))
|
self._genc.add(gen_enum_lookup(name, values, prefix))
|
||||||
|
|
||||||
def visit_array_type(self, name, info, element_type):
|
def visit_array_type(self, name, info, ifcond, element_type):
|
||||||
self._genh.preamble_add(gen_fwd_object_or_array(name))
|
self._genh.preamble_add(gen_fwd_object_or_array(name))
|
||||||
self._genh.add(gen_array(name, element_type))
|
self._genh.add(gen_array(name, element_type))
|
||||||
self._gen_type_cleanup(name)
|
self._gen_type_cleanup(name)
|
||||||
|
|
||||||
def visit_object_type(self, name, info, base, members, variants):
|
def visit_object_type(self, name, info, ifcond, base, members, variants):
|
||||||
# Nothing to do for the special empty builtin
|
# Nothing to do for the special empty builtin
|
||||||
if name == 'q_empty':
|
if name == 'q_empty':
|
||||||
return
|
return
|
||||||
|
@ -231,7 +231,7 @@ class QAPISchemaGenTypeVisitor(QAPISchemaModularCVisitor):
|
||||||
# implicit types won't be directly allocated/freed
|
# implicit types won't be directly allocated/freed
|
||||||
self._gen_type_cleanup(name)
|
self._gen_type_cleanup(name)
|
||||||
|
|
||||||
def visit_alternate_type(self, name, info, variants):
|
def visit_alternate_type(self, name, info, ifcond, variants):
|
||||||
self._genh.preamble_add(gen_fwd_object_or_array(name))
|
self._genh.preamble_add(gen_fwd_object_or_array(name))
|
||||||
self._genh.add(gen_object(name, None,
|
self._genh.add(gen_object(name, None,
|
||||||
[variants.tag_member], variants))
|
[variants.tag_member], variants))
|
||||||
|
|
|
@ -310,15 +310,15 @@ class QAPISchemaGenVisitVisitor(QAPISchemaModularCVisitor):
|
||||||
''',
|
''',
|
||||||
types=types))
|
types=types))
|
||||||
|
|
||||||
def visit_enum_type(self, name, info, values, prefix):
|
def visit_enum_type(self, name, info, ifcond, values, prefix):
|
||||||
self._genh.add(gen_visit_decl(name, scalar=True))
|
self._genh.add(gen_visit_decl(name, scalar=True))
|
||||||
self._genc.add(gen_visit_enum(name))
|
self._genc.add(gen_visit_enum(name))
|
||||||
|
|
||||||
def visit_array_type(self, name, info, element_type):
|
def visit_array_type(self, name, info, ifcond, element_type):
|
||||||
self._genh.add(gen_visit_decl(name))
|
self._genh.add(gen_visit_decl(name))
|
||||||
self._genc.add(gen_visit_list(name, element_type))
|
self._genc.add(gen_visit_list(name, element_type))
|
||||||
|
|
||||||
def visit_object_type(self, name, info, base, members, variants):
|
def visit_object_type(self, name, info, ifcond, base, members, variants):
|
||||||
# Nothing to do for the special empty builtin
|
# Nothing to do for the special empty builtin
|
||||||
if name == 'q_empty':
|
if name == 'q_empty':
|
||||||
return
|
return
|
||||||
|
@ -331,7 +331,7 @@ class QAPISchemaGenVisitVisitor(QAPISchemaModularCVisitor):
|
||||||
self._genh.add(gen_visit_decl(name))
|
self._genh.add(gen_visit_decl(name))
|
||||||
self._genc.add(gen_visit_object(name, base, members, variants))
|
self._genc.add(gen_visit_object(name, base, members, variants))
|
||||||
|
|
||||||
def visit_alternate_type(self, name, info, variants):
|
def visit_alternate_type(self, name, info, ifcond, variants):
|
||||||
self._genh.add(gen_visit_decl(name))
|
self._genh.add(gen_visit_decl(name))
|
||||||
self._genc.add(gen_visit_alternate(name, variants))
|
self._genc.add(gen_visit_alternate(name, variants))
|
||||||
|
|
||||||
|
|
|
@ -237,25 +237,34 @@ command __org.qemu_x-command q_obj___org.qemu_x-command-arg -> __org.qemu_x-Unio
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
object TestIfStruct
|
object TestIfStruct
|
||||||
member foo: int optional=False
|
member foo: int optional=False
|
||||||
|
if ['defined(TEST_IF_STRUCT)']
|
||||||
enum TestIfEnum ['foo', 'bar']
|
enum TestIfEnum ['foo', 'bar']
|
||||||
|
if ['defined(TEST_IF_ENUM)']
|
||||||
object q_obj_TestStruct-wrapper
|
object q_obj_TestStruct-wrapper
|
||||||
member data: TestStruct optional=False
|
member data: TestStruct optional=False
|
||||||
enum TestIfUnionKind ['foo']
|
enum TestIfUnionKind ['foo']
|
||||||
|
if ['defined(TEST_IF_UNION) && defined(TEST_IF_STRUCT)']
|
||||||
object TestIfUnion
|
object TestIfUnion
|
||||||
member type: TestIfUnionKind optional=False
|
member type: TestIfUnionKind optional=False
|
||||||
tag type
|
tag type
|
||||||
case foo: q_obj_TestStruct-wrapper
|
case foo: q_obj_TestStruct-wrapper
|
||||||
|
if ['defined(TEST_IF_UNION) && defined(TEST_IF_STRUCT)']
|
||||||
alternate TestIfAlternate
|
alternate TestIfAlternate
|
||||||
tag type
|
tag type
|
||||||
case foo: int
|
case foo: int
|
||||||
case bar: TestStruct
|
case bar: TestStruct
|
||||||
|
if ['defined(TEST_IF_ALT) && defined(TEST_IF_STRUCT)']
|
||||||
object q_obj_TestIfCmd-arg
|
object q_obj_TestIfCmd-arg
|
||||||
member foo: TestIfStruct optional=False
|
member foo: TestIfStruct optional=False
|
||||||
|
if ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)']
|
||||||
command TestIfCmd q_obj_TestIfCmd-arg -> UserDefThree
|
command TestIfCmd q_obj_TestIfCmd-arg -> UserDefThree
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
|
if ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)']
|
||||||
command TestCmdReturnDefThree None -> UserDefThree
|
command TestCmdReturnDefThree None -> UserDefThree
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
object q_obj_TestIfEvent-arg
|
object q_obj_TestIfEvent-arg
|
||||||
member foo: TestIfStruct optional=False
|
member foo: TestIfStruct optional=False
|
||||||
|
if ['defined(TEST_IF_EVT) && defined(TEST_IF_STRUCT)']
|
||||||
event TestIfEvent q_obj_TestIfEvent-arg
|
event TestIfEvent q_obj_TestIfEvent-arg
|
||||||
boxed=False
|
boxed=False
|
||||||
|
if ['defined(TEST_IF_EVT) && defined(TEST_IF_STRUCT)']
|
||||||
|
|
|
@ -23,12 +23,13 @@ class QAPISchemaTestVisitor(QAPISchemaVisitor):
|
||||||
def visit_include(self, name, info):
|
def visit_include(self, name, info):
|
||||||
print('include %s' % name)
|
print('include %s' % name)
|
||||||
|
|
||||||
def visit_enum_type(self, name, info, values, prefix):
|
def visit_enum_type(self, name, info, ifcond, values, prefix):
|
||||||
print('enum %s %s' % (name, values))
|
print('enum %s %s' % (name, values))
|
||||||
if prefix:
|
if prefix:
|
||||||
print(' prefix %s' % prefix)
|
print(' prefix %s' % prefix)
|
||||||
|
self._print_if(ifcond)
|
||||||
|
|
||||||
def visit_object_type(self, name, info, base, members, variants):
|
def visit_object_type(self, name, info, ifcond, base, members, variants):
|
||||||
print('object %s' % name)
|
print('object %s' % name)
|
||||||
if base:
|
if base:
|
||||||
print(' base %s' % base.name)
|
print(' base %s' % base.name)
|
||||||
|
@ -36,21 +37,25 @@ class QAPISchemaTestVisitor(QAPISchemaVisitor):
|
||||||
print(' member %s: %s optional=%s' % \
|
print(' member %s: %s optional=%s' % \
|
||||||
(m.name, m.type.name, m.optional))
|
(m.name, m.type.name, m.optional))
|
||||||
self._print_variants(variants)
|
self._print_variants(variants)
|
||||||
|
self._print_if(ifcond)
|
||||||
|
|
||||||
def visit_alternate_type(self, name, info, variants):
|
def visit_alternate_type(self, name, info, ifcond, variants):
|
||||||
print('alternate %s' % name)
|
print('alternate %s' % name)
|
||||||
self._print_variants(variants)
|
self._print_variants(variants)
|
||||||
|
self._print_if(ifcond)
|
||||||
|
|
||||||
def visit_command(self, name, info, 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):
|
||||||
print('command %s %s -> %s' % \
|
print('command %s %s -> %s' % \
|
||||||
(name, arg_type and arg_type.name, ret_type and ret_type.name))
|
(name, arg_type and arg_type.name, ret_type and ret_type.name))
|
||||||
print(' gen=%s success_response=%s boxed=%s oob=%s preconfig=%s' % \
|
print(' gen=%s success_response=%s boxed=%s oob=%s preconfig=%s' % \
|
||||||
(gen, success_response, boxed, allow_oob, allow_preconfig))
|
(gen, success_response, boxed, allow_oob, allow_preconfig))
|
||||||
|
self._print_if(ifcond)
|
||||||
|
|
||||||
def visit_event(self, name, info, arg_type, boxed):
|
def visit_event(self, name, info, ifcond, arg_type, boxed):
|
||||||
print('event %s %s' % (name, arg_type and arg_type.name))
|
print('event %s %s' % (name, arg_type and arg_type.name))
|
||||||
print(' boxed=%s' % boxed)
|
print(' boxed=%s' % boxed)
|
||||||
|
self._print_if(ifcond)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _print_variants(variants):
|
def _print_variants(variants):
|
||||||
|
@ -59,6 +64,11 @@ class QAPISchemaTestVisitor(QAPISchemaVisitor):
|
||||||
for v in variants.variants:
|
for v in variants.variants:
|
||||||
print(' case %s: %s' % (v.name, v.type.name))
|
print(' case %s: %s' % (v.name, v.type.name))
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _print_if(ifcond, indent=4):
|
||||||
|
if ifcond:
|
||||||
|
print('%sif %s' % (' ' * indent, ifcond))
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
schema = QAPISchema(sys.argv[1])
|
schema = QAPISchema(sys.argv[1])
|
||||||
|
|
Loading…
Reference in New Issue