aboutsummaryrefslogtreecommitdiff
path: root/tests/qapi-schema/args-name-clash.json
diff options
context:
space:
mode:
authorEric Blake <eblake@redhat.com>2015-11-18 01:52:51 -0700
committerMarkus Armbruster <armbru@redhat.com>2015-12-17 08:21:27 +0100
commit27b60ab93bd1d5d8c85f009aac7a97ffd2c53c86 (patch)
treee53959d5527ff0ba5f9f9da180cb84ae65727205 /tests/qapi-schema/args-name-clash.json
parent88d4ef8b5cbf9d3336564b1d3ac7a91cbe4aee0e (diff)
qapi: Detect collisions in C member names
Detect attempts to declare two object members that would result in the same C member name, by keying the 'seen' dictionary off of the C name rather than the qapi name. It also requires passing info through the check_clash() methods. This addresses a TODO and fixes the previously-broken args-name-clash test. The resulting error message demonstrates the utility of the .describe() method added previously. No change to generated code. Signed-off-by: Eric Blake <eblake@redhat.com> Message-Id: <1447836791-369-17-git-send-email-eblake@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
Diffstat (limited to 'tests/qapi-schema/args-name-clash.json')
-rw-r--r--tests/qapi-schema/args-name-clash.json5
1 files changed, 2 insertions, 3 deletions
diff --git a/tests/qapi-schema/args-name-clash.json b/tests/qapi-schema/args-name-clash.json
index 9e8f88916a..61423cb893 100644
--- a/tests/qapi-schema/args-name-clash.json
+++ b/tests/qapi-schema/args-name-clash.json
@@ -1,5 +1,4 @@
# C member name collision
-# FIXME - This parses, but fails to compile, because the C struct is given
-# two 'a_b' members. Either reject this at parse time, or munge the C names
-# to avoid the collision.
+# Reject members that clash when mapped to C names (we would have two 'a_b'
+# members).
{ 'command': 'oops', 'data': { 'a-b': 'str', 'a_b': 'str' } }