X-Git-Url: https://gerrit.fd.io/r/gitweb?p=vpp.git;a=blobdiff_plain;f=src%2Ftools%2Fvppapigen%2FJSON.py;h=2991bec57ac3fa2eb4f9d8614d3baea41284b004;hp=73bff76cbb7501e33cca6c3a8ead9b786347d6f7;hb=2c2feab;hpb=886bb1ae9b7cfef181e279f3f3b48586ea8d9ad0 diff --git a/src/tools/vppapigen/JSON.py b/src/tools/vppapigen/JSON.py index 73bff76cbb7..2991bec57ac 100644 --- a/src/tools/vppapigen/JSON.py +++ b/src/tools/vppapigen/JSON.py @@ -40,6 +40,8 @@ def walk_defs(s): f = [b.fieldtype, b.fieldname, b.length, b.lengthfield] else: f = [b.fieldtype, b.fieldname, b.length] + elif b.type == 'Union': + print('UNION') else: raise ValueError("Error in processing array type %s" % b) d.append(f) @@ -58,9 +60,10 @@ def walk_defs(s): def run(filename, s, file_crc): j = {} - j['types'] = walk_defs(s['typedefs']) - j['messages'] = walk_defs(s['defines']) - j['enums'] = walk_enums(s['enums']) - j['services'] = walk_services(s['services']) + j['types'] = walk_defs([o for o in s['types'] if o.__class__.__name__ == 'Typedef']) + j['messages'] = walk_defs(s['Define']) + j['unions'] = walk_defs([o for o in s['types'] if o.__class__.__name__ == 'Union']) + j['enums'] = walk_enums([o for o in s['types'] if o.__class__.__name__ == 'Enum']) + j['services'] = walk_services(s['Service']) j['vl_api_version'] = hex(file_crc) return json.dumps(j, indent=4, separators=(',', ': '))