aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/bindings/codegen/parser
diff options
context:
space:
mode:
authorAnthony Ramine <n.oxyde@gmail.com>2015-08-15 14:00:53 +0200
committerAnthony Ramine <n.oxyde@gmail.com>2015-08-15 14:45:26 +0200
commitec2a6b24b1e1317df5669d4b2f01a7c55bb31c75 (patch)
tree2040be614110523ee608609eaf203ed03d3a24d7 /components/script/dom/bindings/codegen/parser
parenta1b3f477aa541fda4d1b6ccb02c3e56143f4d217 (diff)
downloadservo-ec2a6b24b1e1317df5669d4b2f01a7c55bb31c75.tar.gz
servo-ec2a6b24b1e1317df5669d4b2f01a7c55bb31c75.zip
Support default values for restricted float members (fixes #7217)
Diffstat (limited to 'components/script/dom/bindings/codegen/parser')
-rw-r--r--components/script/dom/bindings/codegen/parser/WebIDL.py5
1 files changed, 2 insertions, 3 deletions
diff --git a/components/script/dom/bindings/codegen/parser/WebIDL.py b/components/script/dom/bindings/codegen/parser/WebIDL.py
index a40c563ae35..5741ab8fce5 100644
--- a/components/script/dom/bindings/codegen/parser/WebIDL.py
+++ b/components/script/dom/bindings/codegen/parser/WebIDL.py
@@ -2920,8 +2920,7 @@ class IDLValue(IDLObject):
elif self.type.isInteger() and type.isFloat():
# Convert an integer literal into float
if -2**24 <= self.value <= 2**24:
- floatType = BuiltinTypes[IDLBuiltinType.Types.float]
- return IDLValue(self.location, floatType, float(self.value))
+ return IDLValue(self.location, type, float(self.value))
else:
raise WebIDLError("Converting value %s to %s will lose precision." %
(self.value, type), [location])
@@ -2939,7 +2938,7 @@ class IDLValue(IDLObject):
math.isnan(self.value))):
raise WebIDLError("Trying to convert unrestricted value %s to non-unrestricted"
% self.value, [location]);
- return self
+ return IDLValue(self.location, type, self.value)
elif self.type.isString() and type.isUSVString():
# Allow USVStrings to use default value just like
# DOMString. No coercion is required in this case as Codegen.py