made changes to support new value-mask-pad field of valueparam structures
[free-sw/xcb/proto] / src / size.py
index 2e1c403..5ead8b2 100755 (executable)
@@ -12,27 +12,23 @@ def AttributesUnion(base, **values):
 
 class AnnotateSize(XMLFilterBase):
        types = {
-               'BYTE': 1,
-               'BOOL': 1,
-               'CARD8': 1,
-               'CARD16': 2,
-               'CARD32': 4,
-               'INT8': 1,
-               'INT16': 2,
-               'INT32': 4,
-               'float': 4,
-               'double': 8,
+               'BYTE': 1, 'BOOL': 1,
+               'CARD8': 1, 'CARD16': 2, 'CARD32': 4,
+               'INT8': 1, 'INT16': 2, 'INT32': 4,
+               'char': 1, 'void': 1,
+               'float': 4, 'double': 8,
+               'XID': 4,
        }
-       header = None
+       header = []
        def setTypeSize(self, name, size):
+               assert not self.types.has_key(name), "size of " + name + " declared as both " + str(size) + " and " + str(self.types[name])
                self.types[name] = size
-               self.types[self.header + ':' + name] = size
 
        struct = None
        union = None
        def startElement(self, name, attrs):
                if name == 'xcb':
-                       self.header = attrs['header']
+                       self.header.insert(0, attrs['header'])
                elif name == 'field':
                        size = self.types.get(attrs['type'], 0)
                        if self.struct is not None:
@@ -40,6 +36,10 @@ class AnnotateSize(XMLFilterBase):
                        elif self.union is not None:
                                self.totalsize = max(self.totalsize, size)
                        attrs = AttributesUnion(attrs, bytes=str(size))
+               elif name == 'pad':
+                       assert self.union is None
+                       if self.struct is not None:
+                               self.totalsize += int(attrs['bytes'])
                elif name == 'xidtype':
                        self.setTypeSize(attrs['name'], 4)
                elif name == 'typedef':
@@ -48,17 +48,29 @@ class AnnotateSize(XMLFilterBase):
                        assert self.struct is None and self.union is None
                        setattr(self, name, attrs['name'])
                        self.totalsize = 0
-               XMLFilterBase.startElement(self, name, attrs)
+
+               if len(self.header) == 1 or name == 'xcb':
+                       XMLFilterBase.startElement(self, name, attrs)
+
+       def characters(self, content):
+               if len(self.header) == 1:
+                       XMLFilterBase.characters(self, content)
 
        def endElement(self, name):
-               if name == 'struct' or name == 'union':
+               if len(self.header) == 1 or name == 'xcb':
+                       XMLFilterBase.endElement(self, name)
+
+               if name == 'xcb':
+                       self.header.pop(0)
+               elif name == 'struct' or name == 'union':
                        assert getattr(self, name) is not None
                        self.setTypeSize(getattr(self, name), self.totalsize)
                        setattr(self, name, None)
                        del self.totalsize
-               XMLFilterBase.endElement(self, name)
 
 annotator = AnnotateSize(make_parser())
 annotator.setContentHandler(XMLGenerator())
-for f in sys.argv[1:]:
-       annotator.parse(f)
+if len(sys.argv) > 1:
+       annotator.parse(sys.argv[1])
+else:
+       annotator.parse(sys.stdin)