diff options
Diffstat (limited to 'components/script/dom/bindings/codegen')
-rw-r--r-- | components/script/dom/bindings/codegen/CodegenRust.py | 12 | ||||
-rw-r--r-- | components/script/dom/bindings/codegen/Configuration.py | 4 |
2 files changed, 16 insertions, 0 deletions
diff --git a/components/script/dom/bindings/codegen/CodegenRust.py b/components/script/dom/bindings/codegen/CodegenRust.py index 84d80124df9..90939017ef9 100644 --- a/components/script/dom/bindings/codegen/CodegenRust.py +++ b/components/script/dom/bindings/codegen/CodegenRust.py @@ -5283,6 +5283,7 @@ class CGBindingRoot(CGThing): isCallback=True) enums = config.getEnums(webIDLFile) + typedefs = config.getTypedefs(webIDLFile) if not (descriptors or dictionaries or mainCallbacks or callbackDescriptors or enums): self.root = None @@ -5291,6 +5292,17 @@ class CGBindingRoot(CGThing): # Do codegen for all the enums. cgthings = [CGEnum(e) for e in enums] + # Do codegen for all the typdefs + for t in typedefs: + if t.innerType.isUnion(): + cgthings.extend([CGGeneric("\npub type %s = %s;\n\n" % (t.identifier.name, + "UnionTypes::" + str(t.innerType)))]) + else: + assert not typeNeedsRooting(t.innerType, config.getDescriptorProvider) + cgthings.extend([CGGeneric("\npub type %s = " % (t.identifier.name)), + getRetvalDeclarationForType(t.innerType, config.getDescriptorProvider()), + CGGeneric(";\n\n")]) + # Do codegen for all the dictionaries. cgthings.extend([CGDictionary(d, config.getDescriptorProvider()) for d in dictionaries]) diff --git a/components/script/dom/bindings/codegen/Configuration.py b/components/script/dom/bindings/codegen/Configuration.py index ac78e52c071..762998b91ac 100644 --- a/components/script/dom/bindings/codegen/Configuration.py +++ b/components/script/dom/bindings/codegen/Configuration.py @@ -60,6 +60,7 @@ class Configuration: descriptor.uniqueImplementation = len(otherDescriptors) == 1 self.enums = [e for e in parseData if e.isEnum()] + self.typedefs = [e for e in parseData if e.isTypedef()] self.dictionaries = [d for d in parseData if d.isDictionary()] self.callbacks = [c for c in parseData if c.isCallback() and not c.isInterface()] @@ -90,6 +91,9 @@ class Configuration: def getEnums(self, webIDLFile): return filter(lambda e: e.filename() == webIDLFile, self.enums) + def getTypedefs(self, webIDLFile): + return filter(lambda e: e.filename() == webIDLFile, self.typedefs) + @staticmethod def _filterForFile(items, webIDLFile=""): """Gets the items that match the given filters.""" |