From 3307ec062f569bcfbd7655b33d0239f8d44f21fc Mon Sep 17 00:00:00 2001 From: Andrei Litvin Date: Tue, 11 Jun 2024 15:23:29 -0400 Subject: [PATCH 1/2] Update zapxml parsing to support features --- .../py_matter_idl/matter_idl/test_zapxml.py | 34 +++++++++++++++++++ .../matter_idl/zapxml/handlers/handlers.py | 28 +++++++++++++++ 2 files changed, 62 insertions(+) diff --git a/scripts/py_matter_idl/matter_idl/test_zapxml.py b/scripts/py_matter_idl/matter_idl/test_zapxml.py index 38ba9c85d1fd2a..6e6cd3d8761ca9 100755 --- a/scripts/py_matter_idl/matter_idl/test_zapxml.py +++ b/scripts/py_matter_idl/matter_idl/test_zapxml.py @@ -274,6 +274,40 @@ def testEnum(self): Cluster(name='Test2', code=20, enums=[e3])], )) + def testFeatures(self): + idl = XmlToIdl(''' + + + TestFeatures + 20 + + + + + + + + + + + + + + + ''') + bitmap = Bitmap( + name='Feature', + base_type='bitmap32', + entries=[ + ConstantEntry(name='OnOff', code=1), + ConstantEntry(name='TestFeature', code=2), + ConstantEntry(name='AnotherTest', code=4), + ]) + self.assertEqual(idl, + Idl(clusters=[ + Cluster(name='TestFeatures', code=20, bitmaps=[bitmap]) + ])), + def testStruct(self): idl = XmlToIdl(''' diff --git a/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py b/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py index ae943bfc70a082..e59649d756d932 100644 --- a/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py +++ b/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py @@ -336,6 +336,32 @@ def FinalizeProcessing(self, idl: Idl): def EndProcessing(self): self.context.AddIdlPostProcessor(self) +class FeaturesHandler(BaseHandler): + """Handles .../features + + Attaches a "Feature" bitmap to the given structure + """ + + def __init__(self, context: Context, cluster: Cluster): + super().__init__(context) + self._features = Bitmap(name='Feature', base_type="bitmap32", entries=[]) + self._cluster = cluster + + def GetNextProcessor(self, name, attrs): + if name.lower() == 'feature': + self._features.entries.append(ConstantEntry( + name=attrs['name'], + code=1 << ParseInt(attrs['bit']), + )) + + # Sub-elements are conformance which is not representable in IDL + return BaseHandler(self.context, handled=HandledDepth.ENTIRE_TREE) + return BaseHandler(self.context) + + def EndProcessing(self): + if self._features.entries: + self._cluster.bitmaps.append(self._features) + class DescriptionHandler(BaseHandler): """Handles .../description text elements @@ -511,6 +537,8 @@ def GetNextProcessor(self, name: str, attrs): return CommandHandler(self.context, self._cluster, attrs) elif name.lower() == 'description': return DescriptionHandler(self.context, self._cluster) + elif name.lower() == 'features': + return FeaturesHandler(self.context, self._cluster) elif name.lower() in ['define', 'domain', 'tag', 'client', 'server']: # NOTE: we COULD use client and server to create separate definitions # of each, but the usefulness of this is unclear as the definitions are From 0463e3f9388a5840de03d23b8cc5c4b3919c8d24 Mon Sep 17 00:00:00 2001 From: Andrei Litvin Date: Tue, 11 Jun 2024 15:23:44 -0400 Subject: [PATCH 2/2] Restyle --- scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py | 1 + 1 file changed, 1 insertion(+) diff --git a/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py b/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py index e59649d756d932..866ce71f914214 100644 --- a/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py +++ b/scripts/py_matter_idl/matter_idl/zapxml/handlers/handlers.py @@ -336,6 +336,7 @@ def FinalizeProcessing(self, idl: Idl): def EndProcessing(self): self.context.AddIdlPostProcessor(self) + class FeaturesHandler(BaseHandler): """Handles .../features