The previous patch demonstrated that the generator could get confused if an expression had conflicting meta-types, and silently ignored expressions that lacked a known meta-type. Fix both cases to give a sane error message.
* scripts/qapi.py (check_exprs): Require a valid meta-type for every expression. * tests/qapi-schema/indented-expr.*: Use valid types. * tests/qapi-schema/missing-type.*: Update expected output. * tests/qapi-schema/double-type.*: Likewise. Signed-off-by: Eric Blake <ebl...@redhat.com> --- scripts/qapi.py | 12 ++++++++++++ tests/qapi-schema/double-type.err | 1 + tests/qapi-schema/double-type.exit | 2 +- tests/qapi-schema/double-type.out | 3 --- tests/qapi-schema/indented-expr.json | 4 ++-- tests/qapi-schema/indented-expr.out | 2 +- tests/qapi-schema/missing-type.err | 1 + tests/qapi-schema/missing-type.exit | 2 +- tests/qapi-schema/missing-type.out | 3 --- 9 files changed, 19 insertions(+), 11 deletions(-) diff --git a/scripts/qapi.py b/scripts/qapi.py index 1082416..910e422 100644 --- a/scripts/qapi.py +++ b/scripts/qapi.py @@ -322,6 +322,18 @@ def check_exprs(schema): info = expr_elem['info'] members = expr.get('data') + # 'include' has already been flattened; at this point, all exprs + # should have one of the remaining keys + keys = (expr.has_key('enum') + expr.has_key('union') + + expr.has_key('type') + expr.has_key('command') + + expr.has_key('event')) + if keys < 1: + raise QAPIExprError(info, + "Missing expression meta-type") + if keys > 1: + raise QAPIExprError(info, + "Conflicting expression meta-types") + if expr.has_key('union'): check_union(expr, info) if expr.has_key('event'): diff --git a/tests/qapi-schema/double-type.err b/tests/qapi-schema/double-type.err index e69de29..2df4a12 100644 --- a/tests/qapi-schema/double-type.err +++ b/tests/qapi-schema/double-type.err @@ -0,0 +1 @@ +tests/qapi-schema/double-type.json:1: Conflicting expression meta-types diff --git a/tests/qapi-schema/double-type.exit b/tests/qapi-schema/double-type.exit index 573541a..d00491f 100644 --- a/tests/qapi-schema/double-type.exit +++ b/tests/qapi-schema/double-type.exit @@ -1 +1 @@ -0 +1 diff --git a/tests/qapi-schema/double-type.out b/tests/qapi-schema/double-type.out index 3e244f5..e69de29 100644 --- a/tests/qapi-schema/double-type.out +++ b/tests/qapi-schema/double-type.out @@ -1,3 +0,0 @@ -[OrderedDict([('command', 'foo'), ('type', 'bar'), ('data', OrderedDict())])] -[] -[OrderedDict([('command', 'foo'), ('type', 'bar'), ('data', OrderedDict())])] diff --git a/tests/qapi-schema/indented-expr.json b/tests/qapi-schema/indented-expr.json index d80af60..7115d31 100644 --- a/tests/qapi-schema/indented-expr.json +++ b/tests/qapi-schema/indented-expr.json @@ -1,2 +1,2 @@ -{ 'id' : 'eins' } - { 'id' : 'zwei' } +{ 'command' : 'eins' } + { 'command' : 'zwei' } diff --git a/tests/qapi-schema/indented-expr.out b/tests/qapi-schema/indented-expr.out index 98af89a..b5ce915 100644 --- a/tests/qapi-schema/indented-expr.out +++ b/tests/qapi-schema/indented-expr.out @@ -1,3 +1,3 @@ -[OrderedDict([('id', 'eins')]), OrderedDict([('id', 'zwei')])] +[OrderedDict([('command', 'eins')]), OrderedDict([('command', 'zwei')])] [] [] diff --git a/tests/qapi-schema/missing-type.err b/tests/qapi-schema/missing-type.err index e69de29..af650e0 100644 --- a/tests/qapi-schema/missing-type.err +++ b/tests/qapi-schema/missing-type.err @@ -0,0 +1 @@ +tests/qapi-schema/missing-type.json:1: Missing expression meta-type diff --git a/tests/qapi-schema/missing-type.exit b/tests/qapi-schema/missing-type.exit index 573541a..d00491f 100644 --- a/tests/qapi-schema/missing-type.exit +++ b/tests/qapi-schema/missing-type.exit @@ -1 +1 @@ -0 +1 diff --git a/tests/qapi-schema/missing-type.out b/tests/qapi-schema/missing-type.out index 67fd4fa..e69de29 100644 --- a/tests/qapi-schema/missing-type.out +++ b/tests/qapi-schema/missing-type.out @@ -1,3 +0,0 @@ -[OrderedDict([('data', OrderedDict())])] -[] -[] -- 1.9.3