mirror of
https://github.com/xemu-project/xemu.git
synced 2024-11-24 03:59:52 +00:00
qapi: QAPISchema code generation helper methods
New methods c_name(), c_type(), c_null(), json_type(), alternate_qtype(). Signed-off-by: Markus Armbruster <armbru@redhat.com> Message-Id: <1442401589-24189-4-git-send-email-armbru@redhat.com> Reviewed-by: Daniel P. Berrange <berrange@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
parent
ac88219a6c
commit
f51d8c3db1
@ -766,17 +766,57 @@ class QAPISchemaEntity(object):
|
|||||||
self.name = name
|
self.name = name
|
||||||
self.info = info
|
self.info = info
|
||||||
|
|
||||||
|
def c_name(self):
|
||||||
|
return c_name(self.name)
|
||||||
|
|
||||||
def check(self, schema):
|
def check(self, schema):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
class QAPISchemaType(QAPISchemaEntity):
|
class QAPISchemaType(QAPISchemaEntity):
|
||||||
pass
|
def c_type(self, is_param=False):
|
||||||
|
return c_name(self.name) + pointer_suffix
|
||||||
|
|
||||||
|
def c_null(self):
|
||||||
|
return 'NULL'
|
||||||
|
|
||||||
|
def json_type(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def alternate_qtype(self):
|
||||||
|
json2qtype = {
|
||||||
|
'string': 'QTYPE_QSTRING',
|
||||||
|
'number': 'QTYPE_QFLOAT',
|
||||||
|
'int': 'QTYPE_QINT',
|
||||||
|
'boolean': 'QTYPE_QBOOL',
|
||||||
|
'object': 'QTYPE_QDICT'
|
||||||
|
}
|
||||||
|
return json2qtype.get(self.json_type())
|
||||||
|
|
||||||
|
|
||||||
class QAPISchemaBuiltinType(QAPISchemaType):
|
class QAPISchemaBuiltinType(QAPISchemaType):
|
||||||
def __init__(self, name):
|
def __init__(self, name, json_type, c_type, c_null):
|
||||||
QAPISchemaType.__init__(self, name, None)
|
QAPISchemaType.__init__(self, name, None)
|
||||||
|
assert not c_type or isinstance(c_type, str)
|
||||||
|
assert json_type in ('string', 'number', 'int', 'boolean', 'null',
|
||||||
|
'value')
|
||||||
|
self._json_type_name = json_type
|
||||||
|
self._c_type_name = c_type
|
||||||
|
self._c_null_val = c_null
|
||||||
|
|
||||||
|
def c_name(self):
|
||||||
|
return self.name
|
||||||
|
|
||||||
|
def c_type(self, is_param=False):
|
||||||
|
if is_param and self.name == 'str':
|
||||||
|
return 'const ' + self._c_type_name
|
||||||
|
return self._c_type_name
|
||||||
|
|
||||||
|
def c_null(self):
|
||||||
|
return self._c_null_val
|
||||||
|
|
||||||
|
def json_type(self):
|
||||||
|
return self._json_type_name
|
||||||
|
|
||||||
|
|
||||||
class QAPISchemaEnumType(QAPISchemaType):
|
class QAPISchemaEnumType(QAPISchemaType):
|
||||||
@ -791,6 +831,16 @@ class QAPISchemaEnumType(QAPISchemaType):
|
|||||||
def check(self, schema):
|
def check(self, schema):
|
||||||
assert len(set(self.values)) == len(self.values)
|
assert len(set(self.values)) == len(self.values)
|
||||||
|
|
||||||
|
def c_type(self, is_param=False):
|
||||||
|
return c_name(self.name)
|
||||||
|
|
||||||
|
def c_null(self):
|
||||||
|
return c_enum_const(self.name, (self.values + ['MAX'])[0],
|
||||||
|
self.prefix)
|
||||||
|
|
||||||
|
def json_type(self):
|
||||||
|
return 'string'
|
||||||
|
|
||||||
|
|
||||||
class QAPISchemaArrayType(QAPISchemaType):
|
class QAPISchemaArrayType(QAPISchemaType):
|
||||||
def __init__(self, name, info, element_type):
|
def __init__(self, name, info, element_type):
|
||||||
@ -803,6 +853,9 @@ class QAPISchemaArrayType(QAPISchemaType):
|
|||||||
self.element_type = schema.lookup_type(self._element_type_name)
|
self.element_type = schema.lookup_type(self._element_type_name)
|
||||||
assert self.element_type
|
assert self.element_type
|
||||||
|
|
||||||
|
def json_type(self):
|
||||||
|
return 'array'
|
||||||
|
|
||||||
|
|
||||||
class QAPISchemaObjectType(QAPISchemaType):
|
class QAPISchemaObjectType(QAPISchemaType):
|
||||||
def __init__(self, name, info, base, local_members, variants):
|
def __init__(self, name, info, base, local_members, variants):
|
||||||
@ -840,6 +893,17 @@ class QAPISchemaObjectType(QAPISchemaType):
|
|||||||
self.variants.check(schema, members, seen)
|
self.variants.check(schema, members, seen)
|
||||||
self.members = members
|
self.members = members
|
||||||
|
|
||||||
|
def c_name(self):
|
||||||
|
assert self.info
|
||||||
|
return QAPISchemaType.c_name(self)
|
||||||
|
|
||||||
|
def c_type(self, is_param=False):
|
||||||
|
assert self.info
|
||||||
|
return QAPISchemaType.c_type(self)
|
||||||
|
|
||||||
|
def json_type(self):
|
||||||
|
return 'object'
|
||||||
|
|
||||||
|
|
||||||
class QAPISchemaObjectTypeMember(object):
|
class QAPISchemaObjectTypeMember(object):
|
||||||
def __init__(self, name, typ, optional):
|
def __init__(self, name, typ, optional):
|
||||||
@ -904,6 +968,9 @@ class QAPISchemaAlternateType(QAPISchemaType):
|
|||||||
def check(self, schema):
|
def check(self, schema):
|
||||||
self.variants.check(schema, [], {})
|
self.variants.check(schema, [], {})
|
||||||
|
|
||||||
|
def json_type(self):
|
||||||
|
return 'value'
|
||||||
|
|
||||||
|
|
||||||
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):
|
||||||
@ -969,15 +1036,28 @@ class QAPISchema(object):
|
|||||||
def lookup_type(self, name):
|
def lookup_type(self, name):
|
||||||
return self.lookup_entity(name, QAPISchemaType)
|
return self.lookup_entity(name, QAPISchemaType)
|
||||||
|
|
||||||
def _def_builtin_type(self, name):
|
def _def_builtin_type(self, name, json_type, c_type, c_null):
|
||||||
self._def_entity(QAPISchemaBuiltinType(name))
|
self._def_entity(QAPISchemaBuiltinType(name, json_type,
|
||||||
|
c_type, c_null))
|
||||||
if name != '**':
|
if name != '**':
|
||||||
self._make_array_type(name) # TODO really needed?
|
self._make_array_type(name) # TODO really needed?
|
||||||
|
|
||||||
def _def_predefineds(self):
|
def _def_predefineds(self):
|
||||||
for t in ['str', 'number', 'int', 'int8', 'int16', 'int32', 'int64',
|
for t in [('str', 'string', 'char' + pointer_suffix, 'NULL'),
|
||||||
'uint8', 'uint16', 'uint32', 'uint64', 'size', 'bool', '**']:
|
('number', 'number', 'double', '0'),
|
||||||
self._def_builtin_type(t)
|
('int', 'int', 'int64_t', '0'),
|
||||||
|
('int8', 'int', 'int8_t', '0'),
|
||||||
|
('int16', 'int', 'int16_t', '0'),
|
||||||
|
('int32', 'int', 'int32_t', '0'),
|
||||||
|
('int64', 'int', 'int64_t', '0'),
|
||||||
|
('uint8', 'int', 'uint8_t', '0'),
|
||||||
|
('uint16', 'int', 'uint16_t', '0'),
|
||||||
|
('uint32', 'int', 'uint32_t', '0'),
|
||||||
|
('uint64', 'int', 'uint64_t', '0'),
|
||||||
|
('size', 'int', 'uint64_t', '0'),
|
||||||
|
('bool', 'boolean', 'bool', 'false'),
|
||||||
|
('**', 'value', None, None)]:
|
||||||
|
self._def_builtin_type(*t)
|
||||||
|
|
||||||
def _make_implicit_enum_type(self, name, values):
|
def _make_implicit_enum_type(self, name, values):
|
||||||
name = name + 'Kind'
|
name = name + 'Kind'
|
||||||
|
Loading…
Reference in New Issue
Block a user