aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/bindings/codegen
diff options
context:
space:
mode:
authorIgor Matuszewski <Xanewok@gmail.com>2018-03-13 13:05:04 +0100
committerIgor Matuszewski <Xanewok@gmail.com>2018-03-14 18:43:27 +0100
commit6beb32e28e8652027a28bc8400dbe2d6e78cb286 (patch)
treebb9292dc7b7779b8ca4c28a02562b7f1420b772d /components/script/dom/bindings/codegen
parente025bbb07964eb64317d9a6d63d4a55ba79cd8ae (diff)
downloadservo-6beb32e28e8652027a28bc8400dbe2d6e78cb286.tar.gz
servo-6beb32e28e8652027a28bc8400dbe2d6e78cb286.zip
Support nullable typed arrays in codegen
Diffstat (limited to 'components/script/dom/bindings/codegen')
-rw-r--r--components/script/dom/bindings/codegen/CodegenRust.py5
1 files changed, 3 insertions, 2 deletions
diff --git a/components/script/dom/bindings/codegen/CodegenRust.py b/components/script/dom/bindings/codegen/CodegenRust.py
index 3e39bc231d4..6ab7dd8b1d3 100644
--- a/components/script/dom/bindings/codegen/CodegenRust.py
+++ b/components/script/dom/bindings/codegen/CodegenRust.py
@@ -882,7 +882,8 @@ def getJSToNativeConversionInfo(type, descriptorProvider, failureCode=None,
else:
unwrapFailureCode = failureCode
- typeName = type.name
+ typeName = type.unroll().name # unroll because it may be nullable
+
if isMember == "Union":
typeName = "Heap" + typeName
@@ -902,7 +903,7 @@ def getJSToNativeConversionInfo(type, descriptorProvider, failureCode=None,
if isMember == "Union":
templateBody = "RootedTraceableBox::new(%s)" % templateBody
- declType = CGGeneric("typedarray::%s" % type.name)
+ declType = CGGeneric("typedarray::%s" % typeName)
if type.nullable():
templateBody = "Some(%s)" % templateBody
declType = CGWrapper(declType, pre="Option<", post=">")