aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/bindings/codegen
diff options
context:
space:
mode:
Diffstat (limited to 'components/script/dom/bindings/codegen')
-rw-r--r--components/script/dom/bindings/codegen/CodegenRust.py12
-rw-r--r--components/script/dom/bindings/codegen/Configuration.py4
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."""