14f193e34SMarkus Armbruster# *-*- Mode: Python -*-*
24f193e34SMarkus Armbruster
34f193e34SMarkus Armbruster# for testing enums
44f193e34SMarkus Armbruster{ 'enum': 'EnumOne',
54f193e34SMarkus Armbruster  'data': [ 'value1', 'value2', 'value3' ] }
6895a2a80SEric Blake{ 'struct': 'NestedEnumsOne',
74f193e34SMarkus Armbruster  'data': { 'enum1': 'EnumOne', '*enum2': 'EnumOne', 'enum3': 'EnumOne', '*enum4': 'EnumOne' } }
84f193e34SMarkus Armbruster
9351d36e4SDaniel P. Berrange# for testing override of default naming heuristic
10351d36e4SDaniel P. Berrange{ 'enum': 'QEnumTwo',
11351d36e4SDaniel P. Berrange  'prefix': 'QENUM_TWO',
12351d36e4SDaniel P. Berrange  'data': [ 'value1', 'value2' ] }
13351d36e4SDaniel P. Berrange
144f193e34SMarkus Armbruster# for testing nested structs
158c3f8e77SMarkus Armbruster{ 'struct': 'UserDefOne',
168c3f8e77SMarkus Armbruster  'base': 'UserDefZero',        # intentional forward reference
178c3f8e77SMarkus Armbruster  'data': { 'string': 'str', '*enum1': 'EnumOne' } }
188c3f8e77SMarkus Armbruster
19895a2a80SEric Blake{ 'struct': 'UserDefZero',
20aabbd472SMarkus Armbruster  'data': { 'integer': 'int' } }
21aabbd472SMarkus Armbruster
226446a592SEric Blake{ 'struct': 'UserDefTwoDictDict',
236446a592SEric Blake  'data': { 'userdef': 'UserDefOne', 'string': 'str' } }
246446a592SEric Blake
256446a592SEric Blake{ 'struct': 'UserDefTwoDict',
266446a592SEric Blake  'data': { 'string1': 'str',
276446a592SEric Blake            'dict2': 'UserDefTwoDictDict',
286446a592SEric Blake            '*dict3': 'UserDefTwoDictDict' } }
296446a592SEric Blake
30895a2a80SEric Blake{ 'struct': 'UserDefTwo',
314f193e34SMarkus Armbruster  'data': { 'string0': 'str',
326446a592SEric Blake            'dict1': 'UserDefTwoDict' } }
334f193e34SMarkus Armbruster
344f193e34SMarkus Armbruster# for testing unions
35d220fbcdSEric Blake# Among other things, test that a name collision between branches does
36d220fbcdSEric Blake# not cause any problems (since only one branch can be in use at a time),
37d220fbcdSEric Blake# by intentionally using two branches that both have a C member 'a_b'
38895a2a80SEric Blake{ 'struct': 'UserDefA',
39d220fbcdSEric Blake  'data': { 'boolean': 'bool', '*a_b': 'int' } }
404f193e34SMarkus Armbruster
41895a2a80SEric Blake{ 'struct': 'UserDefB',
42d220fbcdSEric Blake  'data': { 'intb': 'int', '*a-b': 'bool' } }
434f193e34SMarkus Armbruster
448c3f8e77SMarkus Armbruster{ 'union': 'UserDefFlatUnion',
458c3f8e77SMarkus Armbruster  'base': 'UserDefUnionBase',   # intentional forward reference
468c3f8e77SMarkus Armbruster  'discriminator': 'enum1',
478c3f8e77SMarkus Armbruster  'data': { 'value1' : 'UserDefA',
488c3f8e77SMarkus Armbruster            'value2' : 'UserDefB',
498c3f8e77SMarkus Armbruster            'value3' : 'UserDefB' } }
50cb55111bSMichael Roth
51895a2a80SEric Blake{ 'struct': 'UserDefUnionBase',
5280e60a19SMarkus Armbruster  'base': 'UserDefZero',
535223070cSWenchao Xia  'data': { 'string': 'str', 'enum1': 'EnumOne' } }
545223070cSWenchao Xia
55cb55111bSMichael Roth# this variant of UserDefFlatUnion defaults to a union that uses fields with
56cb55111bSMichael Roth# allocated types to test corner cases in the cleanup/dealloc visitor
57cb55111bSMichael Roth{ 'union': 'UserDefFlatUnion2',
58cb55111bSMichael Roth  'base': 'UserDefUnionBase',
59cb55111bSMichael Roth  'discriminator': 'enum1',
608c3f8e77SMarkus Armbruster  'data': { 'value1' : 'UserDefC', # intentional forward reference
618c3f8e77SMarkus Armbruster            'value2' : 'UserDefB',
628c3f8e77SMarkus Armbruster            'value3' : 'UserDefA' } }
63cb55111bSMichael Roth
64ab916fadSEric Blake{ 'alternate': 'UserDefAlternate',
652c38b600SMarkus Armbruster  'data': { 'uda': 'UserDefA', 's': 'str', 'i': 'int' } }
662c38b600SMarkus Armbruster
678c3f8e77SMarkus Armbruster{ 'struct': 'UserDefC',
688c3f8e77SMarkus Armbruster  'data': { 'string1': 'str', 'string2': 'str' } }
698c3f8e77SMarkus Armbruster
70*9c51b441SEric Blake# for testing use of 'number' within alternates
71*9c51b441SEric Blake{ 'alternate': 'AltStrBool', 'data': { 's': 'str', 'b': 'bool' } }
72*9c51b441SEric Blake{ 'alternate': 'AltStrNum', 'data': { 's': 'str', 'n': 'number' } }
73*9c51b441SEric Blake{ 'alternate': 'AltNumStr', 'data': { 'n': 'number', 's': 'str' } }
74*9c51b441SEric Blake{ 'alternate': 'AltStrInt', 'data': { 's': 'str', 'i': 'int' } }
75*9c51b441SEric Blake{ 'alternate': 'AltIntNum', 'data': { 'i': 'int', 'n': 'number' } }
76*9c51b441SEric Blake{ 'alternate': 'AltNumInt', 'data': { 'n': 'number', 'i': 'int' } }
77*9c51b441SEric Blake
784f193e34SMarkus Armbruster# for testing native lists
794f193e34SMarkus Armbruster{ 'union': 'UserDefNativeListUnion',
804f193e34SMarkus Armbruster  'data': { 'integer': ['int'],
814f193e34SMarkus Armbruster            's8': ['int8'],
824f193e34SMarkus Armbruster            's16': ['int16'],
834f193e34SMarkus Armbruster            's32': ['int32'],
844f193e34SMarkus Armbruster            's64': ['int64'],
854f193e34SMarkus Armbruster            'u8': ['uint8'],
864f193e34SMarkus Armbruster            'u16': ['uint16'],
874f193e34SMarkus Armbruster            'u32': ['uint32'],
884f193e34SMarkus Armbruster            'u64': ['uint64'],
894f193e34SMarkus Armbruster            'number': ['number'],
904f193e34SMarkus Armbruster            'boolean': ['bool'],
91cb17f79eSEric Blake            'string': ['str'],
9228770e05SMarkus Armbruster            'sizes': ['size'],
9328770e05SMarkus Armbruster            'any': ['any'] } }
944f193e34SMarkus Armbruster
954f193e34SMarkus Armbruster# testing commands
964f193e34SMarkus Armbruster{ 'command': 'user_def_cmd', 'data': {} }
974f193e34SMarkus Armbruster{ 'command': 'user_def_cmd1', 'data': {'ud1a': 'UserDefOne'} }
98ab22ad96SMarkus Armbruster{ 'command': 'user_def_cmd2',
99ab22ad96SMarkus Armbruster  'data': {'ud1a': 'UserDefOne', '*ud1b': 'UserDefOne'},
100ab22ad96SMarkus Armbruster  'returns': 'UserDefTwo' }
101c2216a8aSMarkus Armbruster{ 'command': 'user_def_cmd3', 'data': {'a': 'int', '*b': 'int' },
102c2216a8aSMarkus Armbruster  'returns': 'int' }
10328770e05SMarkus Armbruster# note: command name 'guest-sync' chosen to avoid "cannot use built-in" error
10428770e05SMarkus Armbruster{ 'command': 'guest-sync', 'data': { 'arg': 'any' }, 'returns': 'any' }
1053953e3a5SLaszlo Ersek
1063953e3a5SLaszlo Ersek# For testing integer range flattening in opts-visitor. The following schema
1073953e3a5SLaszlo Ersek# corresponds to the option format:
1083953e3a5SLaszlo Ersek#
1093953e3a5SLaszlo Ersek# -userdef i64=3-6,i64=-5--1,u64=2,u16=1,u16=7-12
1103953e3a5SLaszlo Ersek#
1113953e3a5SLaszlo Ersek# For simplicity, this example doesn't use [type=]discriminator nor optargs
1123953e3a5SLaszlo Ersek# specific to discriminator values.
113895a2a80SEric Blake{ 'struct': 'UserDefOptions',
1143953e3a5SLaszlo Ersek  'data': {
1153953e3a5SLaszlo Ersek    '*i64' : [ 'int'    ],
1163953e3a5SLaszlo Ersek    '*u64' : [ 'uint64' ],
1173953e3a5SLaszlo Ersek    '*u16' : [ 'uint16' ],
1183953e3a5SLaszlo Ersek    '*i64x':   'int'     ,
1193953e3a5SLaszlo Ersek    '*u64x':   'uint64'  } }
120f6dadb02SWenchao Xia
121f6dadb02SWenchao Xia# testing event
122895a2a80SEric Blake{ 'struct': 'EventStructOne',
123f6dadb02SWenchao Xia  'data': { 'struct1': 'UserDefOne', 'string': 'str', '*enum2': 'EnumOne' } }
124f6dadb02SWenchao Xia
125f6dadb02SWenchao Xia{ 'event': 'EVENT_A' }
126f6dadb02SWenchao Xia{ 'event': 'EVENT_B',
127f6dadb02SWenchao Xia  'data': { } }
128f6dadb02SWenchao Xia{ 'event': 'EVENT_C',
129f6dadb02SWenchao Xia  'data': { '*a': 'int', '*b': 'UserDefOne', 'c': 'str' } }
130f6dadb02SWenchao Xia{ 'event': 'EVENT_D',
131f6dadb02SWenchao Xia  'data': { 'a' : 'EventStructOne', 'b' : 'str', '*c': 'str', '*enum3': 'EnumOne' } }
132fce384b8SEric Blake
133fce384b8SEric Blake# test that we correctly compile downstream extensions
134fce384b8SEric Blake{ 'enum': '__org.qemu_x-Enum', 'data': [ '__org.qemu_x-value' ] }
13583a02706SEric Blake{ 'struct': '__org.qemu_x-Base',
13683a02706SEric Blake  'data': { '__org.qemu_x-member1': '__org.qemu_x-Enum' } }
13783a02706SEric Blake{ 'struct': '__org.qemu_x-Struct', 'base': '__org.qemu_x-Base',
13883a02706SEric Blake  'data': { '__org.qemu_x-member2': 'str' } }
139bb337290SEric Blake{ 'union': '__org.qemu_x-Union1', 'data': { '__org.qemu_x-branch': 'str' } }
140857af5f0SEric Blake{ 'struct': '__org.qemu_x-Struct2',
141857af5f0SEric Blake  'data': { 'array': ['__org.qemu_x-Union1'] } }
142857af5f0SEric Blake{ 'union': '__org.qemu_x-Union2', 'base': '__org.qemu_x-Base',
143857af5f0SEric Blake  'discriminator': '__org.qemu_x-member1',
144857af5f0SEric Blake  'data': { '__org.qemu_x-value': '__org.qemu_x-Struct2' } }
145d1f07c86SEric Blake{ 'alternate': '__org.qemu_x-Alt',
146d1f07c86SEric Blake  'data': { '__org.qemu_x-branch': 'str', 'b': '__org.qemu_x-Base' } }
147e3c4c3d7SEric Blake{ 'event': '__ORG.QEMU_X-EVENT', 'data': '__org.qemu_x-Struct' }
148e3c4c3d7SEric Blake{ 'command': '__org.qemu_x-command',
149e3c4c3d7SEric Blake  'data': { 'a': ['__org.qemu_x-Enum'], 'b': ['__org.qemu_x-Struct'],
150e3c4c3d7SEric Blake            'c': '__org.qemu_x-Union2', 'd': '__org.qemu_x-Alt' },
151e3c4c3d7SEric Blake  'returns': '__org.qemu_x-Union1' }
152