提交 268a1c5e 编写于 作者: E Eric Blake 提交者: Markus Armbruster

qapi: Prepare for catching more semantic parse errors

This patch widens the scope of a try block (with the attending
reindentation required by Python) in preparation for a future
patch adding more instances of QAPIExprError inside the block.
It's easier to separate indentation from semantic changes, so
this patch has no real behavior change.
Signed-off-by: NEric Blake <eblake@redhat.com>
Reviewed-by: NMarkus Armbruster <armbru@redhat.com>
Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
上级 44bd1276
...@@ -399,6 +399,7 @@ def check_exprs(schema): ...@@ -399,6 +399,7 @@ def check_exprs(schema):
check_event(expr, info) check_event(expr, info)
def parse_schema(input_file): def parse_schema(input_file):
# First pass: read entire file into memory
try: try:
schema = QAPISchema(open(input_file, "r")) schema = QAPISchema(open(input_file, "r"))
except (QAPISchemaError, QAPIExprError), e: except (QAPISchemaError, QAPIExprError), e:
...@@ -407,24 +408,26 @@ def parse_schema(input_file): ...@@ -407,24 +408,26 @@ def parse_schema(input_file):
exprs = [] exprs = []
for expr_elem in schema.exprs:
expr = expr_elem['expr']
if expr.has_key('enum'):
add_enum(expr['enum'], expr.get('data'))
elif expr.has_key('union'):
add_union(expr)
elif expr.has_key('type'):
add_struct(expr)
exprs.append(expr)
# Try again for hidden UnionKind enum
for expr_elem in schema.exprs:
expr = expr_elem['expr']
if expr.has_key('union'):
if not discriminator_find_enum_define(expr):
add_enum('%sKind' % expr['union'])
try: try:
# Next pass: learn the types.
for expr_elem in schema.exprs:
expr = expr_elem['expr']
if expr.has_key('enum'):
add_enum(expr['enum'], expr.get('data'))
elif expr.has_key('union'):
add_union(expr)
elif expr.has_key('type'):
add_struct(expr)
exprs.append(expr)
# Try again for hidden UnionKind enum
for expr_elem in schema.exprs:
expr = expr_elem['expr']
if expr.has_key('union'):
if not discriminator_find_enum_define(expr):
add_enum('%sKind' % expr['union'])
# Final pass - validate that exprs make sense
check_exprs(schema) check_exprs(schema)
except QAPIExprError, e: except QAPIExprError, e:
print >>sys.stderr, e print >>sys.stderr, e
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册