summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Snow2021-04-21 20:20:20 +0200
committerMarkus Armbruster2021-04-30 12:59:54 +0200
commitb66c62a2d3318c5d968d5b95428efb74ca5d5702 (patch)
treeb841021d21b56e9d5f890a9f185dac7bfdd80cb6
parentqapi/expr.py: constrain incoming expression types (diff)
downloadqemu-b66c62a2d3318c5d968d5b95428efb74ca5d5702.tar.gz
qemu-b66c62a2d3318c5d968d5b95428efb74ca5d5702.tar.xz
qemu-b66c62a2d3318c5d968d5b95428efb74ca5d5702.zip
qapi/expr.py: Add assertion for union type 'check_dict'
mypy isn't fond of allowing you to check for bool membership in a collection of str elements. Guard this lookup for precisely when we were given a name. Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Eduardo Habkost <ehabkost@redhat.com> Reviewed-by: Cleber Rosa <crosa@redhat.com> Message-Id: <20210421182032.3521476-6-jsnow@redhat.com> Reviewed-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
-rw-r--r--scripts/qapi/expr.py4
1 files changed, 3 insertions, 1 deletions
diff --git a/scripts/qapi/expr.py b/scripts/qapi/expr.py
index 06a0081001..3ab78a555d 100644
--- a/scripts/qapi/expr.py
+++ b/scripts/qapi/expr.py
@@ -194,7 +194,9 @@ def check_type(value, info, source,
raise QAPISemError(info,
"%s should be an object or type name" % source)
- permissive = allow_dict in info.pragma.member_name_exceptions
+ permissive = False
+ if isinstance(allow_dict, str):
+ permissive = allow_dict in info.pragma.member_name_exceptions
# value is a dictionary, check that each member is okay
for (key, arg) in value.items():