提交 3f7dc21b 编写于 作者: M Markus Armbruster

qapi: New QAPISchemaVisitor

The visitor will help keeping the code generation code simple and
reasonably separated from QAPISchema details.
Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
Message-Id: <1442401589-24189-5-git-send-email-armbru@redhat.com>
Reviewed-by: NDaniel P. Berrange <berrange@redhat.com>
Reviewed-by: NEric Blake <eblake@redhat.com>
上级 f51d8c3d
...@@ -772,6 +772,39 @@ class QAPISchemaEntity(object): ...@@ -772,6 +772,39 @@ class QAPISchemaEntity(object):
def check(self, schema): def check(self, schema):
pass pass
def visit(self, visitor):
pass
class QAPISchemaVisitor(object):
def visit_begin(self, schema):
pass
def visit_end(self):
pass
def visit_builtin_type(self, name, info, json_type):
pass
def visit_enum_type(self, name, info, values, prefix):
pass
def visit_array_type(self, name, info, element_type):
pass
def visit_object_type(self, name, info, base, members, variants):
pass
def visit_alternate_type(self, name, info, variants):
pass
def visit_command(self, name, info, arg_type, ret_type,
gen, success_response):
pass
def visit_event(self, name, info, arg_type):
pass
class QAPISchemaType(QAPISchemaEntity): class QAPISchemaType(QAPISchemaEntity):
def c_type(self, is_param=False): def c_type(self, is_param=False):
...@@ -818,6 +851,9 @@ class QAPISchemaBuiltinType(QAPISchemaType): ...@@ -818,6 +851,9 @@ class QAPISchemaBuiltinType(QAPISchemaType):
def json_type(self): def json_type(self):
return self._json_type_name return self._json_type_name
def visit(self, visitor):
visitor.visit_builtin_type(self.name, self.info, self.json_type())
class QAPISchemaEnumType(QAPISchemaType): class QAPISchemaEnumType(QAPISchemaType):
def __init__(self, name, info, values, prefix): def __init__(self, name, info, values, prefix):
...@@ -841,6 +877,10 @@ class QAPISchemaEnumType(QAPISchemaType): ...@@ -841,6 +877,10 @@ class QAPISchemaEnumType(QAPISchemaType):
def json_type(self): def json_type(self):
return 'string' return 'string'
def visit(self, visitor):
visitor.visit_enum_type(self.name, self.info,
self.values, self.prefix)
class QAPISchemaArrayType(QAPISchemaType): class QAPISchemaArrayType(QAPISchemaType):
def __init__(self, name, info, element_type): def __init__(self, name, info, element_type):
...@@ -856,6 +896,9 @@ class QAPISchemaArrayType(QAPISchemaType): ...@@ -856,6 +896,9 @@ class QAPISchemaArrayType(QAPISchemaType):
def json_type(self): def json_type(self):
return 'array' return 'array'
def visit(self, visitor):
visitor.visit_array_type(self.name, self.info, self.element_type)
class QAPISchemaObjectType(QAPISchemaType): class QAPISchemaObjectType(QAPISchemaType):
def __init__(self, name, info, base, local_members, variants): def __init__(self, name, info, base, local_members, variants):
...@@ -904,6 +947,10 @@ class QAPISchemaObjectType(QAPISchemaType): ...@@ -904,6 +947,10 @@ class QAPISchemaObjectType(QAPISchemaType):
def json_type(self): def json_type(self):
return 'object' return 'object'
def visit(self, visitor):
visitor.visit_object_type(self.name, self.info,
self.base, self.local_members, self.variants)
class QAPISchemaObjectTypeMember(object): class QAPISchemaObjectTypeMember(object):
def __init__(self, name, typ, optional): def __init__(self, name, typ, optional):
...@@ -971,6 +1018,9 @@ class QAPISchemaAlternateType(QAPISchemaType): ...@@ -971,6 +1018,9 @@ class QAPISchemaAlternateType(QAPISchemaType):
def json_type(self): def json_type(self):
return 'value' return 'value'
def visit(self, visitor):
visitor.visit_alternate_type(self.name, self.info, self.variants)
class QAPISchemaCommand(QAPISchemaEntity): class QAPISchemaCommand(QAPISchemaEntity):
def __init__(self, name, info, arg_type, ret_type, gen, success_response): def __init__(self, name, info, arg_type, ret_type, gen, success_response):
...@@ -993,6 +1043,11 @@ class QAPISchemaCommand(QAPISchemaEntity): ...@@ -993,6 +1043,11 @@ class QAPISchemaCommand(QAPISchemaEntity):
self.ret_type = schema.lookup_type(self._ret_type_name) self.ret_type = schema.lookup_type(self._ret_type_name)
assert isinstance(self.ret_type, QAPISchemaType) assert isinstance(self.ret_type, QAPISchemaType)
def visit(self, visitor):
visitor.visit_command(self.name, self.info,
self.arg_type, self.ret_type,
self.gen, self.success_response)
class QAPISchemaEvent(QAPISchemaEntity): class QAPISchemaEvent(QAPISchemaEntity):
def __init__(self, name, info, arg_type): def __init__(self, name, info, arg_type):
...@@ -1007,6 +1062,9 @@ class QAPISchemaEvent(QAPISchemaEntity): ...@@ -1007,6 +1062,9 @@ class QAPISchemaEvent(QAPISchemaEntity):
assert isinstance(self.arg_type, QAPISchemaObjectType) assert isinstance(self.arg_type, QAPISchemaObjectType)
assert not self.arg_type.variants # not implemented assert not self.arg_type.variants # not implemented
def visit(self, visitor):
visitor.visit_event(self.name, self.info, self.arg_type)
class QAPISchema(object): class QAPISchema(object):
def __init__(self, fname): def __init__(self, fname):
...@@ -1204,6 +1262,12 @@ class QAPISchema(object): ...@@ -1204,6 +1262,12 @@ class QAPISchema(object):
for ent in self._entity_dict.values(): for ent in self._entity_dict.values():
ent.check(self) ent.check(self)
def visit(self, visitor):
visitor.visit_begin(self)
for name in sorted(self._entity_dict.keys()):
self._entity_dict[name].visit(visitor)
visitor.visit_end()
# #
# Code generation helpers # Code generation helpers
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册