Skip to content

Commit 8374bf4

Browse files
author
Alan Bateman
committedDec 14, 2017
Merge
2 parents b05129a + 185172f commit 8374bf4

File tree

4 files changed

+66
-10
lines changed

4 files changed

+66
-10
lines changed
 

‎src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/AssignSymbols.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -796,7 +796,7 @@ private Node leaveDELETE(final UnaryNode unaryNode) {
796796
args.add(strictFlagNode);
797797

798798
} else {
799-
return LiteralNode.newInstance(unaryNode, true);
799+
throw new AssertionError("Unexpected delete with " + rhs.getClass().getName() + " expression");
800800
}
801801
return new RuntimeNode(unaryNode, request, args);
802802
}

‎src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/Lower.java

+10
Original file line numberDiff line numberDiff line change
@@ -228,6 +228,16 @@ public Node leaveIndexNode(final IndexNode indexNode) {
228228
return super.leaveIndexNode(indexNode);
229229
}
230230

231+
@Override
232+
public Node leaveDELETE(final UnaryNode delete) {
233+
final Expression expression = delete.getExpression();
234+
if (expression instanceof IdentNode || expression instanceof BaseNode) {
235+
return delete;
236+
}
237+
return new BinaryNode(Token.recast(delete.getToken(), TokenType.COMMARIGHT), expression,
238+
LiteralNode.newInstance(delete.getToken(), delete.getFinish(), true));
239+
}
240+
231241
// If expression is a primitive literal that is not an array index and does return its string value. Else return null.
232242
private static String getConstantPropertyName(final Expression expression) {
233243
if (expression instanceof LiteralNode.PrimitiveLiteralNode) {

‎src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java

+1-9
Original file line numberDiff line numberDiff line change
@@ -4404,22 +4404,14 @@ private Expression unaryExpression() {
44044404
final long unaryToken = token;
44054405

44064406
switch (type) {
4407-
case DELETE: {
4408-
next();
4409-
final Expression expr = unaryExpression();
4410-
if (expr instanceof BaseNode || expr instanceof IdentNode) {
4411-
return new UnaryNode(unaryToken, expr);
4412-
}
4413-
appendStatement(new ExpressionStatement(unaryLine, unaryToken, finish, expr));
4414-
return LiteralNode.newInstance(unaryToken, finish, true);
4415-
}
44164407
case ADD:
44174408
case SUB: {
44184409
final TokenType opType = type;
44194410
next();
44204411
final Expression expr = unaryExpression();
44214412
return new UnaryNode(Token.recast(unaryToken, (opType == TokenType.ADD) ? TokenType.POS : TokenType.NEG), expr);
44224413
}
4414+
case DELETE:
44234415
case VOID:
44244416
case TYPEOF:
44254417
case BIT_NOT:
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
/*
2+
* Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation. Oracle designates this
8+
* particular file as subject to the "Classpath" exception as provided
9+
* by Oracle in the LICENSE file that accompanied this code.
10+
*
11+
* This code is distributed in the hope that it will be useful, but WITHOUT
12+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14+
* version 2 for more details (a copy is included in the LICENSE file that
15+
* accompanied this code).
16+
*
17+
* You should have received a copy of the GNU General Public License version
18+
* 2 along with this work; if not, write to the Free Software Foundation,
19+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20+
*
21+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22+
* or visit www.oracle.com if you need additional information or have any
23+
* questions.
24+
*/
25+
package jdk.nashorn.api.tree.test;
26+
27+
import jdk.nashorn.api.tree.CompilationUnitTree;
28+
import jdk.nashorn.api.tree.ExpressionStatementTree;
29+
import jdk.nashorn.api.tree.FunctionCallTree;
30+
import jdk.nashorn.api.tree.Parser;
31+
import jdk.nashorn.api.tree.Tree;
32+
import jdk.nashorn.api.tree.UnaryTree;
33+
import org.testng.Assert;
34+
import org.testng.annotations.Test;
35+
36+
/**
37+
* @test
38+
* @bug 8184723
39+
* @summary Parser should not eagerly transform delete expressions
40+
* @run testng jdk.nashorn.api.tree.test.JDK_8193296_Test
41+
*/
42+
public class JDK_8193296_Test {
43+
@Test
44+
public void test() {
45+
Parser p = Parser.create();
46+
CompilationUnitTree t = p.parse("test", "function x() { }; delete x();", System.out::println);
47+
Assert.assertEquals(t.getSourceElements().size(), 2);
48+
Tree delt = ((ExpressionStatementTree)t.getSourceElements().get(1)).getExpression();
49+
Assert.assertTrue(delt instanceof UnaryTree, delt.getClass().getName());
50+
UnaryTree del = (UnaryTree)delt;
51+
Assert.assertEquals(del.getKind(), Tree.Kind.DELETE);
52+
Assert.assertTrue(del.getExpression() instanceof FunctionCallTree, del.getExpression().getClass().getName());
53+
}
54+
}

0 commit comments

Comments
 (0)
Please sign in to comment.