mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-11 06:55:37 +00:00
qapi: Eliminate QAPISchemaObjectType.check() variable members
We can use seen.values() instead if we make it an OrderedDict. Backports commit 23a4b2c6f19297cd067455c852b4874879594c13 from qemu
This commit is contained in:
parent
a0d6b16297
commit
8b6a605685
|
@ -977,26 +977,22 @@ class QAPISchemaObjectType(QAPISchemaType):
|
||||||
if self.members:
|
if self.members:
|
||||||
return
|
return
|
||||||
self.members = False # mark as being checked
|
self.members = False # mark as being checked
|
||||||
|
seen = OrderedDict()
|
||||||
if self._base_name:
|
if self._base_name:
|
||||||
self.base = schema.lookup_type(self._base_name)
|
self.base = schema.lookup_type(self._base_name)
|
||||||
assert isinstance(self.base, QAPISchemaObjectType)
|
assert isinstance(self.base, QAPISchemaObjectType)
|
||||||
assert not self.base.variants # not implemented
|
assert not self.base.variants # not implemented
|
||||||
self.base.check(schema)
|
self.base.check(schema)
|
||||||
members = list(self.base.members)
|
for m in self.base.members:
|
||||||
else:
|
|
||||||
members = []
|
|
||||||
seen = {}
|
|
||||||
for m in members:
|
|
||||||
assert m.name not in seen
|
assert m.name not in seen
|
||||||
seen[m.name] = m
|
seen[m.name] = m
|
||||||
for m in self.local_members:
|
for m in self.local_members:
|
||||||
m.check(schema)
|
m.check(schema)
|
||||||
assert m.name not in seen
|
assert m.name not in seen
|
||||||
seen[m.name] = m
|
seen[m.name] = m
|
||||||
members.append(m)
|
|
||||||
if self.variants:
|
if self.variants:
|
||||||
self.variants.check(schema, seen)
|
self.variants.check(schema, seen)
|
||||||
self.members = members
|
self.members = seen.values()
|
||||||
|
|
||||||
def is_implicit(self):
|
def is_implicit(self):
|
||||||
# See QAPISchema._make_implicit_object_type()
|
# See QAPISchema._make_implicit_object_type()
|
||||||
|
|
Loading…
Reference in a new issue