Skip to content

Commit

Permalink
Bug 1207006 - Remove the unhelpfully-confusing exceptionCodeIndented.…
Browse files Browse the repository at this point in the history
… r=bz

--HG--
extra : rebase_source : d15686fd71897dc90bcaee1d8c9aba75201abb9d
  • Loading branch information
jswalden committed Sep 22, 2015
1 parent 14f22a4 commit 8106775
Showing 1 changed file with 54 additions and 33 deletions.
87 changes: 54 additions & 33 deletions dom/bindings/Codegen.py
Original file line number Diff line number Diff line change
Expand Up @@ -4226,9 +4226,6 @@ def getJSToNativeConversionInfo(type, descriptorProvider, failureCode=None,
# they really should be!
if exceptionCode is None:
exceptionCode = "return false;\n"
# We often want exceptionCode to be indented, since it often appears in an
# if body.
exceptionCodeIndented = CGIndenter(CGGeneric(exceptionCode))

# Unfortunately, .capitalize() on a string will lowercase things inside the
# string, which we do not want.
Expand Down Expand Up @@ -5177,12 +5174,18 @@ def getConversionCode(varName):
if type.isUSVString():
normalizeCode = "NormalizeUSVString(cx, %s);\n" % varName

conversionCode = (
"if (!ConvertJSValueToString(cx, ${val}, %s, %s, %s)) {\n"
"%s"
"}\n"
"%s" % (nullBehavior, undefinedBehavior, varName,
exceptionCodeIndented.define(), normalizeCode))
conversionCode = fill("""
if (!ConvertJSValueToString(cx, $${val}, ${nullBehavior}, ${undefinedBehavior}, ${varName})) {
$*{exceptionCode}
}
$*{normalizeCode}
"""
,
nullBehavior=nullBehavior,
undefinedBehavior=undefinedBehavior,
varName=varName,
exceptionCode=exceptionCode,
normalizeCode=normalizeCode)

if defaultValue is None:
return conversionCode
Expand Down Expand Up @@ -5225,10 +5228,14 @@ def getConversionCode(varName):

nullable = toStringBool(type.nullable())

conversionCode = (
"if (!ConvertJSValueToByteString(cx, ${val}, %s, ${declName})) {\n"
"%s"
"}\n" % (nullable, exceptionCodeIndented.define()))
conversionCode = fill("""
if (!ConvertJSValueToByteString(cx, $${val}, ${nullable}, $${declName})) {
$*{exceptionCode}
}
""",
nullable=nullable,
exceptionCode=exceptionCode)

# ByteString arguments cannot have a default value.
assert defaultValue is None

Expand Down Expand Up @@ -5448,10 +5455,15 @@ def getConversionCode(varName):
if type.nullable():
dictLoc += ".SetValue()"

template += ('if (!%s.Init(cx, %s, "%s", ${passedToJSImpl})) {\n'
"%s"
"}\n" % (dictLoc, val, firstCap(sourceDescription),
exceptionCodeIndented.define()))
template += fill("""
if (!${dictLoc}.Init(cx, ${val}, "${desc}", $${passedToJSImpl})) {
$*{exceptionCode}
}
""",
dictLoc=dictLoc,
val=val,
desc=firstCap(sourceDescription),
exceptionCode=exceptionCode)

if type.nullable():
declType = CGTemplatedType("Nullable", declType)
Expand Down Expand Up @@ -5533,23 +5545,32 @@ def getConversionCode(varName):
nullCondition = "${val}.isNullOrUndefined()"
if defaultValue is not None and isinstance(defaultValue, IDLNullValue):
nullCondition = "!(${haveValue}) || " + nullCondition
template = (
"if (%s) {\n"
" ${declName}.SetNull();\n"
"} else if (!ValueToPrimitive<%s, %s>(cx, ${val}, &%s)) {\n"
"%s"
"}\n" % (nullCondition, typeName, conversionBehavior,
writeLoc, exceptionCodeIndented.define()))
template = fill("""
if (${nullCondition}) {
$${declName}.SetNull();
} else if (!ValueToPrimitive<${typeName}, ${conversionBehavior}>(cx, $${val}, &${writeLoc})) {
$*{exceptionCode}
}
""",
nullCondition=nullCondition,
typeName=typeName,
conversionBehavior=conversionBehavior,
writeLoc=writeLoc,
exceptionCode=exceptionCode)
else:
assert(defaultValue is None or
not isinstance(defaultValue, IDLNullValue))
writeLoc = "${declName}"
readLoc = writeLoc
template = (
"if (!ValueToPrimitive<%s, %s>(cx, ${val}, &%s)) {\n"
"%s"
"}\n" % (typeName, conversionBehavior, writeLoc,
exceptionCodeIndented.define()))
template = fill("""
if (!ValueToPrimitive<${typeName}, ${conversionBehavior}>(cx, $${val}, &${writeLoc})) {
$*{exceptionCode}
}
""",
typeName=typeName,
conversionBehavior=conversionBehavior,
writeLoc=writeLoc,
exceptionCode=exceptionCode)
declType = CGGeneric(typeName)

if type.isFloat() and not type.isUnrestricted():
Expand All @@ -5558,12 +5579,12 @@ def getConversionCode(varName):
else:
nonFiniteCode = ('ThrowErrorMessage(cx, MSG_NOT_FINITE, "%s");\n'
"%s" % (firstCap(sourceDescription), exceptionCode))

# We're appending to an if-block brace, so strip trailing whitespace
# and add an extra space before the else.
template = template.rstrip()
template += fill(
"""
template += fill("""
else if (!mozilla::IsFinite(${readLoc})) {
// Note: mozilla::IsFinite will do the right thing
// when passed a non-finite float too.
$*{nonFiniteCode}
}
""",
Expand Down

0 comments on commit 8106775

Please sign in to comment.