LibJS: New expressions look for expressions with correct precedence

This commit is contained in:
Matthew Olsson 2020-05-28 15:10:22 -07:00 committed by Andreas Kling
parent 688ca7b196
commit 5cd01ed79e
Notes: sideshowbarker 2024-07-19 05:59:42 +09:00
2 changed files with 52 additions and 2 deletions

View file

@ -893,8 +893,7 @@ NonnullRefPtr<NewExpression> Parser::parse_new_expression()
{
consume(TokenType::New);
// FIXME: Support full expressions as the callee as well.
auto callee = create_ast_node<Identifier>(consume(TokenType::Identifier).value());
auto callee = parse_expression(g_operator_precedence.get(TokenType::New).value(), Associativity::Right, { TokenType::ParenOpen });
Vector<CallExpression::Argument> arguments;

View file

@ -0,0 +1,51 @@
load("test-common.js");
try {
function Foo() { this.x = 1; }
let foo = new Foo();
assert(foo.x === 1);
foo = new Foo
assert(foo.x === 1);
foo = new
Foo
()
assert(foo.x === 1);
foo = new Foo + 2
assert(foo === "[object Object]2");
let a = {
b: function() {
this.x = 2;
},
};
foo = new a.b();
assert(foo.x === 2);
foo = new a.b;
assert(foo.x === 2);
foo = new
a.b();
assert(foo.x === 2);
function funcGetter() {
return function(a, b) {
this.x = a + b;
};
};
foo = new funcGetter()(1, 5);
assert(foo === undefined);
foo = new (funcGetter())(1, 5);
assert(foo.x === 6);
console.log("PASS");
} catch (e) {
console.log("FAIL: " + e);
}