diff --git a/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java b/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java index 84135a891de..70751149b0e 100644 --- a/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java +++ b/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java @@ -5109,8 +5109,13 @@ public class Parser extends AbstractParser implements Loggable { final LiteralNode rawStringArray = LiteralNode.newInstance(templateToken, finish, rawStrings); final LiteralNode cookedStringArray = LiteralNode.newInstance(templateToken, finish, cookedStrings); - final RuntimeNode templateObject = new RuntimeNode(templateToken, finish, RuntimeNode.Request.GET_TEMPLATE_OBJECT, rawStringArray, cookedStringArray); - argumentList.set(0, templateObject); + + if (!env._parse_only) { + final RuntimeNode templateObject = new RuntimeNode(templateToken, finish, RuntimeNode.Request.GET_TEMPLATE_OBJECT, rawStringArray, cookedStringArray); + argumentList.set(0, templateObject); + } else { + argumentList.set(0, rawStringArray); + } return optimizeList(argumentList); } diff --git a/test/nashorn/script/basic/JDK-8188098.js b/test/nashorn/script/basic/JDK-8188098.js new file mode 100644 index 00000000000..7dea37f1360 --- /dev/null +++ b/test/nashorn/script/basic/JDK-8188098.js @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/** + * JDK-8188098:NPE in SimpleTreeVisitorES6 visitor when parsing a tagged template literal + * + * @test + * @run + */ + +var Parser = Java.type("jdk.nashorn.api.tree.Parser"); +var MemberSelectTree = Java.type("jdk.nashorn.api.tree.MemberSelectTree"); +var SimpleTreeVisitor = Java.type("jdk.nashorn.api.tree.SimpleTreeVisitorES6"); +var parser = Parser.create("--language=es6"); + +var ast = parser.parse("hello.js", "foo`PI (${Math.PI}) is transcendental`", print); + +var reachedCall = false; +ast.accept(new (Java.extend(SimpleTreeVisitor)) { + visitFunctionCall: function(node, extra) { + reachedCall = true; + Assert.assertTrue(node.functionSelect.name == "foo"); + var args = node.arguments; + Assert.assertTrue(args.size() == 2); + var strs = args.get(0).elements; + Assert.assertTrue(String(strs.get(0).value) == "PI ("); + Assert.assertTrue(String(strs.get(1).value) == ") is transcendental"); + var expr = args.get(1); + Assert.assertTrue(expr instanceof MemberSelectTree); + Assert.assertTrue(expr.expression.name == "Math"); + Assert.assertTrue(expr.identifier == "PI"); + } +}, null); + +Assert.assertTrue(reachedCall); diff --git a/test/nashorn/src/jdk/nashorn/api/tree/test/JDK_8188098_Test.java b/test/nashorn/src/jdk/nashorn/api/tree/test/JDK_8188098_Test.java new file mode 100644 index 00000000000..9530d2a09bc --- /dev/null +++ b/test/nashorn/src/jdk/nashorn/api/tree/test/JDK_8188098_Test.java @@ -0,0 +1,44 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.nashorn.api.tree.test; + +import jdk.nashorn.api.tree.Parser; +import jdk.nashorn.api.tree.SimpleTreeVisitorES6; +import org.testng.annotations.Test; + +/** + * 8188098: NPE in SimpleTreeVisitorES6 visitor when parsing a tagged template literal + * + * @test + * @run testng jdk.nashorn.api.tree.test.JDK_8188098_Test + */ +public class JDK_8188098_Test { + @Test + public void test() { + Parser p = Parser.create("--language=es6"); + p.parse("test", "foo`hello world`", System.out::println). + accept(new SimpleTreeVisitorES6(), null); + } +}