diff options
author | Eric Blake <eblake@redhat.com> | 2015-05-04 09:05:37 -0600 |
---|---|---|
committer | Markus Armbruster <armbru@redhat.com> | 2015-05-05 18:39:02 +0200 |
commit | ff55d72eaf9628e7d58e7b067b361cdbf789c9f4 (patch) | |
tree | 39ff570f5e091ca43323e7270f80bb9176a9907f /tests/qapi-schema/struct-base-clash-deep.json | |
parent | a7f5966b297330f6492020019544ae87c45d699b (diff) | |
download | qemu-ff55d72eaf9628e7d58e7b067b361cdbf789c9f4.zip qemu-ff55d72eaf9628e7d58e7b067b361cdbf789c9f4.tar.gz qemu-ff55d72eaf9628e7d58e7b067b361cdbf789c9f4.tar.bz2 |
qapi: Check for member name conflicts with a base class
Our type inheritance for both 'struct' and for flat 'union' merges
key/value pairs from the base class with those from the type in
question. Although the C code currently boxes things so that there
is a distinction between which member is referred to, the QMP wire
format does not allow passing a key more than once in a single
object. Besides, if we ever change the generated C code to not be
quite so boxy, we'd want to avoid duplicate member names there,
too.
Fix a testsuite entry added in an earlier patch, as well as adding
a couple more tests to ensure we have appropriate coverage. Ensure
that collisions are detected, regardless of whether there is a
difference in opinion on whether the member name is optional.
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Markus Armbruster <armbru@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Diffstat (limited to 'tests/qapi-schema/struct-base-clash-deep.json')
-rw-r--r-- | tests/qapi-schema/struct-base-clash-deep.json | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/tests/qapi-schema/struct-base-clash-deep.json b/tests/qapi-schema/struct-base-clash-deep.json new file mode 100644 index 0000000..552fe94 --- /dev/null +++ b/tests/qapi-schema/struct-base-clash-deep.json @@ -0,0 +1,9 @@ +# we check for no duplicate keys with indirect base +{ 'struct': 'Base', + 'data': { 'name': 'str' } } +{ 'struct': 'Mid', + 'base': 'Base', + 'data': { 'value': 'int' } } +{ 'struct': 'Sub', + 'base': 'Mid', + 'data': { '*name': 'str' } } |