diff options
author | marha <marha@users.sourceforge.net> | 2012-01-26 10:35:11 +0100 |
---|---|---|
committer | marha <marha@users.sourceforge.net> | 2012-01-26 10:35:11 +0100 |
commit | eb4c088eb71f93b9639f4ff651523d794f1433f7 (patch) | |
tree | 5e95635c1768d7d8e640b298f6c6fbe38cd3c395 /libxcb/xcb-proto/src/size.py | |
parent | e6432710d8a586386b3c7025e845cf4f80830da3 (diff) | |
download | vcxsrv-eb4c088eb71f93b9639f4ff651523d794f1433f7.tar.gz vcxsrv-eb4c088eb71f93b9639f4ff651523d794f1433f7.tar.bz2 vcxsrv-eb4c088eb71f93b9639f4ff651523d794f1433f7.zip |
xwininfo xcb-proto mesa xserver git update 26 12 2012
Diffstat (limited to 'libxcb/xcb-proto/src/size.py')
-rw-r--r-- | libxcb/xcb-proto/src/size.py | 76 |
1 files changed, 0 insertions, 76 deletions
diff --git a/libxcb/xcb-proto/src/size.py b/libxcb/xcb-proto/src/size.py deleted file mode 100644 index 5ead8b238..000000000 --- a/libxcb/xcb-proto/src/size.py +++ /dev/null @@ -1,76 +0,0 @@ -#!/usr/bin/python - -from xml.sax.saxutils import XMLFilterBase, XMLGenerator -from xml.sax.xmlreader import AttributesImpl -from xml.sax import make_parser -import sys - -def AttributesUnion(base, **values): - baseitems = dict(base) - baseitems.update(values) - return AttributesImpl(baseitems) - -class AnnotateSize(XMLFilterBase): - types = { - '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 = [] - 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 - - struct = None - union = None - def startElement(self, name, attrs): - if name == 'xcb': - self.header.insert(0, attrs['header']) - elif name == 'field': - size = self.types.get(attrs['type'], 0) - if self.struct is not None: - self.totalsize += size - 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': - self.setTypeSize(attrs['newname'], self.types[attrs['oldname']]) - elif name == 'struct' or name == 'union': - assert self.struct is None and self.union is None - setattr(self, name, attrs['name']) - self.totalsize = 0 - - 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 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 - -annotator = AnnotateSize(make_parser()) -annotator.setContentHandler(XMLGenerator()) -if len(sys.argv) > 1: - annotator.parse(sys.argv[1]) -else: - annotator.parse(sys.stdin) |