1# *-*- Mode: Python -*-* 2 3# for testing enums 4{ 'enum': 'EnumOne', 5 'data': [ 'value1', 'value2', 'value3' ] } 6{ 'type': 'NestedEnumsOne', 7 'data': { 'enum1': 'EnumOne', '*enum2': 'EnumOne', 'enum3': 'EnumOne', '*enum4': 'EnumOne' } } 8 9# for testing nested structs 10{ 'type': 'UserDefZero', 11 'data': { 'integer': 'int' } } 12 13{ 'type': 'UserDefOne', 14 'base': 'UserDefZero', 15 'data': { 'string': 'str', '*enum1': 'EnumOne' } } 16 17{ 'type': 'UserDefTwo', 18 'data': { 'string': 'str', 19 'dict': { 'string': 'str', 20 'dict': { 'userdef': 'UserDefOne', 'string': 'str' }, 21 '*dict2': { 'userdef': 'UserDefOne', 'string': 'str' } } } } 22 23{ 'type': 'UserDefNested', 24 'data': { 'string0': 'str', 25 'dict1': { 'string1': 'str', 26 'dict2': { 'userdef1': 'UserDefOne', 'string2': 'str' }, 27 '*dict3': { 'userdef2': 'UserDefOne', 'string3': 'str' } } } } 28 29# for testing unions 30{ 'type': 'UserDefA', 31 'data': { 'boolean': 'bool' } } 32 33{ 'type': 'UserDefB', 34 'data': { 'integer': 'int' } } 35 36{ 'type': 'UserDefC', 37 'data': { 'string1': 'str', 'string2': 'str' } } 38 39{ 'union': 'UserDefUnion', 40 'base': 'UserDefZero', 41 'data': { 'a' : 'UserDefA', 'b' : 'UserDefB' } } 42 43{ 'type': 'UserDefUnionBase', 44 'data': { 'string': 'str', 'enum1': 'EnumOne' } } 45 46{ 'union': 'UserDefFlatUnion', 47 'base': 'UserDefUnionBase', 48 'discriminator': 'enum1', 49 'data': { 'value1' : 'UserDefA', 'value2' : 'UserDefB', 'value3' : 'UserDefB' } } 50# FIXME generated struct UserDefFlatUnion has members for direct base 51# UserDefOne, but lacks members for indirect base UserDefZero 52 53# this variant of UserDefFlatUnion defaults to a union that uses fields with 54# allocated types to test corner cases in the cleanup/dealloc visitor 55{ 'union': 'UserDefFlatUnion2', 56 'base': 'UserDefUnionBase', 57 'discriminator': 'enum1', 58 'data': { 'value1' : 'UserDefC', 'value2' : 'UserDefB', 'value3' : 'UserDefA' } } 59 60{ 'union': 'UserDefAnonUnion', 61 'discriminator': {}, 62 'data': { 'uda': 'UserDefA', 's': 'str', 'i': 'int' } } 63 64# for testing native lists 65{ 'union': 'UserDefNativeListUnion', 66 'data': { 'integer': ['int'], 67 's8': ['int8'], 68 's16': ['int16'], 69 's32': ['int32'], 70 's64': ['int64'], 71 'u8': ['uint8'], 72 'u16': ['uint16'], 73 'u32': ['uint32'], 74 'u64': ['uint64'], 75 'number': ['number'], 76 'boolean': ['bool'], 77 'string': ['str'] } } 78 79# testing commands 80{ 'command': 'user_def_cmd', 'data': {} } 81{ 'command': 'user_def_cmd1', 'data': {'ud1a': 'UserDefOne'} } 82{ 'command': 'user_def_cmd2', 83 'data': {'ud1a': 'UserDefOne', '*ud1b': 'UserDefOne'}, 84 'returns': 'UserDefTwo' } 85{ 'command': 'user_def_cmd3', 'data': {'a': 'int', '*b': 'int' }, 86 'returns': 'int' } 87 88# For testing integer range flattening in opts-visitor. The following schema 89# corresponds to the option format: 90# 91# -userdef i64=3-6,i64=-5--1,u64=2,u16=1,u16=7-12 92# 93# For simplicity, this example doesn't use [type=]discriminator nor optargs 94# specific to discriminator values. 95{ 'type': 'UserDefOptions', 96 'data': { 97 '*i64' : [ 'int' ], 98 '*u64' : [ 'uint64' ], 99 '*u16' : [ 'uint16' ], 100 '*i64x': 'int' , 101 '*u64x': 'uint64' } } 102 103# testing event 104{ 'type': 'EventStructOne', 105 'data': { 'struct1': 'UserDefOne', 'string': 'str', '*enum2': 'EnumOne' } } 106 107{ 'event': 'EVENT_A' } 108{ 'event': 'EVENT_B', 109 'data': { } } 110{ 'event': 'EVENT_C', 111 'data': { '*a': 'int', '*b': 'UserDefOne', 'c': 'str' } } 112{ 'event': 'EVENT_D', 113 'data': { 'a' : 'EventStructOne', 'b' : 'str', '*c': 'str', '*enum3': 'EnumOne' } } 114