From 5c4b9f1efd1c5d9853a3c508e2a103d0f5679173 Mon Sep 17 00:00:00 2001 From: Andrew Yourtchenko Date: Tue, 19 Mar 2019 14:52:29 +0100 Subject: vppapigen: allow for enum size other than u32 Change-Id: If20d2fbab9b854b7db276c81918fdff6abcb8385 Signed-off-by: Andrew Yourtchenko --- src/vpp-api/python/vpp_papi/vpp_serializer.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'src/vpp-api/python/vpp_papi') diff --git a/src/vpp-api/python/vpp_papi/vpp_serializer.py b/src/vpp-api/python/vpp_papi/vpp_serializer.py index 1e59e366a8f..bd5f050bba9 100644 --- a/src/vpp-api/python/vpp_papi/vpp_serializer.py +++ b/src/vpp-api/python/vpp_papi/vpp_serializer.py @@ -279,11 +279,13 @@ class VLAList_legacy(): class VPPEnumType(object): def __init__(self, name, msgdef): self.size = types['u32'].size + self.enumtype = 'u32' e_hash = {} for f in msgdef: if type(f) is dict and 'enumtype' in f: if f['enumtype'] != 'u32': - raise NotImplementedError + self.size = types[f['enumtype']].size + self.enumtype = f['enumtype'] continue ename, evalue = f e_hash[ename] = evalue @@ -297,10 +299,10 @@ class VPPEnumType(object): return True def pack(self, data, kwargs=None): - return types['u32'].pack(data) + return types[self.enumtype].pack(data) def unpack(self, data, offset=0, result=None, ntc=False): - x, size = types['u32'].unpack(data, offset) + x, size = types[self.enumtype].unpack(data, offset) return self.enum(x), size -- cgit 1.2.3-korg