[Mesa-dev] [PATCH 5/6] vulkan: enum generator: Stop using iterparse
Jason Ekstrand
jason at jlekstrand.net
Thu Sep 21 15:32:22 UTC 2017
While using iterparse is potentially a little more efficient, the Vulkan
registry XML is not large and using regular element tree simplifies the
parsing logic substantially.
---
src/vulkan/util/gen_enum_to_str.py | 41 +++++++++++++++-----------------------
1 file changed, 16 insertions(+), 25 deletions(-)
diff --git a/src/vulkan/util/gen_enum_to_str.py b/src/vulkan/util/gen_enum_to_str.py
index 8f32102..e5f8964 100644
--- a/src/vulkan/util/gen_enum_to_str.py
+++ b/src/vulkan/util/gen_enum_to_str.py
@@ -157,31 +157,22 @@ def parse_xml(enum_factory, ext_factory, filename):
of VkEnum objects.
"""
- with open(filename, 'rb') as f:
- context = iter(et.iterparse(f, events=('start', 'end')))
-
- # This gives the root element, since goal is to iterate over the
- # elements without building a tree, this allows the root to be cleared
- # (erase the elements) after the children have been processed.
- _, root = next(context)
-
- for event, elem in context:
- if event == 'end' and elem.tag == 'enums':
- type_ = elem.attrib.get('type')
- if type_ == 'enum':
- enum = enum_factory(elem.attrib['name'])
- enum.values.extend([e.attrib['name'] for e in elem
- if e.tag == 'enum'])
- elif event == 'start' and elem.tag == 'extension':
- ext_factory(elem.attrib['name'], int(elem.attrib['number']))
- elif event == 'end' and elem.tag == 'extension':
- if elem.attrib['supported'] != 'vulkan':
- continue
- for e in elem.findall('.//enum[@extends][@offset]'):
- enum = enum_factory(e.attrib['extends'])
- enum.values.append(e.attrib['name'],)
-
- root.clear()
+ xml = et.parse(filename)
+
+ for enum_type in xml.findall('./enums'):
+ if enum_type.attrib.get('type') != 'enum':
+ continue
+
+ enum = enum_factory(enum_type.attrib['name'])
+ for value in enum_type.findall('./enum'):
+ enum.values.append(value.attrib['name'])
+
+ for ext_elem in xml.findall('./extension'):
+ if ext_elem.attrib['supported'] != 'vulkan':
+ continue
+
+ ext_factory(ext_elem.attrib['name'],
+ int(ext_elem.attrib['number']))
def main():
parser = argparse.ArgumentParser()
--
2.5.0.400.gff86faf
More information about the mesa-dev
mailing list