Skip to content

Commit

Permalink
[CVE-2017-0223] Fix right paren location calculation for lambda with …
Browse files Browse the repository at this point in the history
…assignment expression

We don't calculate correct right paren location when a lambda contains an assignment expression where the assignment rhs is wrapped in parens. Due to the incorrect offset, we overwrite the buffer allocated in ScriptFunction::EnsureSourceString when we try to toString the lambda.
  • Loading branch information
boingoing committed May 10, 2017
1 parent 1ae7e3c commit f74773f
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/Parser/Parse.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8440,7 +8440,7 @@ ParseNodePtr Parser::ParseExpr(int oplMin,
{
// Parse the operand, make a new node, and look for more
IdentToken token;
pnodeT = ParseExpr<buildAST>(opl, NULL, fAllowIn, FALSE, pNameHint, &hintLength, &hintOffset, &token);
pnodeT = ParseExpr<buildAST>(opl, NULL, fAllowIn, FALSE, pNameHint, &hintLength, &hintOffset, &token, false, nullptr, plastRParen);

// Detect nested function escapes of the pattern "o.f = function(){...}" or "o[s] = function(){...}".
// Doing so in the parser allows us to disable stack-nested-functions in common cases where an escape
Expand Down
23 changes: 23 additions & 0 deletions test/es6/lambda1.js
Original file line number Diff line number Diff line change
Expand Up @@ -477,6 +477,29 @@ var tests = [
var l = async() => (async() => ('str'));
assert.areEqual("async() => (async() => ('str'))", '' + l, "Nested async lambda should be correct");
}
},
{
name: "Lambda consisting of assignment expression should have correct source string",
body: function () {
var l = () => a = (123)
assert.areEqual('() => a = (123)', '' + l, "Lambda to string should include the parens wrapping the return expression");

var l = () => a = (('๏บบ'))
assert.areEqual("() => a = (('๏บบ'))", '' + l, "Multi-byte characters should not break the string");

var s = "() => a = ('\u{20ac}')";
var l = eval(s);
assert.areEqual(s, '' + l, "Unicode byte sequences should not break the string");

var l = async() => a = ({});
assert.areEqual('async() => a = ({})', '' + l, "Async lambda should also be correct");

var l = () => a = (() => b = (123))
assert.areEqual('() => a = (() => b = (123))', '' + l, "Nested lambda to string should be correct");

var l = async() => a = (async() => b = ('str'));
assert.areEqual("async() => a = (async() => b = ('str'))", '' + l, "Nested async lambda should be correct");
}
}
];

Expand Down

0 comments on commit f74773f

Please sign in to comment.