diff --git a/nashorn/make/project.properties b/nashorn/make/project.properties index 43f4394495e..b6c61b32480 100644 --- a/nashorn/make/project.properties +++ b/nashorn/make/project.properties @@ -35,7 +35,9 @@ build.compiler=modern javac.source=1.9 javac.target=1.9 -javadoc.option=-tag "implSpec:a:Implementation Requirements:" +javadoc.option=\ + -tag "implSpec:a:Implementation Requirements:"\ + -tag "implNote:a:Implementation Note:" # nashorn version information nashorn.version=0.1 diff --git a/nashorn/samples/prettyprinter.js b/nashorn/samples/prettyprinter.js index c9cec3cdab4..a4c708c8eff 100644 --- a/nashorn/samples/prettyprinter.js +++ b/nashorn/samples/prettyprinter.js @@ -209,7 +209,7 @@ function prettyPrint(file) { } print("function "); if (func.name) { - print(func.name); + print(func.name.name); } printFunctionBody(func, extra, end); if (funcDecl) { @@ -608,7 +608,7 @@ function prettyPrint(file) { visitVariable: function(node, extra) { indent(); - print("var " + node.name); + print("var " + node.binding.name); var init = node.initializer; if (init) { print(" = "); diff --git a/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/NashornCompleter.java b/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/NashornCompleter.java index 65c5e28b2a5..6f7ff336eb2 100644 --- a/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/NashornCompleter.java +++ b/nashorn/src/jdk.scripting.nashorn.shell/share/classes/jdk/nashorn/tools/jjs/NashornCompleter.java @@ -439,6 +439,10 @@ final class NashornCompleter implements Completer { args.add("-strict"); } + if (env._es6) { + args.add("--language=es6"); + } + return Parser.create(args.toArray(new String[0])); } } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTree.java index 87e30ae9428..25b4b710afd 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTree.java @@ -38,11 +38,11 @@ package jdk.nashorn.api.tree; */ public interface CatchTree extends Tree { /** - * Returns the catch parameter identifier of the exception caught. + * Returns the catch parameter identifier or parameter binding pattern of the exception caught. * - * @return the catch parameter identifier + * @return the catch parameter identifier or parameter binding pattern */ - IdentifierTree getParameter(); + ExpressionTree getParameter(); /** * Returns the code block of this catch block. diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTreeImpl.java index 1b692222f53..f392d59ad25 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CatchTreeImpl.java @@ -28,12 +28,12 @@ package jdk.nashorn.api.tree; import jdk.nashorn.internal.ir.CatchNode; final class CatchTreeImpl extends TreeImpl implements CatchTree { - private final IdentifierTree param; + private final ExpressionTree param; private final BlockTree block; private final ExpressionTree condition; CatchTreeImpl(final CatchNode node, - final IdentifierTree param, + final ExpressionTree param, final BlockTree block, final ExpressionTree condition) { super(node); @@ -48,7 +48,7 @@ final class CatchTreeImpl extends TreeImpl implements CatchTree { } @Override - public IdentifierTree getParameter() { + public ExpressionTree getParameter() { return param; } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassDeclarationTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassDeclarationTree.java new file mode 100644 index 00000000000..0eb98cfe9f7 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassDeclarationTree.java @@ -0,0 +1,63 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; + +/** + * A tree node that represents a class declaration. + * + * @since 9 + */ +public interface ClassDeclarationTree extends StatementTree { + + /** + * Class identifier. + * + * @return the class identifier + */ + IdentifierTree getName(); + + /** + * The expression of the {@code extends} clause. Optional. + * + * @return the class heritage + */ + ExpressionTree getClassHeritage(); + + /** + * Get the constructor method definition. + * + * @return the constructor + */ + PropertyTree getConstructor(); + + /** + * Get other property definitions except for the constructor. + * + * @return the class elements + */ + List getClassElements(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassDeclarationTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassDeclarationTreeImpl.java new file mode 100644 index 00000000000..824f677483b --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassDeclarationTreeImpl.java @@ -0,0 +1,77 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; +import jdk.nashorn.internal.ir.VarNode; + +final class ClassDeclarationTreeImpl extends StatementTreeImpl implements ClassDeclarationTree { + + private final IdentifierTree name; + private final ExpressionTree classHeritage; + private final PropertyTree constructor; + private final List classElements; + + ClassDeclarationTreeImpl(final VarNode node, final IdentifierTree name, + final ExpressionTree classHeritage, final PropertyTree constructor, + final List classElements) { + super(node); + this.name = name; + this.classHeritage = classHeritage; + this.constructor = constructor; + this.classElements = classElements; + } + + @Override + public Tree.Kind getKind() { + return Tree.Kind.CLASS; + } + + @Override + public IdentifierTree getName() { + return name; + } + + @Override + public ExpressionTree getClassHeritage() { + return classHeritage; + } + + @Override + public PropertyTree getConstructor() { + return constructor; + } + + @Override + public List getClassElements() { + return classElements; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitClassDeclaration(this, data); + } +} \ No newline at end of file diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassExpressionTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassExpressionTree.java new file mode 100644 index 00000000000..938c6849b58 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassExpressionTree.java @@ -0,0 +1,63 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; + +/** + * A tree node that represents a class expression. + * + * @since 9 + */ +public interface ClassExpressionTree extends ExpressionTree { + /** + * Class identifier. Optional. + * + * @return the class identifier + */ + IdentifierTree getName(); + + /** + * The expression of the {@code extends} clause. Optional. + * + * @return the class heritage + */ + ExpressionTree getClassHeritage(); + + /** + * Get the constructor method definition. + * + * @return the constructor + */ + PropertyTree getConstructor(); + + /** + * Get other property definitions except for the constructor. + * + * @return the class elements + */ + List getClassElements(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassExpressionTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassExpressionTreeImpl.java new file mode 100644 index 00000000000..c4108c969c5 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ClassExpressionTreeImpl.java @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; +import jdk.nashorn.internal.ir.ClassNode; + +final class ClassExpressionTreeImpl extends ExpressionTreeImpl implements ClassExpressionTree { + + private final IdentifierTree name; + private final ExpressionTree classHeritage; + private final PropertyTree constructor; + private final List classElements; + + ClassExpressionTreeImpl(final ClassNode cn, final IdentifierTree name, + final ExpressionTree classHeritage, final PropertyTree constructor, + final List classElements) { + super(cn); + this.name = name; + this.classHeritage = classHeritage; + this.constructor = constructor; + this.classElements = classElements; + } + + @Override + public Kind getKind() { + return Kind.CLASS_EXPRESSION; + } + + @Override + public IdentifierTree getName() { + return name; + } + + @Override + public ExpressionTree getClassHeritage() { + return classHeritage; + } + + @Override + public PropertyTree getConstructor() { + return constructor; + } + + @Override + public List getClassElements() { + return classElements; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitClassExpression(this, data); + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTree.java index 472e451f05f..a7afb51f859 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTree.java @@ -62,4 +62,12 @@ public interface CompilationUnitTree extends Tree { * @return the line map for this compilation unit */ LineMap getLineMap(); + + /** + * Return the {@link ModuleTree} associated with this compilation unit. This is null, + * if there is no module information from this compilation unit. + * + * @return the Module info or null + */ + ModuleTree getModule(); } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTreeImpl.java index 6e2230a05d5..552a4c5816e 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/CompilationUnitTreeImpl.java @@ -32,13 +32,18 @@ final class CompilationUnitTreeImpl extends TreeImpl implements CompilationUnitTree { private final FunctionNode funcNode; private final List elements; + private final ModuleTree module; CompilationUnitTreeImpl(final FunctionNode node, - final List elements) { + final List elements, + final ModuleTree module) { super(node); this.funcNode = node; - assert funcNode.getKind() == FunctionNode.Kind.SCRIPT : "script function expected"; + assert funcNode.getKind() == FunctionNode.Kind.SCRIPT || + funcNode.getKind() == FunctionNode.Kind.MODULE : + "script or module function expected"; this.elements = elements; + this.module = module; } @Override @@ -66,6 +71,11 @@ final class CompilationUnitTreeImpl extends TreeImpl return new LineMapImpl(funcNode.getSource()); } + @Override + public ModuleTree getModule() { + return module; + } + @Override public R accept(final TreeVisitor visitor, final D data) { return visitor.visitCompilationUnit(this, data); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/DestructuringDeclTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/DestructuringDeclTreeImpl.java new file mode 100644 index 00000000000..584874bbb3c --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/DestructuringDeclTreeImpl.java @@ -0,0 +1,77 @@ +/* + * Copyright (c) 2016, 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; + +import jdk.nashorn.internal.ir.ExpressionStatement; +import jdk.nashorn.internal.parser.TokenType; + +// This implementation of VariableTree represents a destructuring declaration +final class DestructuringDeclTreeImpl extends StatementTreeImpl + implements VariableTree { + + private final TokenType declType; + private final ExpressionTree lhs; + private final ExpressionTree init; + + DestructuringDeclTreeImpl(ExpressionStatement exprStat, final ExpressionTree lhs, final ExpressionTree init) { + super(exprStat); + assert exprStat.destructuringDeclarationType() != null : "expecting a destructuring decl. statement"; + + this.declType = exprStat.destructuringDeclarationType(); + this.lhs = lhs; + this.init = init; + } + + @Override + public Kind getKind() { + return Kind.VARIABLE; + } + + @Override + public ExpressionTree getBinding() { + return lhs; + } + + @Override + public ExpressionTree getInitializer() { + return init; + } + + @Override + public boolean isConst() { + return declType == TokenType.CONST; + } + + @Override + public boolean isLet() { + return declType == TokenType.LET; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitVariable(this, data); + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ExportEntryTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ExportEntryTree.java new file mode 100644 index 00000000000..2e830abd219 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ExportEntryTree.java @@ -0,0 +1,60 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; + +/** + * A Tree node for export entry in Module information. + */ +public interface ExportEntryTree extends Tree { + /** + * Returns the entry's export name. + * + * @return the export name + */ + public IdentifierTree getExportName(); + + /** + * Returns the entry's module request. + * + * @return the module request + */ + public IdentifierTree getModuleRequest(); + + /** + * Returns the entry's import name. + * + * @return the import name + */ + public IdentifierTree getImportName(); + + /** + * Returns the entry's local name. + * + * @return the local name + */ + public IdentifierTree getLocalName(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ExportEntryTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ExportEntryTreeImpl.java new file mode 100644 index 00000000000..01bc4844859 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ExportEntryTreeImpl.java @@ -0,0 +1,109 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; +import java.util.stream.Collectors; +import jdk.nashorn.internal.ir.FunctionNode; +import jdk.nashorn.internal.ir.IdentNode; +import jdk.nashorn.internal.ir.Module; +import static jdk.nashorn.api.tree.ModuleTreeImpl.identOrNull; + +final class ExportEntryTreeImpl extends TreeImpl implements ExportEntryTree { + private final long startPos, endPos; + private final IdentifierTree exportName; + private final IdentifierTree moduleRequest; + private final IdentifierTree importName; + private final IdentifierTree localName; + + private ExportEntryTreeImpl(final long startPos, final long endPos, + IdentifierTree exportName, + IdentifierTree moduleRequest, + IdentifierTree importName, + IdentifierTree localName) { + super(null); // no underlying Node! + this.startPos = startPos; + this.endPos = endPos; + this.exportName = exportName; + this.moduleRequest = moduleRequest; + this.importName = importName; + this.localName = localName; + } + + private static ExportEntryTreeImpl createExportEntry(Module.ExportEntry entry) { + return new ExportEntryTreeImpl(entry.getStartPosition(), + entry.getEndPosition(), + identOrNull(entry.getExportName()), + identOrNull(entry.getModuleRequest()), + identOrNull(entry.getImportName()), + identOrNull(entry.getLocalName())); + } + + static List createExportList(List exportList) { + return exportList.stream(). + map(ExportEntryTreeImpl::createExportEntry). + collect(Collectors.toList()); + } + + @Override + public Kind getKind() { + return Tree.Kind.EXPORT_ENTRY; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitExportEntry(this, data); + } + + @Override + public long getStartPosition() { + return startPos; + } + + @Override + public long getEndPosition() { + return endPos; + } + + @Override + public IdentifierTree getExportName() { + return exportName; + } + + @Override + public IdentifierTree getModuleRequest() { + return moduleRequest; + } + + @Override + public IdentifierTree getImportName() { + return importName; + } + + @Override + public IdentifierTree getLocalName() { + return localName; + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ForOfLoopTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ForOfLoopTree.java new file mode 100644 index 00000000000..d95e2ed638e --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ForOfLoopTree.java @@ -0,0 +1,62 @@ +/* + * Copyright (c) 2016, 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; + +/** + * A tree node for for..of statement. + * + * For example: + *
+ *   for ( variable of expression )
+ *       statement
+ * 
+ * + * @since 9 + */ +public interface ForOfLoopTree extends LoopTree { + /** + * The for..in left hand side expression. + * + * @return the left hand side expression + */ + ExpressionTree getVariable(); + + /** + * The object or array being whose properties are iterated. + * + * @return the object or array expression being iterated + */ + ExpressionTree getExpression(); + + /** + * The statement contained in this for..in statement. + * + * @return the statement + */ + @Override + StatementTree getStatement(); +} + diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ForOfLoopTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ForOfLoopTreeImpl.java new file mode 100644 index 00000000000..e2306e51c1e --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ForOfLoopTreeImpl.java @@ -0,0 +1,69 @@ +/* + * Copyright (c) 2016, 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; + +import jdk.nashorn.internal.ir.ForNode; + +final class ForOfLoopTreeImpl extends StatementTreeImpl implements ForOfLoopTree { + private final ExpressionTree lhsExpr; + private final ExpressionTree expr; + private final StatementTree stat; + + ForOfLoopTreeImpl(final ForNode node, + final ExpressionTree lhsExpr, + final ExpressionTree expr, + final StatementTree stat) { + super(node); + assert node.isForIn() : "for ..in expected"; + this.lhsExpr = lhsExpr; + this.expr = expr; + this.stat = stat; + } + + @Override + public Kind getKind() { + return Kind.FOR_IN_LOOP; + } + + @Override + public ExpressionTree getVariable() { + return lhsExpr; + } + + @Override + public ExpressionTree getExpression() { + return expr; + } + + @Override + public StatementTree getStatement() { + return stat; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitForOfLoop(this, data); + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTree.java index 1fbd0945c8f..2ff8eb7d802 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTree.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -28,7 +28,7 @@ package jdk.nashorn.api.tree; import java.util.List; /** - * A tree node for a function declaration. + * A tree node for a function declaration. * * For example: *
@@ -37,6 +37,12 @@ import java.util.List;
  *      body
  * 
* + *
+ *   function* name
+ *      ( parameters )
+ *      body
+ * 
+ * * @since 9 */ public interface FunctionDeclarationTree extends StatementTree { @@ -45,7 +51,7 @@ public interface FunctionDeclarationTree extends StatementTree { * * @return name the function declared */ - String getName(); + IdentifierTree getName(); /** * Returns the parameters of this function. @@ -67,4 +73,11 @@ public interface FunctionDeclarationTree extends StatementTree { * @return true if this function is strict */ boolean isStrict(); + + /** + * Is this a generator function? + * + * @return true if this is a generator function + */ + boolean isGenerator(); } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTreeImpl.java index dfd5af938f6..592e4dce9ea 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionDeclarationTreeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -32,7 +32,7 @@ import jdk.nashorn.internal.ir.VarNode; final class FunctionDeclarationTreeImpl extends StatementTreeImpl implements FunctionDeclarationTree { private final FunctionNode funcNode; - private final String funcName; + private final IdentifierTree funcName; private final List params; private final BlockTree body; @@ -43,7 +43,7 @@ final class FunctionDeclarationTreeImpl extends StatementTreeImpl assert node.getInit() instanceof FunctionNode : "function expected"; funcNode = (FunctionNode)node.getInit(); assert funcNode.isDeclared() : "function declaration expected"; - funcName = funcNode.isAnonymous()? null : node.getName().getName(); + funcName = funcNode.isAnonymous()? null : new IdentifierTreeImpl(node.getName()); this.params = params; this.body = body; } @@ -54,7 +54,7 @@ final class FunctionDeclarationTreeImpl extends StatementTreeImpl } @Override - public String getName() { + public IdentifierTree getName() { return funcName; } @@ -73,6 +73,11 @@ final class FunctionDeclarationTreeImpl extends StatementTreeImpl return funcNode.isStrict(); } + @Override + public boolean isGenerator() { + return funcNode.getKind() == FunctionNode.Kind.GENERATOR; + } + @Override public R accept(final TreeVisitor visitor, final D data) { return visitor.visitFunctionDeclaration(this, data); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTree.java index 13a89bdadbd..d3cd3d233c1 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTree.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -28,7 +28,7 @@ package jdk.nashorn.api.tree; import java.util.List; /** - * A tree node for a function expression. + * A tree node for function expressions including arrow functions. * * For example: *
@@ -37,6 +37,10 @@ import java.util.List;
  *      body
  * 
* + *
+ *   var func = (x) => x+1
+ * 
+ * * @since 9 */ public interface FunctionExpressionTree extends ExpressionTree { @@ -45,7 +49,7 @@ public interface FunctionExpressionTree extends ExpressionTree { * * @return name the function declared */ - String getName(); + IdentifierTree getName(); /** * Returns the parameters of this function. @@ -55,11 +59,13 @@ public interface FunctionExpressionTree extends ExpressionTree { List getParameters(); /** - * Returns the body of code of this function. + * Returns the body of this function. This may be a {@link BlockTree} when this + * function has a block body. This is an {@link ExpressionTree} when the function body + * is a concise expression as in an expression arrow, or in an expression closure. * - * @return the body of code + * @return the body of this function */ - BlockTree getBody(); + Tree getBody(); /** * Is this a strict function? @@ -67,4 +73,18 @@ public interface FunctionExpressionTree extends ExpressionTree { * @return true if this function is strict */ boolean isStrict(); + + /** + * Is this a arrow function? + * + * @return true if this is a arrow function + */ + boolean isArrow(); + + /** + * Is this a generator function? + * + * @return true if this is a generator function + */ + boolean isGenerator(); } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTreeImpl.java index b39cfbdfeea..6681f258070 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/FunctionExpressionTreeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -31,9 +31,9 @@ import jdk.nashorn.internal.ir.FunctionNode; final class FunctionExpressionTreeImpl extends ExpressionTreeImpl implements FunctionExpressionTree { private final FunctionNode funcNode; - private final String funcName; + private final IdentifierTree funcName; private final List params; - private final BlockTree body; + private final Tree body; FunctionExpressionTreeImpl(final FunctionNode node, final List params, @@ -46,11 +46,17 @@ final class FunctionExpressionTreeImpl extends ExpressionTreeImpl if (node.isAnonymous() || kind == FunctionNode.Kind.GETTER || kind == FunctionNode.Kind.SETTER) { funcName = null; } else { - funcName = node.getIdent().getName(); + funcName = new IdentifierTreeImpl(node.getIdent()); } this.params = params; - this.body = body; + if (node.getFlag(FunctionNode.HAS_EXPRESSION_BODY)) { + StatementTree first = body.getStatements().get(0); + assert first instanceof ReturnTree : "consise func. expression should have a return statement"; + this.body = ((ReturnTree)first).getExpression(); + } else { + this.body = body; + } } @Override @@ -59,7 +65,7 @@ final class FunctionExpressionTreeImpl extends ExpressionTreeImpl } @Override - public String getName() { + public IdentifierTree getName() { return funcName; } @@ -69,7 +75,7 @@ final class FunctionExpressionTreeImpl extends ExpressionTreeImpl } @Override - public BlockTree getBody() { + public Tree getBody() { return body; } @@ -78,6 +84,16 @@ final class FunctionExpressionTreeImpl extends ExpressionTreeImpl return funcNode.isStrict(); } + @Override + public boolean isArrow() { + return funcNode.getKind() == FunctionNode.Kind.ARROW; + } + + @Override + public boolean isGenerator() { + return funcNode.getKind() == FunctionNode.Kind.GENERATOR; + } + @Override public R accept(final TreeVisitor visitor, final D data) { return visitor.visitFunctionExpression(this, data); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IRTranslator.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IRTranslator.java index 44d6276ca07..0ba7b984788 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IRTranslator.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IRTranslator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -27,6 +27,7 @@ package jdk.nashorn.api.tree; import java.util.ArrayList; import java.util.Comparator; import java.util.List; +import java.util.Map; import jdk.nashorn.internal.ir.AccessNode; import jdk.nashorn.internal.ir.BinaryNode; import jdk.nashorn.internal.ir.Block; @@ -35,6 +36,7 @@ import jdk.nashorn.internal.ir.BreakNode; import jdk.nashorn.internal.ir.CallNode; import jdk.nashorn.internal.ir.CaseNode; import jdk.nashorn.internal.ir.CatchNode; +import jdk.nashorn.internal.ir.ClassNode; import jdk.nashorn.internal.ir.ContinueNode; import jdk.nashorn.internal.ir.DebuggerNode; import jdk.nashorn.internal.ir.EmptyNode; @@ -56,6 +58,7 @@ import jdk.nashorn.internal.ir.RuntimeNode; import jdk.nashorn.internal.ir.SplitNode; import jdk.nashorn.internal.ir.Statement; import jdk.nashorn.internal.ir.SwitchNode; +import jdk.nashorn.internal.ir.TemplateLiteral; import jdk.nashorn.internal.ir.TernaryNode; import jdk.nashorn.internal.ir.ThrowNode; import jdk.nashorn.internal.ir.TryNode; @@ -87,11 +90,14 @@ final class IRTranslator extends SimpleNodeVisitor { return null; } - assert (node.getKind() == FunctionNode.Kind.SCRIPT) : "script function expected"; + assert node.getKind() == FunctionNode.Kind.SCRIPT || + node.getKind() == FunctionNode.Kind.MODULE : + "script or module function expected"; final Block body = node.getBody(); return new CompilationUnitTreeImpl(node, - translateStats(body != null? getOrderedStatements(body.getStatements()) : null)); + translateStats(body != null? getOrderedStatements(body.getStatements()) : null), + translateModule(node)); } @Override @@ -184,8 +190,15 @@ final class IRTranslator extends SimpleNodeVisitor { @Override public boolean enterExpressionStatement(final ExpressionStatement expressionStatement) { - curStat = new ExpressionStatementTreeImpl(expressionStatement, + if (expressionStatement.destructuringDeclarationType() != null) { + ExpressionTree expr = translateExpr(expressionStatement.getExpression()); + assert expr instanceof AssignmentTree : "destructuring decl. statement does not have assignment"; + AssignmentTree assign = (AssignmentTree)expr; + curStat = new DestructuringDeclTreeImpl(expressionStatement, assign.getVariable(), assign.getExpression()); + } else { + curStat = new ExpressionStatementTreeImpl(expressionStatement, translateExpr(expressionStatement.getExpression())); + } return false; } @@ -209,6 +222,11 @@ final class IRTranslator extends SimpleNodeVisitor { translateExpr(forNode.getInit()), translateExpr(forNode.getModify()), translateBlock(forNode.getBody())); + } else if (forNode.isForOf()) { + curStat = new ForOfLoopTreeImpl(forNode, + translateExpr(forNode.getInit()), + translateExpr(forNode.getModify()), + translateBlock(forNode.getBody())); } else { curStat = new ForLoopTreeImpl(forNode, translateExpr(forNode.getInit()), @@ -224,8 +242,7 @@ final class IRTranslator extends SimpleNodeVisitor { public boolean enterFunctionNode(final FunctionNode functionNode) { assert !functionNode.isDeclared() || functionNode.isAnonymous() : "should not reach here for function declaration"; - final List paramTrees - = translateExprs(functionNode.getParameters()); + final List paramTrees = translateParameters(functionNode); final BlockTree blockTree = (BlockTree) translateBlock(functionNode.getBody(), true); curExpr = new FunctionExpressionTreeImpl(functionNode, paramTrees, blockTree); @@ -291,14 +308,7 @@ final class IRTranslator extends SimpleNodeVisitor { @Override public boolean enterObjectNode(final ObjectNode objectNode) { final List propNodes = objectNode.getElements(); - final List propTrees = new ArrayList<>(propNodes.size()); - for (final PropertyNode propNode : propNodes) { - propTrees.add(new PropertyTreeImpl(propNode, - translateExpr(propNode.getKey()), - translateExpr(propNode.getValue()), - (FunctionExpressionTree) translateExpr(propNode.getGetter()), - (FunctionExpressionTree) translateExpr(propNode.getSetter()))); - } + final List propTrees = translateProperties(propNodes); curExpr = new ObjectLiteralTreeImpl(objectNode, propTrees); return false; } @@ -346,6 +356,12 @@ final class IRTranslator extends SimpleNodeVisitor { return false; } + @Override + public boolean enterTemplateLiteral(final TemplateLiteral templateLiteral) { + curExpr = new TemplateLiteralTreeImpl(templateLiteral, translateExprs(templateLiteral.getExpressions())); + return false; + } + @Override public boolean enterTernaryNode(final TernaryNode ternaryNode) { curExpr = new ConditionalExpressionTreeImpl(ternaryNode, @@ -386,6 +402,14 @@ final class IRTranslator extends SimpleNodeVisitor { if (unaryNode.isTokenType(TokenType.NEW)) { curExpr = new NewTreeImpl(unaryNode, translateExpr(unaryNode.getExpression())); + } else if (unaryNode.isTokenType(TokenType.YIELD) || + unaryNode.isTokenType(TokenType.YIELD_STAR)) { + curExpr = new YieldTreeImpl(unaryNode, + translateExpr(unaryNode.getExpression())); + } else if (unaryNode.isTokenType(TokenType.SPREAD_ARGUMENT) || + unaryNode.isTokenType(TokenType.SPREAD_ARRAY)) { + curExpr = new SpreadTreeImpl(unaryNode, + translateExpr(unaryNode.getExpression())); } else { curExpr = new UnaryTreeImpl(unaryNode, translateExpr(unaryNode.getExpression())); @@ -399,12 +423,19 @@ final class IRTranslator extends SimpleNodeVisitor { if (initNode instanceof FunctionNode && ((FunctionNode)initNode).isDeclared()) { final FunctionNode funcNode = (FunctionNode) initNode; - final List paramTrees - = translateExprs(funcNode.getParameters()); + final List paramTrees = translateParameters(funcNode); final BlockTree blockTree = (BlockTree) translateBlock(funcNode.getBody(), true); curStat = new FunctionDeclarationTreeImpl(varNode, paramTrees, blockTree); + } else if (initNode instanceof ClassNode && ((ClassNode)initNode).isStatement()) { + final ClassNode classNode = (ClassNode) initNode; + + curStat = new ClassDeclarationTreeImpl(varNode, + translateIdent(classNode.getIdent()), + translateExpr(classNode.getClassHeritage()), + translateProperty(classNode.getConstructor()), + translateProperties(classNode.getClassElements())); } else { - curStat = new VariableTreeImpl(varNode, translateExpr(initNode)); + curStat = new VariableTreeImpl(varNode, translateIdent(varNode.getName()), translateExpr(initNode)); } return false; @@ -433,6 +464,25 @@ final class IRTranslator extends SimpleNodeVisitor { return false; } + /** + * Callback for entering a ClassNode + * + * @param classNode the node + * @return true if traversal should continue and node children be traversed, false otherwise + */ + @Override + public boolean enterClassNode(final ClassNode classNode) { + assert !classNode.isStatement(): "should not reach here for class declaration"; + + curExpr = new ClassExpressionTreeImpl(classNode, + translateIdent(classNode.getIdent()), + translateExpr(classNode.getClassHeritage()), + translateProperty(classNode.getConstructor()), + translateProperties(classNode.getClassElements())); + + return false; + } + private StatementTree translateBlock(final Block blockNode) { return translateBlock(blockNode, false); } @@ -493,6 +543,24 @@ final class IRTranslator extends SimpleNodeVisitor { return statTrees; } + private List translateParameters(final FunctionNode func) { + Map paramExprs = func.getParameterExpressions(); + if (paramExprs != null) { + List params = func.getParameters(); + final List exprTrees = new ArrayList<>(params.size()); + for (final IdentNode ident : params) { + Expression expr = paramExprs.containsKey(ident)? paramExprs.get(ident) : ident; + curExpr = null; + expr.accept(this); + assert curExpr != null; + exprTrees.add(curExpr); + } + return exprTrees; + } else { + return translateExprs(func.getParameters()); + } + } + private List translateExprs(final List exprs) { if (exprs == null) { return null; @@ -532,4 +600,25 @@ final class IRTranslator extends SimpleNodeVisitor { private static IdentifierTree translateIdent(final IdentNode ident) { return new IdentifierTreeImpl(ident); } + + private List translateProperties(final List propNodes) { + final List propTrees = new ArrayList<>(propNodes.size()); + for (final PropertyNode propNode : propNodes) { + propTrees.add(translateProperty(propNode)); + } + return propTrees; + } + + private PropertyTree translateProperty(final PropertyNode propNode) { + return new PropertyTreeImpl(propNode, + translateExpr(propNode.getKey()), + translateExpr(propNode.getValue()), + (FunctionExpressionTree) translateExpr(propNode.getGetter()), + (FunctionExpressionTree) translateExpr(propNode.getSetter())); + } + + private ModuleTree translateModule(final FunctionNode func) { + return func.getKind() == FunctionNode.Kind.MODULE? + ModuleTreeImpl.create(func) : null; + } } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTree.java index 95498572e86..e82e257cdce 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTree.java @@ -42,4 +42,46 @@ public interface IdentifierTree extends ExpressionTree { * @return the name of this identifier */ String getName(); + + /** + * Is this a rest parameter for a function or rest elements of an array? + * + * @return true if this is a rest parameter + */ + boolean isRestParameter(); + + /** + * Is this super identifier? + * + * @return true if this is super identifier + */ + boolean isSuper(); + + /** + * Is this 'this' identifier? + * + * @return true if this is 'this' identifier + */ + boolean isThis(); + + /** + * Is this "*" used in module export entry? + * + * @return true if this "*" used in module export entry? + */ + boolean isStar(); + + /** + * Is this "default" used in module export entry? + * + * @return true if this 'default' used in module export entry? + */ + boolean isDefault(); + + /** + * Is this "*default*" used in module export entry? + * + * @return true if this '*default*' used in module export entry? + */ + boolean isStarDefaultStar(); } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTreeImpl.java index d455dac22f4..a2af0dda856 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/IdentifierTreeImpl.java @@ -27,6 +27,7 @@ package jdk.nashorn.api.tree; import jdk.nashorn.internal.ir.IdentNode; +import jdk.nashorn.internal.ir.Module; final class IdentifierTreeImpl extends ExpressionTreeImpl implements IdentifierTree { private final String name; @@ -46,6 +47,37 @@ final class IdentifierTreeImpl extends ExpressionTreeImpl implements IdentifierT return name; } + @Override + public boolean isRestParameter() { + return ((IdentNode)node).isRestParameter(); + } + + @Override + public boolean isSuper() { + final IdentNode ident = (IdentNode)node; + return ident.isDirectSuper() || "super".equals(ident.getName()); + } + + @Override + public boolean isThis() { + return "this".equals(((IdentNode)node).getName()); + } + + @Override + public boolean isStar() { + return Module.STAR_NAME.equals(((IdentNode)node).getName()); + } + + @Override + public boolean isDefault() { + return Module.DEFAULT_NAME.equals(((IdentNode)node).getName()); + } + + @Override + public boolean isStarDefaultStar() { + return Module.DEFAULT_EXPORT_BINDING_NAME.equals(((IdentNode)node).getName()); + } + @Override public R accept(final TreeVisitor visitor, final D data) { return visitor.visitIdentifier(this, data); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ImportEntryTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ImportEntryTree.java new file mode 100644 index 00000000000..f28db074080 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ImportEntryTree.java @@ -0,0 +1,53 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; + +/** + * A Tree node for import entry of Module information. + */ +public interface ImportEntryTree extends Tree { + /** + * Returns the entry's module request. + * + * @return the module request + */ + public IdentifierTree getModuleRequest(); + + /** + * Returns the entry's import name. + * + * @return the import name + */ + public IdentifierTree getImportName(); + + /** + * Returns the entry's local name. + * + * @return the local name + */ + public IdentifierTree getLocalName(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ImportEntryTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ImportEntryTreeImpl.java new file mode 100644 index 00000000000..68af2d45921 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ImportEntryTreeImpl.java @@ -0,0 +1,100 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; +import java.util.stream.Collectors; +import jdk.nashorn.internal.ir.FunctionNode; +import jdk.nashorn.internal.ir.IdentNode; +import jdk.nashorn.internal.ir.Module; +import static jdk.nashorn.api.tree.ModuleTreeImpl.identOrNull; + +final class ImportEntryTreeImpl extends TreeImpl implements ImportEntryTree { + private final long startPos, endPos; + private final IdentifierTree moduleRequest; + private final IdentifierTree importName; + private final IdentifierTree localName; + + private ImportEntryTreeImpl(final long startPos, final long endPos, + IdentifierTree moduleRequest, + IdentifierTree importName, + IdentifierTree localName) { + super(null); // No underlying Node! + this.startPos = startPos; + this.endPos = endPos; + this.moduleRequest = moduleRequest; + this.importName = importName; + this.localName = localName; + } + + private static ImportEntryTreeImpl createImportEntry(Module.ImportEntry entry) { + return new ImportEntryTreeImpl(entry.getStartPosition(), + entry.getEndPosition(), + identOrNull(entry.getModuleRequest()), + identOrNull(entry.getImportName()), + identOrNull(entry.getLocalName())); + } + + static List createImportList(List importList) { + return importList.stream(). + map(ImportEntryTreeImpl::createImportEntry). + collect(Collectors.toList()); + } + + @Override + public Kind getKind() { + return Tree.Kind.IMPORT_ENTRY; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitImportEntry(this, data); + } + + @Override + public long getStartPosition() { + return startPos; + } + + @Override + public long getEndPosition() { + return endPos; + } + + @Override + public IdentifierTree getModuleRequest() { + return moduleRequest; + } + + @Override + public IdentifierTree getImportName() { + return importName; + } + + @Override + public IdentifierTree getLocalName() { + return localName; + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ModuleTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ModuleTree.java new file mode 100644 index 00000000000..cb7d3538c80 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ModuleTree.java @@ -0,0 +1,60 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; + +/** + * A Tree node for Module information. + */ +public interface ModuleTree extends Tree { + /** + * Returns the list of import entries. + * + * @return the import entries + */ + public List getImportEntries(); + + /** + * Returns the list of local export entries. + * + * @return the local export entries + */ + public List getLocalExportEntries(); + + /** + * Returns the list of indirect export entries. + * + * @return the indirect export entries + */ + public List getIndirectExportEntries(); + + /** + * Returns the list of star export entries. + * + * @return the star export entries + */ + public List getStarExportEntries(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ModuleTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ModuleTreeImpl.java new file mode 100644 index 00000000000..df32b0914b8 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ModuleTreeImpl.java @@ -0,0 +1,99 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; +import java.util.stream.Collectors; +import jdk.nashorn.internal.ir.FunctionNode; +import jdk.nashorn.internal.ir.IdentNode; +import jdk.nashorn.internal.ir.Module; +import static jdk.nashorn.api.tree.ExportEntryTreeImpl.createExportList; +import static jdk.nashorn.api.tree.ImportEntryTreeImpl.createImportList; + +final class ModuleTreeImpl extends TreeImpl implements ModuleTree { + + private final Module mod; + private final List imports; + private final List localExports; + private final List indirectExports; + private final List starExports; + + private ModuleTreeImpl(final FunctionNode func, + final List imports, + final List localExports, + final List indirectExports, + final List starExports) { + super(func); + assert func.getKind() == FunctionNode.Kind.MODULE : "module function node expected"; + this.mod = func.getModule(); + this.imports = imports; + this.localExports = localExports; + this.indirectExports = indirectExports; + this.starExports = starExports; + } + + static ModuleTreeImpl create(final FunctionNode func) { + final Module mod = func.getModule(); + return new ModuleTreeImpl(func, + createImportList(mod.getImportEntries()), + createExportList(mod.getLocalExportEntries()), + createExportList(mod.getIndirectExportEntries()), + createExportList(mod.getStarExportEntries())); + } + + @Override + public Kind getKind() { + return Tree.Kind.MODULE; + } + + @Override + public List getImportEntries() { + return imports; + } + + @Override + public List getLocalExportEntries() { + return localExports; + } + + @Override + public List getIndirectExportEntries() { + return indirectExports; + } + + @Override + public List getStarExportEntries() { + return starExports; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitModule(this, data); + } + + static IdentifierTree identOrNull(final IdentNode node) { + return node != null? new IdentifierTreeImpl(node) : null; + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Parser.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Parser.java index 63a1bad3a91..a6643d30226 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Parser.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Parser.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -130,6 +130,8 @@ public interface Parser { *
"--no-syntax-extensions" or "-nse"
disable ECMAScript syntax extensions
*
"-scripting"
enable scripting mode extensions
*
"-strict"
enable ECMAScript strict mode
+ *
"--language=es6"
enable ECMAScript 6 parsing mode
+ *
"--es6-module"
enable ECMAScript 6 module parsing mode. This option implies --language=es6
* * * @throws NullPointerException if options array or any of its element is null @@ -148,6 +150,8 @@ public interface Parser { case "-nse": case "-scripting": case "-strict": + case "--language=es6": + case "--es6-module": break; default: throw new IllegalArgumentException(opt); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ParserImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ParserImpl.java index 97a2c8c219c..1fccd7e94db 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ParserImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/ParserImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -22,7 +22,6 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ - package jdk.nashorn.api.tree; import java.io.File; @@ -31,6 +30,7 @@ import java.io.PrintWriter; import java.io.Reader; import java.net.URL; import java.nio.file.Path; +import java.util.Arrays; import java.util.Map; import java.util.Objects; import jdk.nashorn.api.scripting.NashornException; @@ -47,51 +47,94 @@ import jdk.nashorn.internal.runtime.options.Options; final class ParserImpl implements Parser { private final ScriptEnvironment env; + private final boolean moduleMode; ParserImpl(final String... args) throws IllegalArgumentException { - Objects.requireNonNull(args); - Options options = new Options("nashorn"); - options.process(args); - this.env = new ScriptEnvironment(options, - new PrintWriter(System.out), new PrintWriter(System.err)); + Objects.requireNonNull(args); + + // handle the parser specific "--es6-module" option + boolean seenModuleOption = false; + for (int idx = 0; idx < args.length; idx++) { + final String opt = args[idx]; + if (opt.equals("--es6-module")) { + seenModuleOption = true; + /* + * Nashorn parser does not understand parser API specific + * option. This option implies --language=es6. So, we change + * the option to --language=es6. Note that if user specified + * --language=es6 explicitly, that is okay. Nashorn tolerates + * repeated options! + */ + args[idx] = "--language=es6"; + break; + } + } + this.moduleMode = seenModuleOption; + + // append "--parse-only to signal to the Nashorn that it + // is being used in "parse only" mode. + String[] newArgs = Arrays.copyOf(args, args.length + 1, String[].class); + newArgs[args.length] = "--parse-only"; + Options options = new Options("nashorn"); + options.process(newArgs); + this.env = new ScriptEnvironment(options, + new PrintWriter(System.out), new PrintWriter(System.err)); } @Override public CompilationUnitTree parse(final File file, final DiagnosticListener listener) throws IOException, NashornException { + if (moduleMode) { + return parseModule(file, listener); + } final Source src = Source.sourceFor(Objects.requireNonNull(file).getName(), file); return translate(makeParser(src, listener).parse()); } @Override public CompilationUnitTree parse(final Path path, final DiagnosticListener listener) throws IOException, NashornException { + if (moduleMode) { + return parseModule(path, listener); + } final Source src = Source.sourceFor(Objects.requireNonNull(path).toString(), path); return translate(makeParser(src, listener).parse()); } @Override public CompilationUnitTree parse(final URL url, final DiagnosticListener listener) throws IOException, NashornException { + if (moduleMode) { + return parseModule(url, listener); + } final Source src = Source.sourceFor(url.toString(), url); return translate(makeParser(src, listener).parse()); } @Override public CompilationUnitTree parse(final String name, final Reader reader, final DiagnosticListener listener) throws IOException, NashornException { + if (moduleMode) { + return parseModule(name, reader, listener); + } final Source src = Source.sourceFor(Objects.requireNonNull(name), Objects.requireNonNull(reader)); return translate(makeParser(src, listener).parse()); } @Override public CompilationUnitTree parse(final String name, final String code, final DiagnosticListener listener) throws NashornException { + if (moduleMode) { + return parseModule(name, code, listener); + } final Source src = Source.sourceFor(name, code); return translate(makeParser(src, listener).parse()); } @Override public CompilationUnitTree parse(final ScriptObjectMirror scriptObj, final DiagnosticListener listener) throws NashornException { - final Map map = Objects.requireNonNull(scriptObj); + if (moduleMode) { + return parseModule(scriptObj, listener); + } + final Map map = Objects.requireNonNull(scriptObj); if (map.containsKey("script") && map.containsKey("name")) { final String script = JSType.toString(map.get("script")); - final String name = JSType.toString(map.get("name")); + final String name = JSType.toString(map.get("name")); final Source src = Source.sourceFor(name, script); return translate(makeParser(src, listener).parse()); } else { @@ -99,12 +142,55 @@ final class ParserImpl implements Parser { } } + private CompilationUnitTree parseModule(File file, DiagnosticListener listener) throws IOException, NashornException { + final Source src = Source.sourceFor(Objects.requireNonNull(file).getName(), file); + return makeModule(src, listener); + } + + private CompilationUnitTree parseModule(Path path, DiagnosticListener listener) throws IOException, NashornException { + final Source src = Source.sourceFor(Objects.requireNonNull(path).toString(), path); + return makeModule(src, listener); + } + + private CompilationUnitTree parseModule(URL url, DiagnosticListener listener) throws IOException, NashornException { + final Source src = Source.sourceFor(url.toString(), url); + return makeModule(src, listener); + } + + private CompilationUnitTree parseModule(String name, Reader reader, DiagnosticListener listener) throws IOException, NashornException { + final Source src = Source.sourceFor(Objects.requireNonNull(name), Objects.requireNonNull(reader)); + return makeModule(src, listener); + } + + private CompilationUnitTree parseModule(String name, String code, DiagnosticListener listener) throws NashornException { + final Source src = Source.sourceFor(name, code); + return makeModule(src, listener); + } + + private CompilationUnitTree parseModule(ScriptObjectMirror scriptObj, DiagnosticListener listener) throws NashornException { + final Map map = Objects.requireNonNull(scriptObj); + if (map.containsKey("script") && map.containsKey("name")) { + final String script = JSType.toString(map.get("script")); + final String name = JSType.toString(map.get("name")); + final Source src = Source.sourceFor(name, script); + return makeModule(src, listener); + } else { + throw new IllegalArgumentException("can't find 'script' and 'name' properties"); + } + } + + private CompilationUnitTree makeModule(Source src, DiagnosticListener listener) { + final FunctionNode modFunc = makeParser(src, listener).parseModule(src.getName()); + return new IRTranslator().translate(modFunc); + } + private jdk.nashorn.internal.parser.Parser makeParser(final Source source, final DiagnosticListener listener) { - final ErrorManager errMgr = listener != null? new ListenerErrorManager(listener) : new Context.ThrowErrorManager(); + final ErrorManager errMgr = listener != null ? new ListenerErrorManager(listener) : new Context.ThrowErrorManager(); return new jdk.nashorn.internal.parser.Parser(env, source, errMgr); } private static class ListenerErrorManager extends ErrorManager { + private final DiagnosticListener listener; ListenerErrorManager(final DiagnosticListener listener) { diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTree.java index 0b4af44ce4b..9292bdb15ed 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTree.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -60,4 +60,18 @@ public interface PropertyTree extends Tree { * @return the getter function of the property */ public FunctionExpressionTree getSetter(); + + /** + * Is this a class static property? + * + * @return true if this is a static property + */ + public boolean isStatic(); + + /** + * Is this a computed property? + * + * @return true if this is a computed property + */ + public boolean isComputed(); } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTreeImpl.java index 3e9a73adc6a..1ba734ec731 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/PropertyTreeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -32,6 +32,8 @@ final class PropertyTreeImpl extends TreeImpl implements PropertyTree { private final ExpressionTree value; private final FunctionExpressionTree getter; private final FunctionExpressionTree setter; + private final boolean isStatic, isComputed; + PropertyTreeImpl(final PropertyNode node, final ExpressionTree key, final ExpressionTree value, @@ -42,6 +44,8 @@ final class PropertyTreeImpl extends TreeImpl implements PropertyTree { this.value = value; this.getter = getter; this.setter = setter; + this.isStatic = node.isStatic(); + this.isComputed = node.isComputed(); } @Override @@ -69,6 +73,16 @@ final class PropertyTreeImpl extends TreeImpl implements PropertyTree { return setter; } + @Override + public boolean isStatic() { + return isStatic; + } + + @Override + public boolean isComputed() { + return isComputed; + } + @Override public R accept(final TreeVisitor visitor, final D data) { return visitor.visitProperty(this, data); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/RegExpLiteralTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/RegExpLiteralTree.java index d3729e47dd8..ff77c267d12 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/RegExpLiteralTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/RegExpLiteralTree.java @@ -30,7 +30,7 @@ package jdk.nashorn.api.tree; * * @since 9 */ -public interface RegExpLiteralTree extends Tree { +public interface RegExpLiteralTree extends ExpressionTree { /** * Regular expression pattern to match. * diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SimpleTreeVisitorES5_1.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SimpleTreeVisitorES5_1.java index 1b32c4ee96b..b377690a33f 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SimpleTreeVisitorES5_1.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SimpleTreeVisitorES5_1.java @@ -61,6 +61,45 @@ public class SimpleTreeVisitorES5_1 implements TreeVisitor { return null; } + /** + * Visits a {@code ModuleTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitModule(ModuleTree node, P p) { + return visitUnknown(node, p); + } + + /** + * Visits an {@code ExportEntryTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitExportEntry(ExportEntryTree node, P p) { + return visitUnknown(node, p); + } + + /** + * Visits an {@code ImportEntryTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitImportEntry(ImportEntryTree node, P p) { + return visitUnknown(node, p); + } + @Override public R visitBinary(final BinaryTree node, final P r) { node.getLeftOperand().accept(this, r); @@ -105,6 +144,32 @@ public class SimpleTreeVisitorES5_1 implements TreeVisitor { return null; } + /** + * Visits a {@code ClassDeclarationTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitClassDeclaration(ClassDeclarationTree node, P p) { + return visitUnknown(node, p); + } + + /** + * Visits a {@code ClassExpressionTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitClassExpression(ClassExpressionTree node, P p) { + return visitUnknown(node, p); + } + @Override public R visitConditionalExpression(final ConditionalExpressionTree node, final P r) { node.getCondition().accept(this, r); @@ -173,6 +238,19 @@ public class SimpleTreeVisitorES5_1 implements TreeVisitor { return null; } + /** + * Visits a {@code ForOfLoopTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitForOfLoop(ForOfLoopTree node, P p) { + return visitUnknown(node, p); + } + @Override public R visitFunctionCall(final FunctionCallTree node, final P r) { node.getFunctionSelect().accept(this, r); @@ -305,11 +383,37 @@ public class SimpleTreeVisitorES5_1 implements TreeVisitor { return null; } + /** + * Visits a {@code TemplateLiteralTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitTemplateLiteral(TemplateLiteralTree node, P p) { + return visitUnknown(node, p); + } + @Override public R visitEmptyStatement(final EmptyStatementTree node, final P r) { return null; } + /** + * Visits a {@code SpreadTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ + @Override + public R visitSpread(SpreadTree node, P p) { + return visitUnknown(node, p); + } + @Override public R visitSwitch(final SwitchTree node, final P r) { node.getExpression().accept(this, r); @@ -382,9 +486,36 @@ public class SimpleTreeVisitorES5_1 implements TreeVisitor { return null; } + /** + * Visits a {@code YieldTree} tree by calling {@code + * visitUnknown}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code visitUnknown} + */ @Override - public R visitUnknown(final Tree node, final P r) { + public R visitYield(YieldTree node, P p) { + return visitUnknown(node, p); + } + + /** + * {@inheritDoc} + * + * @implSpec The default implementation of this method in {@code + * SimpleTreeVisitorES5_1} will always throw {@code + * UnknownTypeException}. This behavior is not required of a + * subclass. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return abnormal return by throwing exception always + * @throws UnknownTreeException + * a visitor implementation may optionally throw this exception + */ + @Override + public R visitUnknown(final Tree node, final P p) { // unknown in ECMAScript 5.1 edition - throw new UnknownTreeException(node, r); + throw new UnknownTreeException(node, p); } } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SimpleTreeVisitorES6.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SimpleTreeVisitorES6.java new file mode 100644 index 00000000000..18cca4e6843 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SimpleTreeVisitorES6.java @@ -0,0 +1,226 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; + +/** + * A simple implementation of the TreeVisitor for ECMAScript edition 6. + * + *

The visit methods corresponding to ES 6 language constructs walk the + * "components" of the given tree by calling accept method passing the + * current visitor and the additional parameter. + * + *

For constructs introduced in later versions, {@code visitUnknown} + * is called instead which throws {@link UnknownTreeException}. + * + *

Methods in this class may be overridden subject to their + * general contract. Note that annotating methods in concrete + * subclasses with {@link java.lang.Override @Override} will help + * ensure that methods are overridden as intended. + * + * @param the return type of this visitor's methods. Use {@link + * Void} for visitors that do not need to return results. + * @param

the type of the additional parameter to this visitor's + * methods. Use {@code Void} for visitors that do not need an + * additional parameter. + */ +public class SimpleTreeVisitorES6 extends SimpleTreeVisitorES5_1 { + @Override + public R visitCompilationUnit(final CompilationUnitTree node, final P r) { + final ModuleTree mod = node.getModule(); + if (mod != null) { + mod.accept(this, r); + } + return super.visitCompilationUnit(node, r); + } + + /** + * Visit Module tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitModule(ModuleTree node, P p) { + node.getImportEntries().forEach(e -> visitImportEntry(e, p)); + node.getLocalExportEntries().forEach(e -> visitExportEntry(e, p)); + node.getIndirectExportEntries().forEach(e -> visitExportEntry(e, p)); + node.getStarExportEntries().forEach(e -> visitExportEntry(e, p)); + return null; + } + + /** + * Visit Module ExportEntry tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitExportEntry(ExportEntryTree node, P p) { + return null; + } + + /** + * Visit Module ImportEntry tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitImportEntry(ImportEntryTree node, P p) { + return null; + } + + /** + * Visit class statement tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitClassDeclaration(ClassDeclarationTree node, P p) { + node.getName().accept(this, p); + final ExpressionTree heritage = node.getClassHeritage(); + if (heritage != null) { + heritage.accept(this, p); + } + final PropertyTree constructor = node.getConstructor(); + if (constructor != null) { + constructor.accept(this, p); + } + final List elements = node.getClassElements(); + if (elements != null) { + for (PropertyTree prop : elements) { + prop.accept(this, p); + } + } + + return null; + } + + /** + * Visit class expression tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitClassExpression(ClassExpressionTree node, P p) { + node.getName().accept(this, p); + final ExpressionTree heritage = node.getClassHeritage(); + if (heritage != null) { + heritage.accept(this, p); + } + final PropertyTree constructor = node.getConstructor(); + if (constructor != null) { + constructor.accept(this, p); + } + final List elements = node.getClassElements(); + if (elements != null) { + for (PropertyTree prop : elements) { + prop.accept(this, p); + } + } + + return null; + } + + /** + * Visit for..of statement tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitForOfLoop(final ForOfLoopTree node, final P p) { + node.getVariable().accept(this, p); + node.getExpression().accept(this, p); + final StatementTree stat = node.getStatement(); + if (stat != null) { + stat.accept(this, p); + } + return null; + } + + /** + * Visit 'yield' expression tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitYield(YieldTree node, P p) { + node.getExpression().accept(this, p); + return null; + } + + /** + * Visit 'spread' expression tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitSpread(SpreadTree node, P p) { + node.getExpression().accept(this, p); + return null; + } + + /** + * Visit template literal tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + @Override + public R visitTemplateLiteral(TemplateLiteralTree node, P p) { + final List expressions = node.getExpressions(); + for (ExpressionTree expr : expressions) { + expr.accept(this, p); + } + return null; + } + + @Override + public R visitVariable(final VariableTree node, final P r) { + final ExpressionTree expr = node.getBinding(); + if (expr != null) { + expr.accept(this, r); + } + super.visitVariable(node, r); + return null; + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SpreadTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SpreadTree.java new file mode 100644 index 00000000000..ca66dce8580 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SpreadTree.java @@ -0,0 +1,38 @@ +/* + * Copyright (c) 2016, 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; + +/** + * A tree node for spread operator in array elements, function call arguments. + */ +public interface SpreadTree extends ExpressionTree { + /** + * Returns the expression that is being spread. + * + * @return The expression that is being spread. + */ + ExpressionTree getExpression(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SpreadTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SpreadTreeImpl.java new file mode 100644 index 00000000000..a01601f7097 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/SpreadTreeImpl.java @@ -0,0 +1,53 @@ +/* + * Copyright (c) 2016, 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; + +import jdk.nashorn.internal.ir.Expression; + +final class SpreadTreeImpl extends ExpressionTreeImpl + implements SpreadTree { + + private final ExpressionTree expr; + + SpreadTreeImpl(final Expression exprNode, final ExpressionTree expr) { + super(exprNode); + this.expr = expr; + } + + @Override + public Tree.Kind getKind() { + return Tree.Kind.SPREAD; + } + + @Override + public ExpressionTree getExpression() { + return expr; + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitSpread(this, data); + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TemplateLiteralTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TemplateLiteralTree.java new file mode 100644 index 00000000000..86bc4195ed5 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TemplateLiteralTree.java @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; + +/** + * A tree node for template literal strings. + * + * For example: + *

+ * `This is a String with ${computed} values in it`
+ * 
+ * + * @since 9 + * + */ +public interface TemplateLiteralTree extends ExpressionTree { + /** + * Returns the list of expressions in this template string + * + * @return the list of expressions in this template string + */ + List getExpressions(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TemplateLiteralTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TemplateLiteralTreeImpl.java new file mode 100644 index 00000000000..e3be74fe929 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TemplateLiteralTreeImpl.java @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2016, 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; + +import java.util.List; +import jdk.nashorn.internal.ir.Expression; + +final class TemplateLiteralTreeImpl extends ExpressionTreeImpl + implements TemplateLiteralTree { + + private final List expressions; + + TemplateLiteralTreeImpl(Expression node, List expressions) { + super(node); + this.expressions = expressions; + } + + @Override + public Kind getKind() { + return Kind.TEMPLATE_LITERAL; + } + + @Override + public List getExpressions() { + return expressions; + } + + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitTemplateLiteral(this, data); + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Tree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Tree.java index 6b3de2c3591..3d8c2bf13d6 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Tree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/Tree.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -64,6 +64,16 @@ public interface Tree { */ BREAK(BreakTree.class), + /** + * Used for instances of {@link ClassDeclarationTree}. + */ + CLASS(ClassDeclarationTree.class), + + /** + * Used for instances of {@link ClassExpressionTree}. + */ + CLASS_EXPRESSION(ClassExpressionTree.class), + /** * Used for instances of {@link CaseTree}. */ @@ -149,6 +159,21 @@ public interface Tree { */ LABELED_STATEMENT(LabeledStatementTree.class), + /** + * Used for instances of {@link ModuleTree}. + */ + MODULE(ModuleTree.class), + + /** + * Used for instances of {@link ExportEntryTree}. + */ + EXPORT_ENTRY(ExportEntryTree.class), + + /** + * Used for instances of {@link ImportEntryTree}. + */ + IMPORT_ENTRY(ImportEntryTree.class), + /** * Used for instances of {@link FunctionDeclarationTree}. */ @@ -184,6 +209,11 @@ public interface Tree { */ REGEXP_LITERAL(RegExpLiteralTree.class), + /** + * Used for instances of {@link TemplateLiteralTree}. + */ + TEMPLATE_LITERAL(TemplateLiteralTree.class), + /** * Used for instances of {@link ReturnTree}. */ @@ -286,7 +316,7 @@ public interface Tree { /** * Used for instances of {@link UnaryTree} representing logical - * void operator {@code typeof}. + * void operator {@code void}. */ VOID(UnaryTree.class), @@ -494,6 +524,18 @@ public interface Tree { */ OR_ASSIGNMENT(CompoundAssignmentTree.class), + /** + * Used for instances of {@link SpreadTree} representing + * spread "operator" for arrays and function call arguments. + */ + SPREAD(SpreadTree.class), + + /** + * Used for instances of {@link YieldTree} representing (generator) + * yield expression {@code yield expr}. + */ + YIELD(YieldTree.class), + /** * Used for instances of {@link LiteralTree} representing * a number literal expression of type {@code double}. diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeImpl.java index 1e3b6646f23..0df9037df31 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -137,10 +137,15 @@ abstract class TreeImpl implements Tree { return Kind.BITWISE_COMPLEMENT; case DELETE: return Kind.DELETE; + case SPREAD_ARRAY: + case SPREAD_ARGUMENT: + return Kind.SPREAD; case TYPEOF: return Kind.TYPEOF; case VOID: return Kind.VOID; + case YIELD: + return Kind.YIELD; case IN: return Kind.IN; case INSTANCEOF: diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeVisitor.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeVisitor.java index c9c8a9666d8..ea8fc0d4222 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeVisitor.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/TreeVisitor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -117,6 +117,24 @@ public interface TreeVisitor { */ R visitCatch(CatchTree node, P p); + /** + * Visit class statement tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitClassDeclaration(ClassDeclarationTree node, P p); + + /** + * Visit class expression tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitClassExpression(ClassExpressionTree node, P p); + /** * Visit conditional expression tree. * @@ -189,6 +207,15 @@ public interface TreeVisitor { */ R visitForInLoop(ForInLoopTree node, P p); + /** + * Visit for..of statement tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitForOfLoop(ForOfLoopTree node, P p); + /** * Visit function call expression tree. * @@ -216,7 +243,7 @@ public interface TreeVisitor { */ R visitFunctionExpression(FunctionExpressionTree node, P p); - /** + /** * Visit identifier tree. * * @param node node being visited @@ -333,6 +360,15 @@ public interface TreeVisitor { */ R visitRegExpLiteral(RegExpLiteralTree node, P p); + /** + * Visit template literal tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitTemplateLiteral(TemplateLiteralTree node, P p); + /** * Visit an empty statement tree. * @@ -342,6 +378,15 @@ public interface TreeVisitor { */ R visitEmptyStatement(EmptyStatementTree node, P p); + /** + * Visit 'spread' expression tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitSpread(SpreadTree node, P p); + /** * Visit 'switch' statement tree. * @@ -369,6 +414,33 @@ public interface TreeVisitor { */ R visitCompilationUnit(CompilationUnitTree node, P p); + /** + * Visit Module tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitModule(ModuleTree node, P p); + + /** + * Visit Module ExportEntry tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitExportEntry(ExportEntryTree node, P p); + + /** + * Visit Module ImportEntry tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitImportEntry(ImportEntryTree node, P p); + /** * Visit 'try' statement tree. * @@ -423,6 +495,15 @@ public interface TreeVisitor { */ R visitWith(WithTree node, P p); + /** + * Visit 'yield' expression tree. + * + * @param node node being visited + * @param p extra parameter passed to the visitor + * @return value from the visitor + */ + R visitYield(YieldTree node, P p); + /** * Visit unknown expression/statement tree. This fallback will be * called if new Tree subtypes are introduced in future. A specific diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTree.java index 8697360b9bc..b0cbada632f 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTree.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTree.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -26,22 +26,26 @@ package jdk.nashorn.api.tree; /** - * A tree node for a variable declaration. + * A tree node for a variable declaration statement. * * For example: *
- *   var name initializer ;
+ *   var name [ initializer ] ;
+ *   var binding_pattern [ initializer ];
  * 
* * @since 9 */ public interface VariableTree extends StatementTree { /** - * Returns the name of this variable. + * Returns the binding of this declaration. This is an {@link IdentifierTree} + * for a binding identifier case (simple variable declaration). + * This is an {@link ObjectLiteralTree} or a {@link ArrayLiteralTree} for a + * destructuring declaration. * - * @return the name of this variable + * @return the binding expression of this declaration */ - String getName(); + ExpressionTree getBinding(); /** * Returns the initial value expression for this variable. This is @@ -50,4 +54,18 @@ public interface VariableTree extends StatementTree { * @return the initial value expression */ ExpressionTree getInitializer(); + + /** + * Is this a const declaration? + * + * @return true if this is a const declaration + */ + boolean isConst(); + + /** + * Is this a let declaration? + * + * @return true if this is a let declaration + */ + boolean isLet(); } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTreeImpl.java index ca56511f1f9..a1e6f6f7e89 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTreeImpl.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/VariableTreeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 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 @@ -28,12 +28,12 @@ package jdk.nashorn.api.tree; import jdk.nashorn.internal.ir.VarNode; final class VariableTreeImpl extends StatementTreeImpl implements VariableTree { - private final String name; + private final IdentifierTree ident; private final ExpressionTree init; - VariableTreeImpl(final VarNode node, final ExpressionTree init) { + VariableTreeImpl(final VarNode node, final IdentifierTree ident, final ExpressionTree init) { super(node); - this.name = node.getName().getName(); + this.ident = ident; this.init = init; } @@ -43,8 +43,8 @@ final class VariableTreeImpl extends StatementTreeImpl implements VariableTree { } @Override - public String getName() { - return name; + public ExpressionTree getBinding() { + return ident; } @Override @@ -52,6 +52,16 @@ final class VariableTreeImpl extends StatementTreeImpl implements VariableTree { return init; } + @Override + public boolean isConst() { + return ((VarNode)node).isConst(); + } + + @Override + public boolean isLet() { + return ((VarNode)node).isLet(); + } + @Override public R accept(final TreeVisitor visitor, final D data) { return visitor.visitVariable(this, data); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/YieldTree.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/YieldTree.java new file mode 100644 index 00000000000..0b21bb0be2c --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/YieldTree.java @@ -0,0 +1,66 @@ +/* + * Copyright (c) 2016, 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; + +/** + * A tree node for yield expressions used in generator functions. + * + * For example: + *
+ * function* id(){
+ *     var index = 0;
+ *     while(index < 10)
+ *         yield index++;
+ * }
+ * 
+ * + * @since 9 + */ +public interface YieldTree extends ExpressionTree { + /** + * Returns the expression that is yielded. + * + * @return The expression that is yielded. + */ + ExpressionTree getExpression(); + + /** + * Is this a yield * expression in a generator function? + * + * For example: + *
+     * function* id(){
+     *     yield 1;
+     *     yield * anotherGeneratorFunc();
+     *     yield 10;
+     * }
+     * 
+ * + * + * @return true if this is a yield * expression + */ + boolean isStar(); +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/YieldTreeImpl.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/YieldTreeImpl.java new file mode 100644 index 00000000000..aea75d81a4c --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/api/tree/YieldTreeImpl.java @@ -0,0 +1,60 @@ +/* + * Copyright (c) 2016, 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; + +import jdk.nashorn.internal.ir.Expression; +import jdk.nashorn.internal.ir.UnaryNode; +import jdk.nashorn.internal.parser.TokenType; + +final class YieldTreeImpl extends ExpressionTreeImpl + implements YieldTree { + + private final ExpressionTree expr; + + YieldTreeImpl(final Expression exprNode, final ExpressionTree expr) { + super(exprNode); + this.expr = expr; + } + + @Override + public Kind getKind() { + return Kind.YIELD; + } + + @Override + public ExpressionTree getExpression() { + return expr; + } + + @Override + public boolean isStar() { + return ((UnaryNode) node).isTokenType(TokenType.YIELD_STAR); + } + + @Override + public R accept(final TreeVisitor visitor, final D data) { + return visitor.visitYield(this, data); + } +} diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/SplitIntoFunctions.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/SplitIntoFunctions.java index 1489e01a859..20074338de3 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/SplitIntoFunctions.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/SplitIntoFunctions.java @@ -167,6 +167,7 @@ final class SplitIntoFunctions extends NodeVisitor { createIdent(name), originalFn.getName() + "$" + name, isProgram ? Collections.singletonList(createReturnParamIdent()) : Collections.emptyList(), + null, FunctionNode.Kind.NORMAL, // We only need IS_SPLIT conservatively, in case it contains any array units so that we force // the :callee's existence, to force :scope to never be in a slot lower than 2. This is actually diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ClassNode.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ClassNode.java index 4c0c6ffb175..4b06d223a43 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ClassNode.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ClassNode.java @@ -42,6 +42,7 @@ public class ClassNode extends Expression { private final PropertyNode constructor; private final List classElements; private final int line; + private final boolean isStatement; /** * Constructor. @@ -53,15 +54,17 @@ public class ClassNode extends Expression { * @param classHeritage class heritage * @param constructor constructor * @param classElements class elements + * @param isStatement is this a statement or an expression? */ public ClassNode(final int line, final long token, final int finish, final IdentNode ident, final Expression classHeritage, final PropertyNode constructor, - final List classElements) { + final List classElements, final boolean isStatement) { super(token, finish); this.line = line; this.ident = ident; this.classHeritage = classHeritage; this.constructor = constructor; this.classElements = classElements; + this.isStatement = isStatement; } /** @@ -100,6 +103,15 @@ public class ClassNode extends Expression { return Collections.unmodifiableList(classElements); } + /** + * Returns if this class was a statement or an expression + * + * @return true if this class was a statement + */ + public boolean isStatement() { + return isStatement; + } + /** * Returns the line number. * diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ExpressionStatement.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ExpressionStatement.java index b8e5428011e..21618ab8657 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ExpressionStatement.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/ExpressionStatement.java @@ -27,6 +27,7 @@ package jdk.nashorn.internal.ir; import jdk.nashorn.internal.ir.annotations.Immutable; import jdk.nashorn.internal.ir.visitor.NodeVisitor; +import jdk.nashorn.internal.parser.TokenType; /** * IR representation for executing bare expressions. Basically, an expression @@ -39,6 +40,23 @@ public final class ExpressionStatement extends Statement { /** Expression to execute. */ private final Expression expression; + private final TokenType destructuringDecl; + + /** + * Constructor + * + * @param lineNumber line number + * @param token token + * @param finish finish + * @param expression the expression to execute + * @param destructuringDecl does this statement represent a destructuring declaration? + */ + public ExpressionStatement(final int lineNumber, final long token, final int finish, + final Expression expression, final TokenType destructuringDecl) { + super(lineNumber, token, finish); + this.expression = expression; + this.destructuringDecl = destructuringDecl; + } /** * Constructor @@ -49,13 +67,13 @@ public final class ExpressionStatement extends Statement { * @param expression the expression to execute */ public ExpressionStatement(final int lineNumber, final long token, final int finish, final Expression expression) { - super(lineNumber, token, finish); - this.expression = expression; + this(lineNumber, token, finish, expression, null); } private ExpressionStatement(final ExpressionStatement expressionStatement, final Expression expression) { super(expressionStatement); this.expression = expression; + this.destructuringDecl = null; } @Override @@ -80,6 +98,15 @@ public final class ExpressionStatement extends Statement { return expression; } + /** + * Return declaration type if this expression statement is a destructuring declaration + * + * @return declaration type (LET, VAR, CONST) if destructuring declaration, null otherwise. + */ + public TokenType destructuringDeclarationType() { + return destructuringDecl; + } + /** * Reset the expression to be executed * @param expression the expression diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/FunctionNode.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/FunctionNode.java index 8eda934b542..89bfcab5a76 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/FunctionNode.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/FunctionNode.java @@ -35,6 +35,7 @@ import static jdk.nashorn.internal.runtime.linker.NashornCallSiteDescriptor.CALL import java.util.Collections; import java.util.Iterator; import java.util.List; +import java.util.Map; import jdk.nashorn.internal.codegen.CompileUnit; import jdk.nashorn.internal.codegen.Compiler; import jdk.nashorn.internal.codegen.CompilerConstants; @@ -106,6 +107,9 @@ public final class FunctionNode extends LexicalContextExpression implements Flag /** List of parameters. */ private final List parameters; + /** Map of ES6 function parameter expressions. */ + private final Map parameterExpressions; + /** First token of function. **/ private final long firstToken; @@ -242,6 +246,9 @@ public final class FunctionNode extends LexicalContextExpression implements Flag /** Does this function use new.target? */ public static final int ES6_USES_NEW_TARGET = 1 << 25; + /** Does this function have expression as its body? */ + public static final int HAS_EXPRESSION_BODY = 1 << 26; + /** Does this function or any nested functions contain an eval? */ private static final int HAS_DEEP_EVAL = HAS_EVAL | HAS_NESTED_EVAL; @@ -306,6 +313,7 @@ public final class FunctionNode extends LexicalContextExpression implements Flag * @param ident the identifier * @param name the name of the function * @param parameters parameter list + * @param paramExprs the ES6 function parameter expressions * @param kind kind of function as in {@link FunctionNode.Kind} * @param flags initial flags * @param body body of the function @@ -324,6 +332,7 @@ public final class FunctionNode extends LexicalContextExpression implements Flag final IdentNode ident, final String name, final List parameters, + final Map paramExprs, final FunctionNode.Kind kind, final int flags, final Block body, @@ -338,6 +347,7 @@ public final class FunctionNode extends LexicalContextExpression implements Flag this.name = name; this.kind = kind; this.parameters = parameters; + this.parameterExpressions = paramExprs; this.firstToken = firstToken; this.lastToken = lastToken; this.namespace = namespace; @@ -375,6 +385,7 @@ public final class FunctionNode extends LexicalContextExpression implements Flag this.lastToken = lastToken; this.body = body; this.parameters = parameters; + this.parameterExpressions = functionNode.parameterExpressions; this.thisProperties = thisProperties; this.rootClass = rootClass; this.source = source; @@ -976,6 +987,15 @@ public final class FunctionNode extends LexicalContextExpression implements Flag return Collections.unmodifiableList(parameters); } + /** + * Get the ES6 style parameter expressions of this function. This may be null. + * + * @return a Map of parameter IdentNode to Expression node (for ES6 parameter expressions) + */ + public Map getParameterExpressions() { + return parameterExpressions; + } + /** * Return the number of parameters to this function * @return the number of parameters diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/TemplateLiteral.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/TemplateLiteral.java new file mode 100644 index 00000000000..0a7dc89f2f0 --- /dev/null +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/TemplateLiteral.java @@ -0,0 +1,77 @@ +/* + * Copyright (c) 2010, 2013, 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.internal.ir; + +import java.util.Collections; +import java.util.List; +import jdk.nashorn.internal.codegen.types.Type; +import jdk.nashorn.internal.ir.visitor.NodeVisitor; + +/** + * Represents ES6 template string expression. Note that this Node class is used + * only in "parse only" mode. In evaluation mode, Parser directly folds template + * literal as string concatenation. Parser API uses this node to represent ES6 + * template literals "as is" rather than as a String concatenation. + */ +public final class TemplateLiteral extends Expression { + private static final long serialVersionUID = 1L; + private final List exprs; + + public TemplateLiteral(final List exprs) { + super(exprs.get(0).getToken(), exprs.get(exprs.size() - 1).finish); + this.exprs = exprs; + } + + @Override + public Type getType() { + return Type.STRING; + } + + @Override + public Node accept(NodeVisitor visitor) { + if (visitor.enterTemplateLiteral(this)) { + return visitor.leaveTemplateLiteral(this); + } + + return this; + } + + @Override + public void toString(StringBuilder sb, boolean printType) { + for (Expression expr : exprs) { + sb.append(expr); + } + } + + /** + * The list of expressions that are part of this template literal. + * + * @return the list of expressions that are part of this template literal. + */ + public List getExpressions() { + return Collections.unmodifiableList(exprs); + } +} \ No newline at end of file diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/visitor/NodeVisitor.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/visitor/NodeVisitor.java index c83587c34d4..2aba91fadfd 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/visitor/NodeVisitor.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/ir/visitor/NodeVisitor.java @@ -59,6 +59,7 @@ import jdk.nashorn.internal.ir.SetSplitState; import jdk.nashorn.internal.ir.SplitNode; import jdk.nashorn.internal.ir.SplitReturn; import jdk.nashorn.internal.ir.SwitchNode; +import jdk.nashorn.internal.ir.TemplateLiteral; import jdk.nashorn.internal.ir.TernaryNode; import jdk.nashorn.internal.ir.ThrowNode; import jdk.nashorn.internal.ir.TryNode; @@ -737,6 +738,26 @@ public abstract class NodeVisitor { return leaveDefault(switchNode); } + /** + * Callback for entering a TemplateLiteral (used only in --parse-only mode) + * + * @param templateLiteral the node + * @return true if traversal should continue and node children be traversed, false otherwise + */ + public boolean enterTemplateLiteral(final TemplateLiteral templateLiteral) { + return enterDefault(templateLiteral); + } + + /** + * Callback for leaving a TemplateLiteral (used only in --parse-only mode) + * + * @param templateLiteral the node + * @return processed node, which will replace the original one, or the original node + */ + public Node leaveTemplateLiteral(final TemplateLiteral templateLiteral) { + return leaveDefault(templateLiteral); + } + /** * Callback for entering a TernaryNode * diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java index b9a926d1029..46675820e4b 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/Parser.java @@ -127,6 +127,7 @@ import jdk.nashorn.internal.ir.ReturnNode; import jdk.nashorn.internal.ir.RuntimeNode; import jdk.nashorn.internal.ir.Statement; import jdk.nashorn.internal.ir.SwitchNode; +import jdk.nashorn.internal.ir.TemplateLiteral; import jdk.nashorn.internal.ir.TernaryNode; import jdk.nashorn.internal.ir.ThrowNode; import jdk.nashorn.internal.ir.TryNode; @@ -545,7 +546,7 @@ public class Parser extends AbstractParser implements Loggable { sb.append(ident.getName()); final String name = namespace.uniqueName(sb.toString()); - assert parentFunction != null || name.equals(PROGRAM.symbolName()) : "name = " + name; + assert parentFunction != null || kind == FunctionNode.Kind.MODULE || name.equals(PROGRAM.symbolName()) : "name = " + name; int flags = 0; if (isStrictMode) { @@ -575,6 +576,7 @@ public class Parser extends AbstractParser implements Loggable { ident, function.getName(), parameters, + function.getParameterExpressions(), kind, function.getFlags(), body, @@ -622,19 +624,6 @@ public class Parser extends AbstractParser implements Loggable { return new Block(blockToken, finish, flags, newBlock.getStatements()); } - /** - * Get the statements in a case clause. - */ - private List caseStatementList() { - final ParserContextBlockNode newBlock = newBlock(); - try { - statementList(); - } finally { - restoreBlock(newBlock); - } - return newBlock.getStatements(); - } - /** * Get all the statements generated by a single statement. * @return Statements. @@ -855,17 +844,6 @@ public class Parser extends AbstractParser implements Loggable { }); } - private static Expression newBinaryExpression(final long op, final Expression lhs, final Expression rhs) { - final TokenType opType = Token.descType(op); - - // Build up node. - if (BinaryNode.isLogical(opType)) { - return new BinaryNode(op, new JoinPredecessorExpression(lhs), new JoinPredecessorExpression(rhs)); - } - return new BinaryNode(op, lhs, rhs); - } - - /** * Reduce increment/decrement to simpler operations. * @param firstToken First token. @@ -1268,7 +1246,7 @@ public class Parser extends AbstractParser implements Loggable { className = getIdent(); } - return classTail(classLineNumber, classToken, className); + return classTail(classLineNumber, classToken, className, isStatement); } private static final class ClassElementKey { @@ -1317,7 +1295,8 @@ public class Parser extends AbstractParser implements Loggable { * static MethodDefinition[?Yield] * ; */ - private ClassNode classTail(final int classLineNumber, final long classToken, final IdentNode className) { + private ClassNode classTail(final int classLineNumber, final long classToken, + final IdentNode className, final boolean isStatement) { final boolean oldStrictMode = isStrictMode; isStrictMode = true; try { @@ -1399,7 +1378,7 @@ public class Parser extends AbstractParser implements Loggable { } classElements.trimToSize(); - return new ClassNode(classLineNumber, classToken, finish, className, classHeritage, constructor, classElements); + return new ClassNode(classLineNumber, classToken, finish, className, classHeritage, constructor, classElements, isStatement); } finally { isStrictMode = oldStrictMode; } @@ -1601,6 +1580,9 @@ public class Parser extends AbstractParser implements Loggable { private List variableDeclarationList(final TokenType varType, final boolean isStatement, final int sourceOrder) { // VAR tested in caller. assert varType == VAR || varType == LET || varType == CONST; + final int varLine = line; + final long varToken = token; + next(); final List bindings = new ArrayList<>(); @@ -1613,9 +1595,6 @@ public class Parser extends AbstractParser implements Loggable { Expression missingAssignment = null; while (true) { - // Get starting token. - final int varLine = line; - final long varToken = token; // Get name of var. if (type == YIELD && inGeneratorFunction()) { expect(IDENT); @@ -1627,10 +1606,14 @@ public class Parser extends AbstractParser implements Loggable { if (isDestructuring) { final int finalVarFlags = varFlags; verifyDestructuringBindingPattern(binding, new Consumer() { + @Override public void accept(final IdentNode identNode) { verifyIdent(identNode, contextString); - final VarNode var = new VarNode(varLine, varToken, sourceOrder, identNode.getFinish(), identNode.setIsDeclaredHere(), null, finalVarFlags); - appendStatement(var); + if (!env._parse_only) { + // don't bother adding a variable if we are just parsing! + final VarNode var = new VarNode(varLine, varToken, sourceOrder, identNode.getFinish(), identNode.setIsDeclaredHere(), null, finalVarFlags); + appendStatement(var); + } } }); } @@ -1682,7 +1665,7 @@ public class Parser extends AbstractParser implements Loggable { assert init != null || !isStatement; binding = init == null ? binding : verifyAssignment(Token.recast(varToken, ASSIGN), binding, init); if (isStatement) { - appendStatement(new ExpressionStatement(varLine, binding.getToken(), finish, binding)); + appendStatement(new ExpressionStatement(varLine, binding.getToken(), finish, binding, varType)); } else if (init == null) { if (missingAssignment == null) { missingAssignment = binding; @@ -1748,7 +1731,8 @@ public class Parser extends AbstractParser implements Loggable { * Verify destructuring variable declaration binding pattern and extract bound variable declarations. */ private void verifyDestructuringBindingPattern(final Expression pattern, final Consumer identifierCallback) { - assert pattern instanceof ObjectNode || pattern instanceof LiteralNode.ArrayLiteralNode; + assert (pattern instanceof BinaryNode && ((BinaryNode)pattern).isTokenType(ASSIGN)) || + pattern instanceof ObjectNode || pattern instanceof LiteralNode.ArrayLiteralNode; pattern.accept(new NodeVisitor(new LexicalContext()) { @Override public boolean enterLiteralNode(final LiteralNode literalNode) { @@ -1857,9 +1841,8 @@ public class Parser extends AbstractParser implements Loggable { // Get expression and add as statement. final Expression expression = expression(); - ExpressionStatement expressionStatement = null; if (expression != null) { - expressionStatement = new ExpressionStatement(expressionLine, expressionToken, finish, expression); + ExpressionStatement expressionStatement = new ExpressionStatement(expressionLine, expressionToken, finish, expression); appendStatement(expressionStatement); } else { expect(null); @@ -2625,6 +2608,10 @@ public class Parser extends AbstractParser implements Loggable { final long catchToken = token; next(); expect(LPAREN); + + // FIXME: ES6 catch parameter can be a BindingIdentifier or a BindingPattern + // We need to generalize this here! + // http://www.ecma-international.org/ecma-262/6.0/ final IdentNode exception = getIdent(); // ECMA 12.4.1 strict mode restrictions @@ -4021,12 +4008,18 @@ public class Parser extends AbstractParser implements Loggable { ParserContextFunctionNode currentFunction = lc.getCurrentFunction(); if (currentFunction != null) { - // desugar to: param = (param === undefined) ? initializer : param; - // possible alternative: if (param === undefined) param = initializer; - BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); - TernaryNode value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); - BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), ident, value); - lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + if (env._parse_only) { + // keep what is seen in source "as is" and save it as parameter expression + BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), ident, initializer); + currentFunction.addParameterExpression(ident, assignment); + } else { + // desugar to: param = (param === undefined) ? initializer : param; + // possible alternative: if (param === undefined) param = initializer; + BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); + TernaryNode value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); + BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), ident, value); + lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + } } } @@ -4050,16 +4043,31 @@ public class Parser extends AbstractParser implements Loggable { // binding pattern with initializer. desugar to: (param === undefined) ? initializer : param Expression initializer = assignmentExpression(false); - // TODO initializer must not contain yield expression if yield=true (i.e. this is generator function's parameter list) - BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); - value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); + + if (env._parse_only) { + // we don't want the synthetic identifier in parse only mode + value = initializer; + } else { + // TODO initializer must not contain yield expression if yield=true (i.e. this is generator function's parameter list) + BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); + value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); + } } ParserContextFunctionNode currentFunction = lc.getCurrentFunction(); if (currentFunction != null) { // destructuring assignment BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), pattern, value); - lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + if (env._parse_only) { + // in parse-only mode, represent source tree "as is" + if (ident.isDefaultParameter()) { + currentFunction.addParameterExpression(ident, assignment); + } else { + currentFunction.addParameterExpression(ident, pattern); + } + } else { + lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + } } } parameters.add(ident); @@ -4077,7 +4085,9 @@ public class Parser extends AbstractParser implements Loggable { ParserContextFunctionNode currentFunction = lc.getCurrentFunction(); if (currentFunction != null) { // declare function-scope variables for destructuring bindings - lc.getFunctionBody(currentFunction).appendStatement(new VarNode(paramLine, Token.recast(paramToken, VAR), pattern.getFinish(), identNode, null)); + if (!env._parse_only) { + lc.getFunctionBody(currentFunction).appendStatement(new VarNode(paramLine, Token.recast(paramToken, VAR), pattern.getFinish(), identNode, null)); + } // detect duplicate bounds names in parameter list currentFunction.addParameterBinding(identNode); currentFunction.setSimpleParameterList(false); @@ -4136,6 +4146,7 @@ public class Parser extends AbstractParser implements Loggable { // the note below for reasoning on skipping happening before instead of after RBRACE for // details). if (parseBody) { + functionNode.setFlag(FunctionNode.HAS_EXPRESSION_BODY); final ReturnNode returnNode = new ReturnNode(functionNode.getLineNumber(), expr.getToken(), lastFinish, expr); appendStatement(returnNode); } @@ -4305,7 +4316,7 @@ public class Parser extends AbstractParser implements Loggable { } private RuntimeNode referenceError(final Expression lhs, final Expression rhs, final boolean earlyError) { - if (earlyError) { + if (env._parse_only || earlyError) { throw error(JSErrorType.REFERENCE_ERROR, AbstractParser.message("invalid.lvalue"), lhs.getToken()); } final ArrayList args = new ArrayList<>(); @@ -4838,10 +4849,14 @@ public class Parser extends AbstractParser implements Loggable { ParserContextFunctionNode currentFunction = lc.getCurrentFunction(); if (currentFunction != null) { - BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); - TernaryNode value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); - BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), ident, value); - lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + if (env._parse_only) { + currentFunction.addParameterExpression(ident, param); + } else { + BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); + TernaryNode value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); + BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), ident, value); + lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + } currentFunction.addParameterBinding(ident); currentFunction.setSimpleParameterList(false); @@ -4855,10 +4870,14 @@ public class Parser extends AbstractParser implements Loggable { ParserContextFunctionNode currentFunction = lc.getCurrentFunction(); if (currentFunction != null) { - BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); - TernaryNode value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); - BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), param, value); - lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + if (env._parse_only) { + currentFunction.addParameterExpression(ident, param); + } else { + BinaryNode test = new BinaryNode(Token.recast(paramToken, EQ_STRICT), ident, newUndefinedLiteral(paramToken, finish)); + TernaryNode value = new TernaryNode(Token.recast(paramToken, TERNARY), test, new JoinPredecessorExpression(initializer), new JoinPredecessorExpression(ident)); + BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), param, value); + lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + } } return ident; } @@ -4872,8 +4891,12 @@ public class Parser extends AbstractParser implements Loggable { ParserContextFunctionNode currentFunction = lc.getCurrentFunction(); if (currentFunction != null) { - BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), param, ident); - lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + if (env._parse_only) { + currentFunction.addParameterExpression(ident, param); + } else { + BinaryNode assignment = new BinaryNode(Token.recast(paramToken, ASSIGN), param, ident); + lc.getFunctionBody(currentFunction).appendStatement(new ExpressionStatement(paramLine, assignment.getToken(), assignment.getFinish(), assignment)); + } } return ident; } @@ -4982,20 +5005,37 @@ public class Parser extends AbstractParser implements Loggable { return literal; } - Expression concat = literal; - TokenType lastLiteralType; - do { - final Expression expression = expression(); - if (type != TEMPLATE_MIDDLE && type != TEMPLATE_TAIL) { - throw error(AbstractParser.message("unterminated.template.expression"), token); - } - concat = new BinaryNode(Token.recast(lastLiteralToken, TokenType.ADD), concat, expression); - lastLiteralType = type; - lastLiteralToken = token; - literal = getLiteral(); - concat = new BinaryNode(Token.recast(lastLiteralToken, TokenType.ADD), concat, literal); - } while (lastLiteralType == TEMPLATE_MIDDLE); - return concat; + if (env._parse_only) { + List exprs = new ArrayList<>(); + exprs.add(literal); + TokenType lastLiteralType; + do { + final Expression expression = expression(); + if (type != TEMPLATE_MIDDLE && type != TEMPLATE_TAIL) { + throw error(AbstractParser.message("unterminated.template.expression"), token); + } + exprs.add(expression); + lastLiteralType = type; + literal = getLiteral(); + exprs.add(literal); + } while (lastLiteralType == TEMPLATE_MIDDLE); + return new TemplateLiteral(exprs); + } else { + Expression concat = literal; + TokenType lastLiteralType; + do { + final Expression expression = expression(); + if (type != TEMPLATE_MIDDLE && type != TEMPLATE_TAIL) { + throw error(AbstractParser.message("unterminated.template.expression"), token); + } + concat = new BinaryNode(Token.recast(lastLiteralToken, TokenType.ADD), concat, expression); + lastLiteralType = type; + lastLiteralToken = token; + literal = getLiteral(); + concat = new BinaryNode(Token.recast(lastLiteralToken, TokenType.ADD), concat, literal); + } while (lastLiteralType == TEMPLATE_MIDDLE); + return concat; + } } /** diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/ParserContextFunctionNode.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/ParserContextFunctionNode.java index cfd8b293071..0e53c2b376a 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/ParserContextFunctionNode.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/parser/ParserContextFunctionNode.java @@ -24,9 +24,12 @@ */ package jdk.nashorn.internal.parser; +import java.util.HashMap; import java.util.HashSet; import java.util.List; +import java.util.Map; import jdk.nashorn.internal.codegen.Namespace; +import jdk.nashorn.internal.ir.Expression; import jdk.nashorn.internal.ir.FunctionNode; import jdk.nashorn.internal.ir.IdentNode; import jdk.nashorn.internal.ir.Module; @@ -70,6 +73,7 @@ class ParserContextFunctionNode extends ParserContextBaseNode { private Module module; private int debugFlags; + private Map parameterExpressions; /** * @param token The token for the function @@ -169,6 +173,22 @@ class ParserContextFunctionNode extends ParserContextBaseNode { this.parameters = parameters; } + /** + * Return ES6 function parameter expressions + * + * @return ES6 function parameter expressions + */ + public Map getParameterExpressions() { + return parameterExpressions; + } + + void addParameterExpression(IdentNode ident, Expression node) { + if (parameterExpressions == null) { + parameterExpressions = new HashMap<>(); + } + parameterExpressions.put(ident, node); + } + /** * Set last token * @param token New last token diff --git a/nashorn/test/script/basic/JDK-8075207.js b/nashorn/test/script/basic/JDK-8075207.js index d44fc5512b9..168345d9ded 100644 --- a/nashorn/test/script/basic/JDK-8075207.js +++ b/nashorn/test/script/basic/JDK-8075207.js @@ -61,7 +61,7 @@ Assert.assertTrue(stats.get(1) instanceof FunctionDeclarationTree); Assert.assertTrue(stats.get(2) instanceof VariableTree); var print_hello = stats.get(1); -Assert.assertEquals(print_hello.name, "print_hello"); +Assert.assertEquals(print_hello.name.name, "print_hello"); var print_hello_stats = print_hello.body.statements; Assert.assertTrue(print_hello_stats.get(0) instanceof VariableTree); Assert.assertTrue(print_hello_stats.get(1) instanceof ExpressionStatementTree); diff --git a/nashorn/test/script/basic/JDK-8075448.js b/nashorn/test/script/basic/JDK-8075448.js index 3f5e1fd0fa9..ec6cb6f11ba 100644 --- a/nashorn/test/script/basic/JDK-8075448.js +++ b/nashorn/test/script/basic/JDK-8075448.js @@ -44,6 +44,6 @@ var ast = parser.parse("test.js", code, print); var stats = ast.sourceElements; Assert.assertTrue(stats[0] instanceof VariableTree); -Assert.assertEquals(stats[0].name, "i"); +Assert.assertEquals(stats[0].binding.name, "i"); Assert.assertTrue(stats[1] instanceof ForLoopTree); diff --git a/nashorn/test/script/basic/es6/let-const-switch.js.EXPECTED b/nashorn/test/script/basic/es6/let-const-switch.js.EXPECTED index 90309bfe1af..c534d448fbd 100644 --- a/nashorn/test/script/basic/es6/let-const-switch.js.EXPECTED +++ b/nashorn/test/script/basic/es6/let-const-switch.js.EXPECTED @@ -1,12 +1,12 @@ -1 -2 -0 -1 -2 -0 -SyntaxError: test/script/basic/es6/let-const-switch.js#34:8:1:25 Unsupported let declaration in unprotected switch statement -switch (x) { case 0: let x = 1; } - ^ -SyntaxError: test/script/basic/es6/let-const-switch.js#34:8:1:27 Unsupported const declaration in unprotected switch statement -switch (x) { case 0: const x = 1; } - ^ +1 +2 +0 +1 +2 +0 +SyntaxError: test/script/basic/es6/let-const-switch.js#34:8:1:21 Unsupported let declaration in unprotected switch statement +switch (x) { case 0: let x = 1; } + ^ +SyntaxError: test/script/basic/es6/let-const-switch.js#34:8:1:21 Unsupported const declaration in unprotected switch statement +switch (x) { case 0: const x = 1; } + ^ diff --git a/nashorn/test/script/nosecurity/parserapi.js b/nashorn/test/script/nosecurity/parserapi.js index 3c1086f4ef3..d2868fa9a6e 100644 --- a/nashorn/test/script/nosecurity/parserapi.js +++ b/nashorn/test/script/nosecurity/parserapi.js @@ -62,6 +62,26 @@ Parser.prototype.convert = function(tree) { var result = {}; for (var i in obj) { var val = obj[i]; + // skip these ES6 specific properties to reduce noise + // in the output - unless there were set to true + if (typeof(val) == 'boolean' && val == false) { + switch (i) { + case "computed": + case "static": + case "restParameter": + case "this": + case "super": + case "star": + case "default": + case "starDefaultStar": + case "arrow": + case "generator": + case "let": + case "const": + continue; + } + } + if (val instanceof Parser.Tree) { result[i] = this.convert(val); } else if (val instanceof Parser.List) { diff --git a/nashorn/test/script/nosecurity/parserapi.js.EXPECTED b/nashorn/test/script/nosecurity/parserapi.js.EXPECTED index 82f4506ed69..6378c3004ee 100644 --- a/nashorn/test/script/nosecurity/parserapi.js.EXPECTED +++ b/nashorn/test/script/nosecurity/parserapi.js.EXPECTED @@ -1,4 +1,4 @@ -[ +[ { "endPosition": "1113", "kind": "COMPILATION_UNIT", @@ -6,8 +6,13 @@ { "endPosition": "1123", "kind": "VARIABLE", - "name": "x", - "startPosition": "1117", + "binding": { + "endPosition": "1118", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "1117" + }, + "startPosition": "1113", "initializer": { "endPosition": "1123", "kind": "ARRAY_LITERAL", @@ -18,8 +23,13 @@ { "endPosition": "1147", "kind": "VARIABLE", - "name": "y", - "startPosition": "1129", + "binding": { + "endPosition": "1130", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "1129" + }, + "startPosition": "1125", "initializer": { "endPosition": "1147", "kind": "ARRAY_LITERAL", @@ -55,8 +65,13 @@ { "endPosition": "1165", "kind": "VARIABLE", - "name": "z", - "startPosition": "1153", + "binding": { + "endPosition": "1154", + "kind": "IDENTIFIER", + "name": "z", + "startPosition": "1153" + }, + "startPosition": "1149", "initializer": { "endPosition": "1165", "kind": "ARRAY_LITERAL", @@ -82,8 +97,13 @@ { "endPosition": "1200", "kind": "VARIABLE", - "name": "k", - "startPosition": "1171", + "binding": { + "endPosition": "1172", + "kind": "IDENTIFIER", + "name": "k", + "startPosition": "1171" + }, + "startPosition": "1167", "initializer": { "endPosition": "1200", "kind": "ARRAY_LITERAL", @@ -132,8 +152,8 @@ "sourceName": "parsertests/array_literal.js", "strict": "false", "startPosition": "1113" -} -, +} +, { "endPosition": "1126", "kind": "COMPILATION_UNIT", @@ -406,8 +426,8 @@ "sourceName": "parsertests/assignmentExpr.js", "strict": "false", "startPosition": "1126" -} -, +} +, { "endPosition": "1116", "kind": "COMPILATION_UNIT", @@ -912,8 +932,8 @@ "sourceName": "parsertests/binaryExpr.js", "strict": "false", "startPosition": "1116" -} -, +} +, { "endPosition": "1117", "kind": "COMPILATION_UNIT", @@ -959,8 +979,8 @@ "sourceName": "parsertests/block.js", "strict": "false", "startPosition": "1117" -} -, +} +, { "endPosition": "1117", "kind": "COMPILATION_UNIT", @@ -1060,8 +1080,8 @@ "sourceName": "parsertests/breakStat.js", "strict": "false", "startPosition": "1117" -} -, +} +, { "endPosition": "1117", "kind": "COMPILATION_UNIT", @@ -1098,8 +1118,8 @@ "sourceName": "parsertests/condExpr.js", "strict": "false", "startPosition": "1117" -} -, +} +, { "endPosition": "1120", "kind": "COMPILATION_UNIT", @@ -1199,8 +1219,8 @@ "sourceName": "parsertests/continueStat.js", "strict": "false", "startPosition": "1120" -} -, +} +, { "endPosition": "1118", "kind": "COMPILATION_UNIT", @@ -1214,8 +1234,8 @@ "sourceName": "parsertests/debuggerStat.js", "strict": "false", "startPosition": "1118" -} -, +} +, { "endPosition": "1137", "kind": "COMPILATION_UNIT", @@ -1223,7 +1243,12 @@ { "endPosition": "1172", "kind": "FUNCTION", - "name": "hello", + "name": { + "endPosition": "1151", + "kind": "IDENTIFIER", + "name": "hello", + "startPosition": "1146" + }, "body": { "endPosition": "1170", "kind": "BLOCK", @@ -1262,7 +1287,12 @@ { "endPosition": "1203", "kind": "FUNCTION", - "name": "hello", + "name": { + "endPosition": "1187", + "kind": "IDENTIFIER", + "name": "hello", + "startPosition": "1182" + }, "body": { "endPosition": "1201", "kind": "BLOCK", @@ -1308,7 +1338,12 @@ { "endPosition": "1240", "kind": "FUNCTION", - "name": "hello", + "name": { + "endPosition": "1218", + "kind": "IDENTIFIER", + "name": "hello", + "startPosition": "1213" + }, "body": { "endPosition": "1238", "kind": "BLOCK", @@ -1366,8 +1401,13 @@ { "endPosition": "1282", "kind": "VARIABLE", - "name": "hello", - "startPosition": "1245", + "binding": { + "endPosition": "1250", + "kind": "IDENTIFIER", + "name": "hello", + "startPosition": "1245" + }, + "startPosition": "1241", "initializer": { "endPosition": "1264", "kind": "FUNCTION_EXPRESSION", @@ -1410,12 +1450,22 @@ { "endPosition": "1331", "kind": "VARIABLE", - "name": "hello", - "startPosition": "1288", + "binding": { + "endPosition": "1293", + "kind": "IDENTIFIER", + "name": "hello", + "startPosition": "1288" + }, + "startPosition": "1284", "initializer": { "endPosition": "1313", "kind": "FUNCTION_EXPRESSION", - "name": "hello", + "name": { + "endPosition": "1310", + "kind": "IDENTIFIER", + "name": "hello", + "startPosition": "1305" + }, "body": { "endPosition": "1329", "kind": "BLOCK", @@ -1473,7 +1523,12 @@ { "endPosition": "1380", "kind": "FUNCTION", - "name": "test", + "name": { + "endPosition": "1361", + "kind": "IDENTIFIER", + "name": "test", + "startPosition": "1357" + }, "body": { "endPosition": "1377", "kind": "BLOCK", @@ -1500,8 +1555,8 @@ "sourceName": "parsertests/functions.js", "strict": "false", "startPosition": "1137" -} -, +} +, { "endPosition": "1114", "kind": "COMPILATION_UNIT", @@ -1604,8 +1659,8 @@ "sourceName": "parsertests/ifStat.js", "strict": "false", "startPosition": "1114" -} -, +} +, { "endPosition": "1113", "kind": "COMPILATION_UNIT", @@ -1668,8 +1723,8 @@ "sourceName": "parsertests/labelledStat.js", "strict": "false", "startPosition": "1113" -} -, +} +, { "endPosition": "1125", "kind": "COMPILATION_UNIT", @@ -2066,8 +2121,8 @@ "sourceName": "parsertests/lhsExpr.js", "strict": "false", "startPosition": "1125" -} -, +} +, { "endPosition": "1110", "kind": "COMPILATION_UNIT", @@ -2350,8 +2405,8 @@ "sourceName": "parsertests/loopStat.js", "strict": "false", "startPosition": "1110" -} -, +} +, { "endPosition": "1125", "kind": "COMPILATION_UNIT", @@ -2608,6 +2663,7 @@ "expression": { "endPosition": "1272", "kind": "IDENTIFIER", + "this": "true", "name": "this", "startPosition": "1268" }, @@ -2650,6 +2706,7 @@ "expression": { "endPosition": "1300", "kind": "IDENTIFIER", + "this": "true", "name": "this", "startPosition": "1296" }, @@ -2705,8 +2762,8 @@ "sourceName": "parsertests/objectLitExpr.js", "strict": "false", "startPosition": "1125" -} -, +} +, { "endPosition": "1118", "kind": "COMPILATION_UNIT", @@ -2781,8 +2838,8 @@ "sourceName": "parsertests/parenExpr.js", "strict": "false", "startPosition": "1118" -} -, +} +, { "endPosition": "1119", "kind": "COMPILATION_UNIT", @@ -2791,6 +2848,7 @@ "expression": { "endPosition": "1123", "kind": "IDENTIFIER", + "this": "true", "name": "this", "startPosition": "1119" }, @@ -2995,8 +3053,8 @@ "sourceName": "parsertests/primaryExpr.js", "strict": "false", "startPosition": "1119" -} -, +} +, { "endPosition": "1114", "kind": "COMPILATION_UNIT", @@ -3004,8 +3062,13 @@ { "endPosition": "1127", "kind": "VARIABLE", - "name": "x", - "startPosition": "1118", + "binding": { + "endPosition": "1119", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "1118" + }, + "startPosition": "1114", "initializer": { "endPosition": "1127", "kind": "REGEXP_LITERAL", @@ -3017,8 +3080,13 @@ { "endPosition": "1143", "kind": "VARIABLE", - "name": "y", - "startPosition": "1133", + "binding": { + "endPosition": "1134", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "1133" + }, + "startPosition": "1129", "initializer": { "endPosition": "1143", "kind": "REGEXP_LITERAL", @@ -3030,8 +3098,13 @@ { "endPosition": "1168", "kind": "VARIABLE", - "name": "z", - "startPosition": "1149", + "binding": { + "endPosition": "1150", + "kind": "IDENTIFIER", + "name": "z", + "startPosition": "1149" + }, + "startPosition": "1145", "initializer": { "endPosition": "1168", "kind": "REGEXP_LITERAL", @@ -3044,8 +3117,8 @@ "sourceName": "parsertests/regexp_literal.js", "strict": "false", "startPosition": "1114" -} -, +} +, { "endPosition": "1118", "kind": "COMPILATION_UNIT", @@ -3144,8 +3217,8 @@ "sourceName": "parsertests/returnStat.js", "strict": "false", "startPosition": "1118" -} -, +} +, { "endPosition": "1111", "kind": "COMPILATION_UNIT", @@ -3309,8 +3382,8 @@ "sourceName": "parsertests/switchStat.js", "strict": "false", "startPosition": "1111" -} -, +} +, { "endPosition": "1110", "kind": "COMPILATION_UNIT", @@ -3421,8 +3494,8 @@ "sourceName": "parsertests/throwStat.js", "strict": "false", "startPosition": "1110" -} -, +} +, { "endPosition": "1121", "kind": "COMPILATION_UNIT", @@ -3783,8 +3856,8 @@ "sourceName": "parsertests/tryCatchStat.js", "strict": "false", "startPosition": "1121" -} -, +} +, { "endPosition": "1115", "kind": "COMPILATION_UNIT", @@ -3969,8 +4042,8 @@ "sourceName": "parsertests/unaryExpr.js", "strict": "false", "startPosition": "1115" -} -, +} +, { "endPosition": "1122", "kind": "COMPILATION_UNIT", @@ -3989,7 +4062,12 @@ { "endPosition": "1165", "kind": "FUNCTION", - "name": "f", + "name": { + "endPosition": "1146", + "kind": "IDENTIFIER", + "name": "f", + "startPosition": "1145" + }, "body": { "endPosition": "1162", "kind": "BLOCK", @@ -4016,8 +4094,8 @@ "sourceName": "parsertests/useStrict.js", "strict": "true", "startPosition": "1122" -} -, +} +, { "endPosition": "1143", "kind": "COMPILATION_UNIT", @@ -4025,26 +4103,46 @@ { "endPosition": "1148", "kind": "VARIABLE", - "name": "a", - "startPosition": "1147" + "binding": { + "endPosition": "1148", + "kind": "IDENTIFIER", + "name": "a", + "startPosition": "1147" + }, + "startPosition": "1143" }, { "endPosition": "1155", "kind": "VARIABLE", - "name": "a", - "startPosition": "1154" + "binding": { + "endPosition": "1155", + "kind": "IDENTIFIER", + "name": "a", + "startPosition": "1154" + }, + "startPosition": "1150" }, { "endPosition": "1158", "kind": "VARIABLE", - "name": "b", - "startPosition": "1157" + "binding": { + "endPosition": "1158", + "kind": "IDENTIFIER", + "name": "b", + "startPosition": "1157" + }, + "startPosition": "1150" }, { "endPosition": "1200", "kind": "VARIABLE", - "name": "a", - "startPosition": "1190", + "binding": { + "endPosition": "1191", + "kind": "IDENTIFIER", + "name": "a", + "startPosition": "1190" + }, + "startPosition": "1186", "initializer": { "endPosition": "1200", "kind": "STRING_LITERAL", @@ -4055,8 +4153,13 @@ { "endPosition": "1212", "kind": "VARIABLE", - "name": "a", - "startPosition": "1207", + "binding": { + "endPosition": "1208", + "kind": "IDENTIFIER", + "name": "a", + "startPosition": "1207" + }, + "startPosition": "1203", "initializer": { "endPosition": "1212", "kind": "NUMBER_LITERAL", @@ -4067,8 +4170,13 @@ { "endPosition": "1219", "kind": "VARIABLE", - "name": "b", - "startPosition": "1214", + "binding": { + "endPosition": "1215", + "kind": "IDENTIFIER", + "name": "b", + "startPosition": "1214" + }, + "startPosition": "1203", "initializer": { "endPosition": "1219", "kind": "NUMBER_LITERAL", @@ -4079,8 +4187,13 @@ { "endPosition": "1226", "kind": "VARIABLE", - "name": "c", - "startPosition": "1221", + "binding": { + "endPosition": "1222", + "kind": "IDENTIFIER", + "name": "c", + "startPosition": "1221" + }, + "startPosition": "1203", "initializer": { "endPosition": "1226", "kind": "NUMBER_LITERAL", @@ -4092,8 +4205,8 @@ "sourceName": "parsertests/varDecl.js", "strict": "false", "startPosition": "1143" -} -, +} +, { "endPosition": "1111", "kind": "COMPILATION_UNIT", @@ -4142,8 +4255,8 @@ "sourceName": "parsertests/withStat.js", "strict": "false", "startPosition": "1111" -} -, +} +, { "fileName": "parsernegativetests/caseoutofswitch.js", "code": "case (1090, 4)", @@ -4152,8 +4265,8 @@ "position": "1090", "message": "parsernegativetests/caseoutofswitch.js:29:0 Expected an operand but found case\ncase 23:\n^", "lineNumber": "29" -} -, +} +, { "fileName": "parsernegativetests/caseoutofswitch.js", "code": "default (1112, 7)", @@ -4162,8 +4275,8 @@ "position": "1112", "message": "parsernegativetests/caseoutofswitch.js:31:0 Expected an operand but found default\ndefault:\n^", "lineNumber": "31" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4240,8 +4353,8 @@ "sourceName": "parsernegativetests/caseoutofswitch.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/illegalbreak.js", "code": "break (1090, 5)", @@ -4250,8 +4363,8 @@ "position": "1090", "message": "parsernegativetests/illegalbreak.js:29:0 Illegal break statement\nbreak;\n^", "lineNumber": "29" -} -, +} +, { "fileName": "parsernegativetests/illegalbreak.js", "code": "ident (1103, 3)", @@ -4260,8 +4373,8 @@ "position": "1103", "message": "parsernegativetests/illegalbreak.js:30:6 Undefined Label \"foo\"\nbreak foo;\n ^", "lineNumber": "30" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4290,8 +4403,8 @@ "sourceName": "parsernegativetests/illegalbreak.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/illegalcontinue.js", "code": "continue (1090, 8)", @@ -4300,8 +4413,8 @@ "position": "1090", "message": "parsernegativetests/illegalcontinue.js:29:0 Illegal continue statement\ncontinue;\n^", "lineNumber": "29" -} -, +} +, { "fileName": "parsernegativetests/illegalcontinue.js", "code": "ident (1109, 3)", @@ -4310,8 +4423,8 @@ "position": "1109", "message": "parsernegativetests/illegalcontinue.js:30:9 Undefined Label \"foo\"\ncontinue foo;\n ^", "lineNumber": "30" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4340,8 +4453,8 @@ "sourceName": "parsernegativetests/illegalcontinue.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/illegallvalue.js", "code": "decimal (1090, 2)", @@ -4350,8 +4463,8 @@ "position": "1090", "message": "parsernegativetests/illegallvalue.js:29:0 Invalid left hand side for assignment\n44 = 54;\n^", "lineNumber": "29" -} -, +} +, { "fileName": "parsernegativetests/illegallvalue.js", "code": "decimal (1099, 3)", @@ -4360,8 +4473,8 @@ "position": "1099", "message": "parsernegativetests/illegallvalue.js:30:0 Invalid left hand side for assignment\n233 += 33;\n^", "lineNumber": "30" -} -, +} +, { "fileName": "parsernegativetests/illegallvalue.js", "code": "decimal (1110, 4)", @@ -4370,8 +4483,8 @@ "position": "1110", "message": "parsernegativetests/illegallvalue.js:31:0 Invalid left hand side for assignment\n3423 -= 234;\n^", "lineNumber": "31" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4410,8 +4523,8 @@ "sourceName": "parsernegativetests/illegallvalue.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/illegaloperator.js", "code": "* (1093, 1)", @@ -4420,8 +4533,8 @@ "position": "1093", "message": "parsernegativetests/illegaloperator.js:29:3 Expected an operand but found *\nx ** y\n ^", "lineNumber": "29" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4440,8 +4553,8 @@ "sourceName": "parsernegativetests/illegaloperator.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/keywordident.js", "code": "var (1094, 3)", @@ -4450,8 +4563,8 @@ "position": "1094", "message": "parsernegativetests/keywordident.js:29:4 Expected ident but found var\nvar var = 23;\n ^", "lineNumber": "29" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4469,8 +4582,13 @@ { "endPosition": "1115", "kind": "VARIABLE", - "name": "x", - "startPosition": "1108", + "binding": { + "endPosition": "1109", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "1108" + }, + "startPosition": "1104", "initializer": { "endPosition": "1115", "kind": "NUMBER_LITERAL", @@ -4482,8 +4600,8 @@ "sourceName": "parsernegativetests/keywordident.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/parenmissing.js", "code": "; (1096, 1)", @@ -4492,8 +4610,8 @@ "position": "1096", "message": "parsernegativetests/parenmissing.js:29:6 Expected ) but found ;\n(1 + 2;\n ^", "lineNumber": "29" -} -, +} +, { "fileName": "parsernegativetests/parenmissing.js", "code": ") (1103, 1)", @@ -4502,8 +4620,8 @@ "position": "1103", "message": "parsernegativetests/parenmissing.js:30:5 Expected ; but found )\nx * y);\n ^", "lineNumber": "30" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4554,8 +4672,8 @@ "sourceName": "parsernegativetests/parenmissing.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/repeatedproperty.js", "code": "ident (1111, 3)", @@ -4564,8 +4682,8 @@ "position": "1111", "message": "parsernegativetests/repeatedproperty.js:29:21 Property \"foo\" already defined\nvar obj = { foo: 34, get foo() { return 'hello' } };\n ^", "lineNumber": "29" -} -, +} +, { "fileName": "parsernegativetests/repeatedproperty.js", "code": "ident (1165, 3)", @@ -4574,8 +4692,8 @@ "position": "1165", "message": "parsernegativetests/repeatedproperty.js:30:22 Property \"foo\" already defined\nvar obj1 = { foo: 34, set foo(x) { } };\n ^", "lineNumber": "30" -} -, +} +, { "fileName": "parsernegativetests/repeatedproperty.js", "code": "ident (1205, 3)", @@ -4584,8 +4702,8 @@ "position": "1205", "message": "parsernegativetests/repeatedproperty.js:31:22 Property \"foo\" already defined\nvar obj2 = { foo: 34, set foo(x) { } };\n ^", "lineNumber": "31" -} -, +} +, { "fileName": "parsernegativetests/repeatedproperty.js", "code": "ident (1251, 3)", @@ -4594,8 +4712,8 @@ "position": "1251", "message": "parsernegativetests/repeatedproperty.js:32:28 Property \"bar\" already defined\nvar obj3 = { get bar() { }, get bar() {} };\n ^", "lineNumber": "32" -} -, +} +, { "fileName": "parsernegativetests/repeatedproperty.js", "code": "ident (1296, 3)", @@ -4604,8 +4722,8 @@ "position": "1296", "message": "parsernegativetests/repeatedproperty.js:33:29 Property \"bar\" already defined\nvar obj4 = { set bar(x) { }, set bar(x) {} };\n ^", "lineNumber": "33" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4664,8 +4782,8 @@ "sourceName": "parsernegativetests/repeatedproperty.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/strict_repeatedproperty.js", "code": "ident (1126, 3)", @@ -4674,8 +4792,8 @@ "position": "1126", "message": "parsernegativetests/strict_repeatedproperty.js:31:21 Property \"foo\" already defined\nvar obj = { foo: 34, foo: 'hello' };\n ^", "lineNumber": "31" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4705,8 +4823,8 @@ "sourceName": "parsernegativetests/strict_repeatedproperty.js", "strict": "true", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/strict_repeatparam.js", "code": "ident (1122, 1)", @@ -4715,8 +4833,8 @@ "position": "1122", "message": "parsernegativetests/strict_repeatparam.js:31:17 strict mode function cannot have duplicate parameter name \"x\"\nfunction func(x, x) {}\n ^", "lineNumber": "31" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4746,8 +4864,8 @@ "sourceName": "parsernegativetests/strict_repeatparam.js", "strict": "true", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/strict_with.js", "code": "with (1105, 4)", @@ -4756,8 +4874,8 @@ "position": "1105", "message": "parsernegativetests/strict_with.js:31:0 \"with\" statement cannot be used in strict mode\nwith({}) {}\n^", "lineNumber": "31" -} -, +} +, { "fileName": "parsernegativetests/strict_with.js", "code": ") (1112, 1)", @@ -4766,8 +4884,8 @@ "position": "1112", "message": "parsernegativetests/strict_with.js:31:7 Expected ; but found )\nwith({}) {}\n ^", "lineNumber": "31" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4807,8 +4925,8 @@ "sourceName": "parsernegativetests/strict_with.js", "strict": "true", "startPosition": "1090" -} -, +} +, { "fileName": "parsernegativetests/toplevelreturn.js", "code": "return (1090, 6)", @@ -4817,8 +4935,8 @@ "position": "1090", "message": "parsernegativetests/toplevelreturn.js:29:0 Invalid return statement\nreturn;\n^", "lineNumber": "29" -} -, +} +, { "fileName": "parsernegativetests/toplevelreturn.js", "code": "return (1098, 6)", @@ -4827,8 +4945,8 @@ "position": "1098", "message": "parsernegativetests/toplevelreturn.js:30:0 Invalid return statement\nreturn 23;\n^", "lineNumber": "30" -} -, +} +, { "endPosition": "1090", "kind": "COMPILATION_UNIT", @@ -4857,8 +4975,8 @@ "sourceName": "parsernegativetests/toplevelreturn.js", "strict": "false", "startPosition": "1090" -} -, +} +, { "endPosition": "1136", "kind": "COMPILATION_UNIT", @@ -4866,7 +4984,12 @@ { "endPosition": "1222", "kind": "FUNCTION", - "name": "Parser", + "name": { + "endPosition": "1151", + "kind": "IDENTIFIER", + "name": "Parser", + "startPosition": "1145" + }, "body": { "endPosition": "1220", "kind": "BLOCK", @@ -4898,6 +5021,7 @@ "expression": { "endPosition": "1193", "kind": "IDENTIFIER", + "this": "true", "name": "this", "startPosition": "1189" }, @@ -5165,8 +5289,13 @@ { "endPosition": "1718", "kind": "VARIABLE", - "name": "tree", - "startPosition": "1669", + "binding": { + "endPosition": "1673", + "kind": "IDENTIFIER", + "name": "tree", + "startPosition": "1669" + }, + "startPosition": "1665", "initializer": { "endPosition": "1718", "kind": "FUNCTION_INVOCATION", @@ -5177,6 +5306,7 @@ "expression": { "endPosition": "1680", "kind": "IDENTIFIER", + "this": "true", "name": "this", "startPosition": "1676" }, @@ -5272,6 +5402,7 @@ "expression": { "endPosition": "1790", "kind": "IDENTIFIER", + "this": "true", "name": "this", "startPosition": "1786" }, @@ -5429,7 +5560,7 @@ "endPosition": "2016", "kind": "FUNCTION_EXPRESSION", "body": { - "endPosition": "2994", + "endPosition": "3634", "kind": "BLOCK", "statements": [ { @@ -5554,8 +5685,13 @@ { "endPosition": "2169", "kind": "VARIABLE", - "name": "obj", - "startPosition": "2132", + "binding": { + "endPosition": "2135", + "kind": "IDENTIFIER", + "name": "obj", + "startPosition": "2132" + }, + "startPosition": "2128", "initializer": { "endPosition": "2169", "kind": "FUNCTION_INVOCATION", @@ -5591,8 +5727,13 @@ { "endPosition": "2190", "kind": "VARIABLE", - "name": "result", - "startPosition": "2179", + "binding": { + "endPosition": "2185", + "kind": "IDENTIFIER", + "name": "result", + "startPosition": "2179" + }, + "startPosition": "2175", "initializer": { "endPosition": "2190", "kind": "OBJECT_LITERAL", @@ -5603,8 +5744,13 @@ { "endPosition": "2206", "kind": "VARIABLE", - "name": "i", - "startPosition": "2205" + "binding": { + "endPosition": "2206", + "kind": "IDENTIFIER", + "name": "i", + "startPosition": "2205" + }, + "startPosition": "2201" }, { "expression": { @@ -5613,7 +5759,7 @@ "name": "obj", "startPosition": "2210" }, - "endPosition": "2975", + "endPosition": "3615", "kind": "FOR_IN_LOOP", "forEach": "false", "variable": { @@ -5623,14 +5769,19 @@ "startPosition": "2205" }, "statement": { - "endPosition": "2975", + "endPosition": "3615", "kind": "BLOCK", "statements": [ { "endPosition": "2241", "kind": "VARIABLE", - "name": "val", - "startPosition": "2229", + "binding": { + "endPosition": "2232", + "kind": "IDENTIFIER", + "name": "val", + "startPosition": "2229" + }, + "startPosition": "2225", "initializer": { "expression": { "endPosition": "2238", @@ -5652,605 +5803,836 @@ { "condition": { "leftOperand": { - "endPosition": "2258", + "leftOperand": { + "expression": { + "endPosition": "2384", + "kind": "IDENTIFIER", + "name": "val", + "startPosition": "2381" + }, + "endPosition": "2384", + "kind": "TYPEOF", + "startPosition": "2374" + }, + "endPosition": "2397", + "kind": "EQUAL_TO", + "rightOperand": { + "endPosition": "2397", + "kind": "STRING_LITERAL", + "value": "boolean", + "startPosition": "2390" + }, + "startPosition": "2374" + }, + "endPosition": "2414", + "kind": "CONDITIONAL_AND", + "rightOperand": { + "leftOperand": { + "endPosition": "2405", + "kind": "IDENTIFIER", + "name": "val", + "startPosition": "2402" + }, + "endPosition": "2414", + "kind": "EQUAL_TO", + "rightOperand": { + "endPosition": "2414", + "kind": "BOOLEAN_LITERAL", + "value": "false", + "startPosition": "2409" + }, + "startPosition": "2402" + }, + "startPosition": "2374" + }, + "endPosition": "2881", + "kind": "IF", + "startPosition": "2370", + "thenStatement": { + "endPosition": "2881", + "kind": "BLOCK", + "statements": [ + { + "cases": [ + { + "expression": { + "endPosition": "2473", + "kind": "STRING_LITERAL", + "value": "computed", + "startPosition": "2465" + }, + "endPosition": "2475", + "kind": "CASE", + "statements": [], + "startPosition": "2459" + }, + { + "expression": { + "endPosition": "2504", + "kind": "STRING_LITERAL", + "value": "static", + "startPosition": "2498" + }, + "endPosition": "2506", + "kind": "CASE", + "statements": [], + "startPosition": "2492" + }, + { + "expression": { + "endPosition": "2542", + "kind": "STRING_LITERAL", + "value": "restParameter", + "startPosition": "2529" + }, + "endPosition": "2544", + "kind": "CASE", + "statements": [], + "startPosition": "2523" + }, + { + "expression": { + "endPosition": "2571", + "kind": "STRING_LITERAL", + "value": "this", + "startPosition": "2567" + }, + "endPosition": "2573", + "kind": "CASE", + "statements": [], + "startPosition": "2561" + }, + { + "expression": { + "endPosition": "2601", + "kind": "STRING_LITERAL", + "value": "super", + "startPosition": "2596" + }, + "endPosition": "2603", + "kind": "CASE", + "statements": [], + "startPosition": "2590" + }, + { + "expression": { + "endPosition": "2630", + "kind": "STRING_LITERAL", + "value": "star", + "startPosition": "2626" + }, + "endPosition": "2632", + "kind": "CASE", + "statements": [], + "startPosition": "2620" + }, + { + "expression": { + "endPosition": "2662", + "kind": "STRING_LITERAL", + "value": "default", + "startPosition": "2655" + }, + "endPosition": "2664", + "kind": "CASE", + "statements": [], + "startPosition": "2649" + }, + { + "expression": { + "endPosition": "2702", + "kind": "STRING_LITERAL", + "value": "starDefaultStar", + "startPosition": "2687" + }, + "endPosition": "2704", + "kind": "CASE", + "statements": [], + "startPosition": "2681" + }, + { + "expression": { + "endPosition": "2732", + "kind": "STRING_LITERAL", + "value": "arrow", + "startPosition": "2727" + }, + "endPosition": "2734", + "kind": "CASE", + "statements": [], + "startPosition": "2721" + }, + { + "expression": { + "endPosition": "2766", + "kind": "STRING_LITERAL", + "value": "generator", + "startPosition": "2757" + }, + "endPosition": "2768", + "kind": "CASE", + "statements": [], + "startPosition": "2751" + }, + { + "expression": { + "endPosition": "2794", + "kind": "STRING_LITERAL", + "value": "let", + "startPosition": "2791" + }, + "endPosition": "2796", + "kind": "CASE", + "statements": [], + "startPosition": "2785" + }, + { + "expression": { + "endPosition": "2824", + "kind": "STRING_LITERAL", + "value": "const", + "startPosition": "2819" + }, + "endPosition": "2856", + "kind": "CASE", + "statements": [ + { + "endPosition": "2856", + "kind": "CONTINUE", + "startPosition": "2847" + } + ], + "startPosition": "2813" + } + ], + "expression": { + "endPosition": "2439", + "kind": "IDENTIFIER", + "name": "i", + "startPosition": "2438" + }, + "endPosition": "2871", + "kind": "SWITCH", + "startPosition": "2430" + } + ], + "startPosition": "2416" + } + }, + { + "condition": { + "leftOperand": { + "endPosition": "2898", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2255" + "startPosition": "2895" }, "expression": { - "endPosition": "2258", + "endPosition": "2898", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2255" + "startPosition": "2895" }, - "endPosition": "2281", + "endPosition": "2921", "kind": "INSTANCE_OF", "rightOperand": { "identifier": "Tree", "expression": { - "endPosition": "2276", + "endPosition": "2916", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "2270" + "startPosition": "2910" }, - "endPosition": "2281", + "endPosition": "2921", "kind": "MEMBER_SELECT", - "startPosition": "2270" + "startPosition": "2910" }, "type": { "identifier": "Tree", "expression": { - "endPosition": "2276", + "endPosition": "2916", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "2270" + "startPosition": "2910" }, - "endPosition": "2281", + "endPosition": "2921", "kind": "MEMBER_SELECT", - "startPosition": "2270" + "startPosition": "2910" }, - "startPosition": "2255" + "startPosition": "2895" }, "elseStatement": { "condition": { "leftOperand": { - "endPosition": "2350", + "endPosition": "2990", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2347" + "startPosition": "2987" }, "expression": { - "endPosition": "2350", + "endPosition": "2990", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2347" + "startPosition": "2987" }, - "endPosition": "2373", + "endPosition": "3013", "kind": "INSTANCE_OF", "rightOperand": { "identifier": "List", "expression": { - "endPosition": "2368", + "endPosition": "3008", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "2362" + "startPosition": "3002" }, - "endPosition": "2373", + "endPosition": "3013", "kind": "MEMBER_SELECT", - "startPosition": "2362" + "startPosition": "3002" }, "type": { "identifier": "List", "expression": { - "endPosition": "2368", + "endPosition": "3008", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "2362" + "startPosition": "3002" }, - "endPosition": "2373", + "endPosition": "3013", "kind": "MEMBER_SELECT", - "startPosition": "2362" + "startPosition": "3002" }, - "startPosition": "2347" + "startPosition": "2987" }, "elseStatement": { - "endPosition": "2969", + "endPosition": "3609", "kind": "BLOCK", "statements": [ { "cases": [ { "expression": { - "endPosition": "2625", + "endPosition": "3265", "kind": "STRING_LITERAL", "value": "number", - "startPosition": "2619" + "startPosition": "3259" }, - "endPosition": "2627", + "endPosition": "3267", "kind": "CASE", "statements": [], - "startPosition": "2613" + "startPosition": "3253" }, { "expression": { - "endPosition": "2656", + "endPosition": "3296", "kind": "STRING_LITERAL", "value": "string", - "startPosition": "2650" + "startPosition": "3290" }, - "endPosition": "2658", + "endPosition": "3298", "kind": "CASE", "statements": [], - "startPosition": "2644" + "startPosition": "3284" }, { "expression": { - "endPosition": "2688", + "endPosition": "3328", "kind": "STRING_LITERAL", "value": "boolean", - "startPosition": "2681" + "startPosition": "3321" }, - "endPosition": "2762", + "endPosition": "3402", "kind": "CASE", "statements": [ { "expression": { "expression": { - "endPosition": "2734", + "endPosition": "3374", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "2729", + "endPosition": "3369", "kind": "IDENTIFIER", "name": "String", - "startPosition": "2723" + "startPosition": "3363" }, "arguments": [ { - "endPosition": "2733", + "endPosition": "3373", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2730" + "startPosition": "3370" } ], - "startPosition": "2723" + "startPosition": "3363" }, - "endPosition": "2734", + "endPosition": "3374", "kind": "ASSIGNMENT", "variable": { "expression": { - "endPosition": "2717", + "endPosition": "3357", "kind": "IDENTIFIER", "name": "result", - "startPosition": "2711" + "startPosition": "3351" }, - "endPosition": "2720", + "endPosition": "3360", "kind": "ARRAY_ACCESS", "index": { - "endPosition": "2719", + "endPosition": "3359", "kind": "IDENTIFIER", "name": "i", - "startPosition": "2718" + "startPosition": "3358" }, - "startPosition": "2711" + "startPosition": "3351" }, - "startPosition": "2711" + "startPosition": "3351" }, - "endPosition": "2734", + "endPosition": "3374", "kind": "EXPRESSION_STATEMENT", - "startPosition": "2711" + "startPosition": "3351" }, { - "endPosition": "2762", + "endPosition": "3402", "kind": "BREAK", - "startPosition": "2756" + "startPosition": "3396" } ], - "startPosition": "2675" + "startPosition": "3315" }, { - "endPosition": "2945", + "endPosition": "3585", "kind": "CASE", "statements": [ { "condition": { "leftOperand": { "leftOperand": { - "endPosition": "2815", + "endPosition": "3455", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2812" + "startPosition": "3452" }, "expression": { - "endPosition": "2815", + "endPosition": "3455", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2812" + "startPosition": "3452" }, - "endPosition": "2841", + "endPosition": "3481", "kind": "INSTANCE_OF", "rightOperand": { "identifier": "Long", "expression": { "identifier": "lang", "expression": { - "endPosition": "2831", + "endPosition": "3471", "kind": "IDENTIFIER", "name": "java", - "startPosition": "2827" + "startPosition": "3467" }, - "endPosition": "2836", + "endPosition": "3476", "kind": "MEMBER_SELECT", - "startPosition": "2827" + "startPosition": "3467" }, - "endPosition": "2841", + "endPosition": "3481", "kind": "MEMBER_SELECT", - "startPosition": "2827" + "startPosition": "3467" }, "type": { "identifier": "Long", "expression": { "identifier": "lang", "expression": { - "endPosition": "2831", + "endPosition": "3471", "kind": "IDENTIFIER", "name": "java", - "startPosition": "2827" + "startPosition": "3467" }, - "endPosition": "2836", + "endPosition": "3476", "kind": "MEMBER_SELECT", - "startPosition": "2827" + "startPosition": "3467" }, - "endPosition": "2841", + "endPosition": "3481", "kind": "MEMBER_SELECT", - "startPosition": "2827" + "startPosition": "3467" }, - "startPosition": "2812" + "startPosition": "3452" }, - "endPosition": "2871", + "endPosition": "3511", "kind": "CONDITIONAL_OR", "rightOperand": { "leftOperand": { - "endPosition": "2848", + "endPosition": "3488", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2845" + "startPosition": "3485" }, "expression": { - "endPosition": "2848", + "endPosition": "3488", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2845" + "startPosition": "3485" }, - "endPosition": "2871", + "endPosition": "3511", "kind": "INSTANCE_OF", "rightOperand": { "identifier": "Enum", "expression": { - "endPosition": "2866", + "endPosition": "3506", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "2860" + "startPosition": "3500" }, - "endPosition": "2871", + "endPosition": "3511", "kind": "MEMBER_SELECT", - "startPosition": "2860" + "startPosition": "3500" }, "type": { "identifier": "Enum", "expression": { - "endPosition": "2866", + "endPosition": "3506", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "2860" + "startPosition": "3500" }, - "endPosition": "2871", + "endPosition": "3511", "kind": "MEMBER_SELECT", - "startPosition": "2860" + "startPosition": "3500" }, - "startPosition": "2845" + "startPosition": "3485" }, - "startPosition": "2812" + "startPosition": "3452" }, - "endPosition": "2945", + "endPosition": "3585", "kind": "IF", - "startPosition": "2808", + "startPosition": "3448", "thenStatement": { - "endPosition": "2945", + "endPosition": "3585", "kind": "BLOCK", "statements": [ { "expression": { "expression": { - "endPosition": "2922", + "endPosition": "3562", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "2917", + "endPosition": "3557", "kind": "IDENTIFIER", "name": "String", - "startPosition": "2911" + "startPosition": "3551" }, "arguments": [ { - "endPosition": "2921", + "endPosition": "3561", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2918" + "startPosition": "3558" } ], - "startPosition": "2911" + "startPosition": "3551" }, - "endPosition": "2922", + "endPosition": "3562", "kind": "ASSIGNMENT", "variable": { "expression": { - "endPosition": "2905", + "endPosition": "3545", "kind": "IDENTIFIER", "name": "result", - "startPosition": "2899" + "startPosition": "3539" }, - "endPosition": "2908", + "endPosition": "3548", "kind": "ARRAY_ACCESS", "index": { - "endPosition": "2907", + "endPosition": "3547", "kind": "IDENTIFIER", "name": "i", - "startPosition": "2906" + "startPosition": "3546" }, - "startPosition": "2899" + "startPosition": "3539" }, - "startPosition": "2899" + "startPosition": "3539" }, - "endPosition": "2922", + "endPosition": "3562", "kind": "EXPRESSION_STATEMENT", - "startPosition": "2899" + "startPosition": "3539" } ], - "startPosition": "2873" + "startPosition": "3513" } } ], - "startPosition": "2779" + "startPosition": "3419" } ], "expression": { "expression": { - "endPosition": "2593", + "endPosition": "3233", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2590" + "startPosition": "3230" }, - "endPosition": "2593", + "endPosition": "3233", "kind": "TYPEOF", - "startPosition": "2583" + "startPosition": "3223" }, - "endPosition": "2959", + "endPosition": "3599", "kind": "SWITCH", - "startPosition": "2575" + "startPosition": "3215" } ], - "startPosition": "2561" + "startPosition": "3201" }, - "endPosition": "2969", + "endPosition": "3609", "kind": "IF", - "startPosition": "2343", + "startPosition": "2983", "thenStatement": { - "endPosition": "2555", + "endPosition": "3195", "kind": "BLOCK", "statements": [ { - "endPosition": "2420", + "endPosition": "3060", "kind": "VARIABLE", - "name": "arr", - "startPosition": "2393", + "binding": { + "endPosition": "3036", + "kind": "IDENTIFIER", + "name": "arr", + "startPosition": "3033" + }, + "startPosition": "3029", "initializer": { "constructorExpression": { - "endPosition": "2420", + "endPosition": "3060", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "2408", + "endPosition": "3048", "kind": "IDENTIFIER", "name": "Array", - "startPosition": "2403" + "startPosition": "3043" }, "arguments": [ { - "endPosition": "2419", + "endPosition": "3059", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "size", "expression": { - "endPosition": "2412", + "endPosition": "3052", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2409" + "startPosition": "3049" }, - "endPosition": "2417", + "endPosition": "3057", "kind": "MEMBER_SELECT", - "startPosition": "2409" + "startPosition": "3049" }, "arguments": [], - "startPosition": "2409" + "startPosition": "3049" } ], - "startPosition": "2403" + "startPosition": "3043" }, - "endPosition": "2420", + "endPosition": "3060", "kind": "NEW", - "startPosition": "2399" + "startPosition": "3039" } }, { - "endPosition": "2444", + "endPosition": "3084", "kind": "VARIABLE", - "name": "j", - "startPosition": "2443" + "binding": { + "endPosition": "3084", + "kind": "IDENTIFIER", + "name": "j", + "startPosition": "3083" + }, + "startPosition": "3079" }, { "expression": { - "endPosition": "2451", + "endPosition": "3091", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2448" + "startPosition": "3088" }, - "endPosition": "2515", + "endPosition": "3155", "kind": "FOR_IN_LOOP", "forEach": "false", "variable": { - "endPosition": "2444", + "endPosition": "3084", "kind": "IDENTIFIER", "name": "j", - "startPosition": "2443" + "startPosition": "3083" }, "statement": { - "endPosition": "2515", + "endPosition": "3155", "kind": "BLOCK", "statements": [ { "expression": { "expression": { - "endPosition": "2500", + "endPosition": "3140", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "convert", "expression": { - "endPosition": "2484", + "endPosition": "3124", "kind": "IDENTIFIER", + "this": "true", "name": "this", - "startPosition": "2480" + "startPosition": "3120" }, - "endPosition": "2492", + "endPosition": "3132", "kind": "MEMBER_SELECT", - "startPosition": "2480" + "startPosition": "3120" }, "arguments": [ { "expression": { - "endPosition": "2496", + "endPosition": "3136", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2493" + "startPosition": "3133" }, - "endPosition": "2499", + "endPosition": "3139", "kind": "ARRAY_ACCESS", "index": { - "endPosition": "2498", + "endPosition": "3138", "kind": "IDENTIFIER", "name": "j", - "startPosition": "2497" + "startPosition": "3137" }, - "startPosition": "2493" + "startPosition": "3133" } ], - "startPosition": "2480" + "startPosition": "3120" }, - "endPosition": "2500", + "endPosition": "3140", "kind": "ASSIGNMENT", "variable": { "expression": { - "endPosition": "2474", + "endPosition": "3114", "kind": "IDENTIFIER", "name": "arr", - "startPosition": "2471" + "startPosition": "3111" }, - "endPosition": "2477", + "endPosition": "3117", "kind": "ARRAY_ACCESS", "index": { - "endPosition": "2476", + "endPosition": "3116", "kind": "IDENTIFIER", "name": "j", - "startPosition": "2475" + "startPosition": "3115" }, - "startPosition": "2471" + "startPosition": "3111" }, - "startPosition": "2471" + "startPosition": "3111" }, - "endPosition": "2500", + "endPosition": "3140", "kind": "EXPRESSION_STATEMENT", - "startPosition": "2471" + "startPosition": "3111" } ], - "startPosition": "2453" + "startPosition": "3093" }, - "startPosition": "2434" + "startPosition": "3074" }, { "expression": { "expression": { - "endPosition": "2544", + "endPosition": "3184", "kind": "IDENTIFIER", "name": "arr", - "startPosition": "2541" + "startPosition": "3181" }, - "endPosition": "2544", + "endPosition": "3184", "kind": "ASSIGNMENT", "variable": { "expression": { - "endPosition": "2535", + "endPosition": "3175", "kind": "IDENTIFIER", "name": "result", - "startPosition": "2529" + "startPosition": "3169" }, - "endPosition": "2538", + "endPosition": "3178", "kind": "ARRAY_ACCESS", "index": { - "endPosition": "2537", + "endPosition": "3177", "kind": "IDENTIFIER", "name": "i", - "startPosition": "2536" + "startPosition": "3176" }, - "startPosition": "2529" + "startPosition": "3169" }, - "startPosition": "2529" + "startPosition": "3169" }, - "endPosition": "2544", + "endPosition": "3184", "kind": "EXPRESSION_STATEMENT", - "startPosition": "2529" + "startPosition": "3169" } ], - "startPosition": "2375" + "startPosition": "3015" } }, - "endPosition": "2969", + "endPosition": "3609", "kind": "IF", - "startPosition": "2251", + "startPosition": "2891", "thenStatement": { - "endPosition": "2337", + "endPosition": "2977", "kind": "BLOCK", "statements": [ { "expression": { "expression": { - "endPosition": "2326", + "endPosition": "2966", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "convert", "expression": { - "endPosition": "2313", + "endPosition": "2953", "kind": "IDENTIFIER", + "this": "true", "name": "this", - "startPosition": "2309" + "startPosition": "2949" }, - "endPosition": "2321", + "endPosition": "2961", "kind": "MEMBER_SELECT", - "startPosition": "2309" + "startPosition": "2949" }, "arguments": [ { - "endPosition": "2325", + "endPosition": "2965", "kind": "IDENTIFIER", "name": "val", - "startPosition": "2322" + "startPosition": "2962" } ], - "startPosition": "2309" + "startPosition": "2949" }, - "endPosition": "2326", + "endPosition": "2966", "kind": "ASSIGNMENT", "variable": { "expression": { - "endPosition": "2303", + "endPosition": "2943", "kind": "IDENTIFIER", "name": "result", - "startPosition": "2297" + "startPosition": "2937" }, - "endPosition": "2306", + "endPosition": "2946", "kind": "ARRAY_ACCESS", "index": { - "endPosition": "2305", + "endPosition": "2945", "kind": "IDENTIFIER", "name": "i", - "startPosition": "2304" + "startPosition": "2944" }, - "startPosition": "2297" + "startPosition": "2937" }, - "startPosition": "2297" + "startPosition": "2937" }, - "endPosition": "2326", + "endPosition": "2966", "kind": "EXPRESSION_STATEMENT", - "startPosition": "2297" + "startPosition": "2937" } ], - "startPosition": "2283" + "startPosition": "2923" } } ], @@ -6260,14 +6642,14 @@ }, { "expression": { - "endPosition": "2993", + "endPosition": "3633", "kind": "IDENTIFIER", "name": "result", - "startPosition": "2987" + "startPosition": "3627" }, - "endPosition": "2994", + "endPosition": "3634", "kind": "RETURN", - "startPosition": "2980" + "startPosition": "3620" } ], "startPosition": "2016" @@ -6305,105 +6687,120 @@ }, "startPosition": "1974" }, - "endPosition": "2996", + "endPosition": "3636", "kind": "EXPRESSION_STATEMENT", "startPosition": "1974" }, { - "endPosition": "3726", + "endPosition": "4366", "kind": "FUNCTION", - "name": "processFiles", + "name": { + "endPosition": "3659", + "kind": "IDENTIFIER", + "name": "processFiles", + "startPosition": "3647" + }, "body": { - "endPosition": "3724", + "endPosition": "4364", "kind": "BLOCK", "statements": [ { - "endPosition": "3070", + "endPosition": "3710", "kind": "VARIABLE", - "name": "File", - "startPosition": "3038", + "binding": { + "endPosition": "3682", + "kind": "IDENTIFIER", + "name": "File", + "startPosition": "3678" + }, + "startPosition": "3674", "initializer": { - "endPosition": "3070", + "endPosition": "3710", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "type", "expression": { - "endPosition": "3049", + "endPosition": "3689", "kind": "IDENTIFIER", "name": "Java", - "startPosition": "3045" + "startPosition": "3685" }, - "endPosition": "3054", + "endPosition": "3694", "kind": "MEMBER_SELECT", - "startPosition": "3045" + "startPosition": "3685" }, "arguments": [ { - "endPosition": "3068", + "endPosition": "3708", "kind": "STRING_LITERAL", "value": "java.io.File", - "startPosition": "3056" + "startPosition": "3696" } ], - "startPosition": "3045" + "startPosition": "3685" } }, { - "endPosition": "3126", + "endPosition": "3766", "kind": "VARIABLE", - "name": "files", - "startPosition": "3080", + "binding": { + "endPosition": "3725", + "kind": "IDENTIFIER", + "name": "files", + "startPosition": "3720" + }, + "startPosition": "3716", "initializer": { - "endPosition": "3126", + "endPosition": "3766", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "listFiles", "expression": { "constructorExpression": { - "endPosition": "3114", + "endPosition": "3754", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3096", + "endPosition": "3736", "kind": "IDENTIFIER", "name": "File", - "startPosition": "3092" + "startPosition": "3732" }, "arguments": [ { "leftOperand": { - "endPosition": "3104", + "endPosition": "3744", "kind": "IDENTIFIER", "name": "__DIR__", - "startPosition": "3097" + "startPosition": "3737" }, - "endPosition": "3113", + "endPosition": "3753", "kind": "PLUS", "rightOperand": { - "endPosition": "3113", + "endPosition": "3753", "kind": "IDENTIFIER", "name": "subdir", - "startPosition": "3107" + "startPosition": "3747" }, - "startPosition": "3097" + "startPosition": "3737" } ], - "startPosition": "3092" + "startPosition": "3732" }, - "endPosition": "3114", + "endPosition": "3754", "kind": "NEW", - "startPosition": "3088" + "startPosition": "3728" }, - "endPosition": "3124", + "endPosition": "3764", "kind": "MEMBER_SELECT", - "startPosition": "3088" + "startPosition": "3728" }, "arguments": [], - "startPosition": "3088" + "startPosition": "3728" } }, { "expression": { - "endPosition": "3160", + "endPosition": "3800", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "sort", @@ -6412,751 +6809,786 @@ "expression": { "identifier": "util", "expression": { - "endPosition": "3136", + "endPosition": "3776", "kind": "IDENTIFIER", "name": "java", - "startPosition": "3132" + "startPosition": "3772" }, - "endPosition": "3141", + "endPosition": "3781", "kind": "MEMBER_SELECT", - "startPosition": "3132" + "startPosition": "3772" }, - "endPosition": "3148", + "endPosition": "3788", "kind": "MEMBER_SELECT", - "startPosition": "3132" + "startPosition": "3772" }, - "endPosition": "3153", + "endPosition": "3793", "kind": "MEMBER_SELECT", - "startPosition": "3132" + "startPosition": "3772" }, "arguments": [ { - "endPosition": "3159", + "endPosition": "3799", "kind": "IDENTIFIER", "name": "files", - "startPosition": "3154" + "startPosition": "3794" } ], - "startPosition": "3132" + "startPosition": "3772" }, - "endPosition": "3160", + "endPosition": "3800", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3132" + "startPosition": "3772" }, { - "endPosition": "3184", + "endPosition": "3824", "kind": "VARIABLE", - "name": "file", - "startPosition": "3180" + "binding": { + "endPosition": "3824", + "kind": "IDENTIFIER", + "name": "file", + "startPosition": "3820" + }, + "startPosition": "3816" }, { "expression": { - "endPosition": "3193", + "endPosition": "3833", "kind": "IDENTIFIER", "name": "files", - "startPosition": "3188" + "startPosition": "3828" }, - "endPosition": "3724", + "endPosition": "4364", "kind": "FOR_IN_LOOP", "forEach": "true", "variable": { - "endPosition": "3184", + "endPosition": "3824", "kind": "IDENTIFIER", "name": "file", - "startPosition": "3180" + "startPosition": "3820" }, "statement": { - "endPosition": "3724", + "endPosition": "4364", "kind": "BLOCK", "statements": [ { "condition": { - "endPosition": "3234", + "endPosition": "3874", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "endsWith", "expression": { "identifier": "name", "expression": { - "endPosition": "3213", + "endPosition": "3853", "kind": "IDENTIFIER", "name": "file", - "startPosition": "3209" + "startPosition": "3849" }, - "endPosition": "3218", + "endPosition": "3858", "kind": "MEMBER_SELECT", - "startPosition": "3209" + "startPosition": "3849" }, - "endPosition": "3227", + "endPosition": "3867", "kind": "MEMBER_SELECT", - "startPosition": "3209" + "startPosition": "3849" }, "arguments": [ { - "endPosition": "3232", + "endPosition": "3872", "kind": "STRING_LITERAL", "value": ".js", - "startPosition": "3229" + "startPosition": "3869" } ], - "startPosition": "3209" + "startPosition": "3849" }, - "endPosition": "3718", + "endPosition": "4358", "kind": "IF", - "startPosition": "3205", + "startPosition": "3845", "thenStatement": { - "endPosition": "3718", + "endPosition": "4358", "kind": "BLOCK", "statements": [ { - "endPosition": "3278", + "endPosition": "3918", "kind": "VARIABLE", - "name": "script", - "startPosition": "3254", + "binding": { + "endPosition": "3900", + "kind": "IDENTIFIER", + "name": "script", + "startPosition": "3894" + }, + "startPosition": "3890", "initializer": { - "endPosition": "3278", + "endPosition": "3918", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3272", + "endPosition": "3912", "kind": "IDENTIFIER", "name": "readFully", - "startPosition": "3263" + "startPosition": "3903" }, "arguments": [ { - "endPosition": "3277", + "endPosition": "3917", "kind": "IDENTIFIER", "name": "file", - "startPosition": "3273" + "startPosition": "3913" } ], - "startPosition": "3263" + "startPosition": "3903" } }, { - "endPosition": "3317", + "endPosition": "3957", "kind": "VARIABLE", - "name": "parser", - "startPosition": "3296", + "binding": { + "endPosition": "3942", + "kind": "IDENTIFIER", + "name": "parser", + "startPosition": "3936" + }, + "startPosition": "3932", "initializer": { "constructorExpression": { - "endPosition": "3317", + "endPosition": "3957", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3315", + "endPosition": "3955", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "3309" + "startPosition": "3949" }, "arguments": [], - "startPosition": "3309" + "startPosition": "3949" }, - "endPosition": "3317", + "endPosition": "3957", "kind": "NEW", - "startPosition": "3305" + "startPosition": "3945" } }, { - "endPosition": "3578", + "endPosition": "4218", "kind": "VARIABLE", - "name": "tree", - "startPosition": "3335", + "binding": { + "endPosition": "3979", + "kind": "IDENTIFIER", + "name": "tree", + "startPosition": "3975" + }, + "startPosition": "3971", "initializer": { - "endPosition": "3578", + "endPosition": "4218", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "parse", "expression": { - "endPosition": "3348", + "endPosition": "3988", "kind": "IDENTIFIER", "name": "parser", - "startPosition": "3342" + "startPosition": "3982" }, - "endPosition": "3354", + "endPosition": "3994", "kind": "MEMBER_SELECT", - "startPosition": "3342" + "startPosition": "3982" }, "arguments": [ { "leftOperand": { "leftOperand": { - "endPosition": "3361", + "endPosition": "4001", "kind": "IDENTIFIER", "name": "subdir", - "startPosition": "3355" + "startPosition": "3995" }, - "endPosition": "3366", + "endPosition": "4006", "kind": "PLUS", "rightOperand": { - "endPosition": "3366", + "endPosition": "4006", "kind": "STRING_LITERAL", "value": "/", - "startPosition": "3365" + "startPosition": "4005" }, - "startPosition": "3355" + "startPosition": "3995" }, - "endPosition": "3379", + "endPosition": "4019", "kind": "PLUS", "rightOperand": { "identifier": "name", "expression": { - "endPosition": "3374", + "endPosition": "4014", "kind": "IDENTIFIER", "name": "file", - "startPosition": "3370" + "startPosition": "4010" }, - "endPosition": "3379", + "endPosition": "4019", "kind": "MEMBER_SELECT", - "startPosition": "3370" + "startPosition": "4010" }, - "startPosition": "3355" + "startPosition": "3995" }, { - "endPosition": "3387", + "endPosition": "4027", "kind": "IDENTIFIER", "name": "script", - "startPosition": "3381" + "startPosition": "4021" }, { - "endPosition": "3426", + "endPosition": "4066", "kind": "FUNCTION_EXPRESSION", "body": { - "endPosition": "3559", + "endPosition": "4199", "kind": "BLOCK", "statements": [ { "expression": { - "endPosition": "3526", + "endPosition": "4166", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3453", + "endPosition": "4093", "kind": "IDENTIFIER", "name": "print", - "startPosition": "3448" + "startPosition": "4088" }, "arguments": [ { - "endPosition": "3525", + "endPosition": "4165", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "replace", "expression": { - "endPosition": "3505", + "endPosition": "4145", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "stringify", "expression": { - "endPosition": "3458", + "endPosition": "4098", "kind": "IDENTIFIER", "name": "JSON", - "startPosition": "3454" + "startPosition": "4094" }, - "endPosition": "3468", + "endPosition": "4108", "kind": "MEMBER_SELECT", - "startPosition": "3454" + "startPosition": "4094" }, "arguments": [ { - "endPosition": "3495", + "endPosition": "4135", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "convert", "expression": { - "endPosition": "3475", + "endPosition": "4115", "kind": "IDENTIFIER", "name": "parser", - "startPosition": "3469" + "startPosition": "4109" }, - "endPosition": "3483", + "endPosition": "4123", "kind": "MEMBER_SELECT", - "startPosition": "3469" + "startPosition": "4109" }, "arguments": [ { - "endPosition": "3494", + "endPosition": "4134", "kind": "IDENTIFIER", "name": "diagnostic", - "startPosition": "3484" + "startPosition": "4124" } ], - "startPosition": "3469" + "startPosition": "4109" }, { - "endPosition": "3501", + "endPosition": "4141", "kind": "NULL_LITERAL", - "startPosition": "3497" + "startPosition": "4137" }, { - "endPosition": "3504", + "endPosition": "4144", "kind": "NUMBER_LITERAL", "value": "2", - "startPosition": "3503" + "startPosition": "4143" } ], - "startPosition": "3454" + "startPosition": "4094" }, - "endPosition": "3513", + "endPosition": "4153", "kind": "MEMBER_SELECT", - "startPosition": "3454" + "startPosition": "4094" }, "arguments": [ { - "endPosition": "3520", + "endPosition": "4160", "kind": "REGEXP_LITERAL", "options": "g", "pattern": "\\\\r", - "startPosition": "3514" + "startPosition": "4154" }, { - "endPosition": "3523", + "endPosition": "4163", "kind": "STRING_LITERAL", "value": "", - "startPosition": "3523" + "startPosition": "4163" } ], - "startPosition": "3513" + "startPosition": "4153" } ], - "startPosition": "3448" + "startPosition": "4088" }, - "endPosition": "3526", + "endPosition": "4166", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3448" + "startPosition": "4088" }, { "expression": { - "endPosition": "3558", + "endPosition": "4198", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3553", + "endPosition": "4193", "kind": "IDENTIFIER", "name": "print", - "startPosition": "3548" + "startPosition": "4188" }, "arguments": [ { - "endPosition": "3556", + "endPosition": "4196", "kind": "STRING_LITERAL", "value": ",", - "startPosition": "3555" + "startPosition": "4195" } ], - "startPosition": "3548" + "startPosition": "4188" }, - "endPosition": "3558", + "endPosition": "4198", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3548" + "startPosition": "4188" } ], - "startPosition": "3426" + "startPosition": "4066" }, "strict": "false", - "startPosition": "3426", + "startPosition": "4066", "parameters": [ { - "endPosition": "3424", + "endPosition": "4064", "kind": "IDENTIFIER", "name": "diagnostic", - "startPosition": "3414" + "startPosition": "4054" } ] } ], - "startPosition": "3342" + "startPosition": "3982" } }, { "condition": { "leftOperand": { - "endPosition": "3601", + "endPosition": "4241", "kind": "IDENTIFIER", "name": "tree", - "startPosition": "3597" + "startPosition": "4237" }, - "endPosition": "3609", + "endPosition": "4249", "kind": "NOT_EQUAL_TO", "rightOperand": { - "endPosition": "3609", + "endPosition": "4249", "kind": "NULL_LITERAL", - "startPosition": "3605" + "startPosition": "4245" }, - "startPosition": "3597" + "startPosition": "4237" }, - "endPosition": "3708", + "endPosition": "4348", "kind": "IF", - "startPosition": "3593", + "startPosition": "4233", "thenStatement": { - "endPosition": "3708", + "endPosition": "4348", "kind": "BLOCK", "statements": [ { "expression": { - "endPosition": "3665", + "endPosition": "4305", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3634", + "endPosition": "4274", "kind": "IDENTIFIER", "name": "print", - "startPosition": "3629" + "startPosition": "4269" }, "arguments": [ { - "endPosition": "3664", + "endPosition": "4304", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "stringify", "expression": { - "endPosition": "3639", + "endPosition": "4279", "kind": "IDENTIFIER", "name": "JSON", - "startPosition": "3635" + "startPosition": "4275" }, - "endPosition": "3649", + "endPosition": "4289", "kind": "MEMBER_SELECT", - "startPosition": "3635" + "startPosition": "4275" }, "arguments": [ { - "endPosition": "3654", + "endPosition": "4294", "kind": "IDENTIFIER", "name": "tree", - "startPosition": "3650" + "startPosition": "4290" }, { - "endPosition": "3660", + "endPosition": "4300", "kind": "NULL_LITERAL", - "startPosition": "3656" + "startPosition": "4296" }, { - "endPosition": "3663", + "endPosition": "4303", "kind": "NUMBER_LITERAL", "value": "2", - "startPosition": "3662" + "startPosition": "4302" } ], - "startPosition": "3635" + "startPosition": "4275" } ], - "startPosition": "3629" + "startPosition": "4269" }, - "endPosition": "3665", + "endPosition": "4305", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3629" + "startPosition": "4269" }, { "expression": { - "endPosition": "3693", + "endPosition": "4333", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3688", + "endPosition": "4328", "kind": "IDENTIFIER", "name": "print", - "startPosition": "3683" + "startPosition": "4323" }, "arguments": [ { - "endPosition": "3691", + "endPosition": "4331", "kind": "STRING_LITERAL", "value": ",", - "startPosition": "3690" + "startPosition": "4330" } ], - "startPosition": "3683" + "startPosition": "4323" }, - "endPosition": "3693", + "endPosition": "4333", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3683" + "startPosition": "4323" } ], - "startPosition": "3611" + "startPosition": "4251" } } ], - "startPosition": "3236" + "startPosition": "3876" } } ], - "startPosition": "3195" + "startPosition": "3835" }, - "startPosition": "3166" + "startPosition": "3806" } ], - "startPosition": "3028" + "startPosition": "3668" }, "strict": "false", - "startPosition": "2998", + "startPosition": "3638", "parameters": [ { - "endPosition": "3026", + "endPosition": "3666", "kind": "IDENTIFIER", "name": "subdir", - "startPosition": "3020" + "startPosition": "3660" } ] }, { - "endPosition": "4070", + "endPosition": "4710", "kind": "FUNCTION", - "name": "main", + "name": { + "endPosition": "4421", + "kind": "IDENTIFIER", + "name": "main", + "startPosition": "4417" + }, "body": { - "endPosition": "4068", + "endPosition": "4708", "kind": "BLOCK", "statements": [ { "expression": { - "endPosition": "3800", + "endPosition": "4440", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3795", + "endPosition": "4435", "kind": "IDENTIFIER", "name": "print", - "startPosition": "3790" + "startPosition": "4430" }, "arguments": [ { - "endPosition": "3798", + "endPosition": "4438", "kind": "STRING_LITERAL", "value": "[", - "startPosition": "3797" + "startPosition": "4437" } ], - "startPosition": "3790" + "startPosition": "4430" }, - "endPosition": "3800", + "endPosition": "4440", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3790" + "startPosition": "4430" }, { "expression": { - "endPosition": "3834", + "endPosition": "4474", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3819", + "endPosition": "4459", "kind": "IDENTIFIER", "name": "processFiles", - "startPosition": "3807" + "startPosition": "4447" }, "arguments": [ { - "endPosition": "3832", + "endPosition": "4472", "kind": "STRING_LITERAL", "value": "parsertests", - "startPosition": "3821" + "startPosition": "4461" } ], - "startPosition": "3807" + "startPosition": "4447" }, - "endPosition": "3834", + "endPosition": "4474", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3807" + "startPosition": "4447" }, { "expression": { - "endPosition": "3875", + "endPosition": "4515", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3852", + "endPosition": "4492", "kind": "IDENTIFIER", "name": "processFiles", - "startPosition": "3840" + "startPosition": "4480" }, "arguments": [ { - "endPosition": "3873", + "endPosition": "4513", "kind": "STRING_LITERAL", "value": "parsernegativetests", - "startPosition": "3854" + "startPosition": "4494" } ], - "startPosition": "3840" + "startPosition": "4480" }, - "endPosition": "3875", + "endPosition": "4515", "kind": "EXPRESSION_STATEMENT", - "startPosition": "3840" + "startPosition": "4480" }, { - "endPosition": "3944", + "endPosition": "4584", "kind": "VARIABLE", - "name": "script", - "startPosition": "3916", + "binding": { + "endPosition": "4562", + "kind": "IDENTIFIER", + "name": "script", + "startPosition": "4556" + }, + "startPosition": "4552", "initializer": { - "endPosition": "3944", + "endPosition": "4584", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3934", + "endPosition": "4574", "kind": "IDENTIFIER", "name": "readFully", - "startPosition": "3925" + "startPosition": "4565" }, "arguments": [ { - "endPosition": "3943", + "endPosition": "4583", "kind": "IDENTIFIER", "name": "__FILE__", - "startPosition": "3935" + "startPosition": "4575" } ], - "startPosition": "3925" + "startPosition": "4565" } }, { - "endPosition": "4009", + "endPosition": "4649", "kind": "VARIABLE", - "name": "tree", - "startPosition": "3954", + "binding": { + "endPosition": "4598", + "kind": "IDENTIFIER", + "name": "tree", + "startPosition": "4594" + }, + "startPosition": "4590", "initializer": { - "endPosition": "4009", + "endPosition": "4649", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "parse", "expression": { "constructorExpression": { - "endPosition": "3973", + "endPosition": "4613", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "3971", + "endPosition": "4611", "kind": "IDENTIFIER", "name": "Parser", - "startPosition": "3965" + "startPosition": "4605" }, "arguments": [], - "startPosition": "3965" + "startPosition": "4605" }, - "endPosition": "3973", + "endPosition": "4613", "kind": "NEW", - "startPosition": "3961" + "startPosition": "4601" }, - "endPosition": "3979", + "endPosition": "4619", "kind": "MEMBER_SELECT", - "startPosition": "3961" + "startPosition": "4601" }, "arguments": [ { - "endPosition": "3993", + "endPosition": "4633", "kind": "STRING_LITERAL", "value": "parserapi.js", - "startPosition": "3981" + "startPosition": "4621" }, { - "endPosition": "4002", + "endPosition": "4642", "kind": "IDENTIFIER", "name": "script", - "startPosition": "3996" + "startPosition": "4636" }, { - "endPosition": "4008", + "endPosition": "4648", "kind": "NULL_LITERAL", - "startPosition": "4004" + "startPosition": "4644" } ], - "startPosition": "3961" + "startPosition": "4601" } }, { "expression": { - "endPosition": "4051", + "endPosition": "4691", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "4020", + "endPosition": "4660", "kind": "IDENTIFIER", "name": "print", - "startPosition": "4015" + "startPosition": "4655" }, "arguments": [ { - "endPosition": "4050", + "endPosition": "4690", "kind": "FUNCTION_INVOCATION", "functionSelect": { "identifier": "stringify", "expression": { - "endPosition": "4025", + "endPosition": "4665", "kind": "IDENTIFIER", "name": "JSON", - "startPosition": "4021" + "startPosition": "4661" }, - "endPosition": "4035", + "endPosition": "4675", "kind": "MEMBER_SELECT", - "startPosition": "4021" + "startPosition": "4661" }, "arguments": [ { - "endPosition": "4040", + "endPosition": "4680", "kind": "IDENTIFIER", "name": "tree", - "startPosition": "4036" + "startPosition": "4676" }, { - "endPosition": "4046", + "endPosition": "4686", "kind": "NULL_LITERAL", - "startPosition": "4042" + "startPosition": "4682" }, { - "endPosition": "4049", + "endPosition": "4689", "kind": "NUMBER_LITERAL", "value": "2", - "startPosition": "4048" + "startPosition": "4688" } ], - "startPosition": "4021" + "startPosition": "4661" } ], - "startPosition": "4015" + "startPosition": "4655" }, - "endPosition": "4051", + "endPosition": "4691", "kind": "EXPRESSION_STATEMENT", - "startPosition": "4015" + "startPosition": "4655" }, { "expression": { - "endPosition": "4067", + "endPosition": "4707", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "4062", + "endPosition": "4702", "kind": "IDENTIFIER", "name": "print", - "startPosition": "4057" + "startPosition": "4697" }, "arguments": [ { - "endPosition": "4065", + "endPosition": "4705", "kind": "STRING_LITERAL", "value": "]", - "startPosition": "4064" + "startPosition": "4704" } ], - "startPosition": "4057" + "startPosition": "4697" }, - "endPosition": "4067", + "endPosition": "4707", "kind": "EXPRESSION_STATEMENT", - "startPosition": "4057" + "startPosition": "4697" } ], - "startPosition": "3784" + "startPosition": "4424" }, "strict": "false", - "startPosition": "3768", + "startPosition": "4408", "parameters": [] }, { "expression": { - "endPosition": "4078", + "endPosition": "4718", "kind": "FUNCTION_INVOCATION", "functionSelect": { - "endPosition": "4076", + "endPosition": "4716", "kind": "IDENTIFIER", "name": "main", - "startPosition": "4072" + "startPosition": "4712" }, "arguments": [], - "startPosition": "4072" + "startPosition": "4712" }, - "endPosition": "4078", + "endPosition": "4718", "kind": "EXPRESSION_STATEMENT", - "startPosition": "4072" + "startPosition": "4712" } ], "sourceName": "parserapi.js", "strict": "false", "startPosition": "1136" -} -] +} +] diff --git a/nashorn/test/script/nosecurity/parservisitor.js b/nashorn/test/script/nosecurity/parservisitor.js index 069f50f68d4..9f71addc81a 100644 --- a/nashorn/test/script/nosecurity/parservisitor.js +++ b/nashorn/test/script/nosecurity/parservisitor.js @@ -202,7 +202,7 @@ parse("funccall.js", "func()", parse("funcdecl.js", "function func() {}", new (Java.extend(SimpleTreeVisitor))() { visitFunctionDeclaration: function(fd) { - print("in visitFunctionDeclaration " + fd.name); + print("in visitFunctionDeclaration " + fd.name.name); } }); @@ -361,7 +361,7 @@ unaryExpr("void.js", "void x"); parse("var.js", "var x = 34;", new (Java.extend(SimpleTreeVisitor))() { visitVariable: function(vn) { - print("in visitVariable " + vn.name + " = " + vn.initializer.value); + print("in visitVariable " + vn.binding.name + " = " + vn.initializer.value); } }); diff --git a/nashorn/test/script/nosecurity/treeapi/arrow.js b/nashorn/test/script/nosecurity/treeapi/arrow.js new file mode 100644 index 00000000000..b4b92f50c3d --- /dev/null +++ b/nashorn/test/script/nosecurity/treeapi/arrow.js @@ -0,0 +1,49 @@ +/* + * Copyright (c) 2016, 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. + */ + +/** + * Tests to check representation of ES6 arrows. + * + * @test + * @option -scripting + * @run + */ + +load(__DIR__ + "utils.js") + +var code = <x*2; +[].map(v => v + 1); + +EOF + +parse("arrow.js", code, "--language=es6", new (Java.extend(visitor_es6, { + visitVariable : function (node, obj) { + obj.push(convert(node)) + }, + visitExpressionStatement : function (node, obj) { + obj.push(convert(node)) + } +}))) + diff --git a/nashorn/test/script/nosecurity/treeapi/arrow.js.EXPECTED b/nashorn/test/script/nosecurity/treeapi/arrow.js.EXPECTED new file mode 100644 index 00000000000..e53a895f641 --- /dev/null +++ b/nashorn/test/script/nosecurity/treeapi/arrow.js.EXPECTED @@ -0,0 +1,103 @@ +[ + { + "endPosition": "15", + "kind": "VARIABLE", + "binding": { + "endPosition": "6", + "kind": "IDENTIFIER", + "name": "f", + "startPosition": "5" + }, + "startPosition": "1", + "initializer": { + "endPosition": "12", + "arrow": "true", + "kind": "FUNCTION_EXPRESSION", + "name": "null", + "body": { + "leftOperand": { + "endPosition": "13", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "12" + }, + "endPosition": "15", + "kind": "MULTIPLY", + "rightOperand": { + "endPosition": "15", + "kind": "NUMBER_LITERAL", + "value": "2", + "startPosition": "14" + }, + "startPosition": "12" + }, + "strict": "false", + "startPosition": "12", + "parameters": [ + { + "endPosition": "10", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "9" + } + ] + } + }, + { + "expression": { + "endPosition": "35", + "kind": "FUNCTION_INVOCATION", + "functionSelect": { + "identifier": "map", + "expression": { + "endPosition": "19", + "kind": "ARRAY_LITERAL", + "elements": [], + "startPosition": "17" + }, + "endPosition": "23", + "kind": "MEMBER_SELECT", + "startPosition": "17" + }, + "arguments": [ + { + "endPosition": "29", + "arrow": "true", + "kind": "FUNCTION_EXPRESSION", + "name": "null", + "body": { + "leftOperand": { + "endPosition": "30", + "kind": "IDENTIFIER", + "name": "v", + "startPosition": "29" + }, + "endPosition": "34", + "kind": "PLUS", + "rightOperand": { + "endPosition": "34", + "kind": "NUMBER_LITERAL", + "value": "1", + "startPosition": "33" + }, + "startPosition": "29" + }, + "strict": "false", + "startPosition": "29", + "parameters": [ + { + "endPosition": "25", + "kind": "IDENTIFIER", + "name": "v", + "startPosition": "24" + } + ] + } + ], + "startPosition": "17" + }, + "endPosition": "35", + "kind": "EXPRESSION_STATEMENT", + "startPosition": "17" + } +] diff --git a/nashorn/test/script/nosecurity/treeapi/arrow_params.js b/nashorn/test/script/nosecurity/treeapi/arrow_params.js new file mode 100644 index 00000000000..9a477c6db10 --- /dev/null +++ b/nashorn/test/script/nosecurity/treeapi/arrow_params.js @@ -0,0 +1,49 @@ +/* + * Copyright (c) 2016, 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. + */ + +/** + * Tests to check representation of ES6 arrow params. + * + * @test + * @option -scripting + * @run + */ + +load(__DIR__ + "utils.js") + +var code = <x*3; +var f2 = ({x, y})=>x*y; +var f3 = ([x, y])=>x+y; +var f4 = ({x, y}={y: 4, x: 5})=>x*y; +var f5 = ([x, y]=[3, 6])=>x+y; + +EOF + +parse("arrow_params.js", code, "--language=es6", new (Java.extend(visitor_es6, { + visitVariable : function (node, obj) { + obj.push(convert(node)) + } +}))) + diff --git a/nashorn/test/script/nosecurity/treeapi/arrow_params.js.EXPECTED b/nashorn/test/script/nosecurity/treeapi/arrow_params.js.EXPECTED new file mode 100644 index 00000000000..e25cbd8cda2 --- /dev/null +++ b/nashorn/test/script/nosecurity/treeapi/arrow_params.js.EXPECTED @@ -0,0 +1,411 @@ +[ + { + "endPosition": "20", + "kind": "VARIABLE", + "binding": { + "endPosition": "7", + "kind": "IDENTIFIER", + "name": "f1", + "startPosition": "5" + }, + "startPosition": "1", + "initializer": { + "endPosition": "17", + "arrow": "true", + "kind": "FUNCTION_EXPRESSION", + "name": "null", + "body": { + "leftOperand": { + "endPosition": "18", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "17" + }, + "endPosition": "20", + "kind": "MULTIPLY", + "rightOperand": { + "endPosition": "20", + "kind": "NUMBER_LITERAL", + "value": "3", + "startPosition": "19" + }, + "startPosition": "17" + }, + "strict": "false", + "startPosition": "17", + "parameters": [ + { + "expression": { + "endPosition": "14", + "kind": "NUMBER_LITERAL", + "value": "2", + "startPosition": "13" + }, + "endPosition": "14", + "kind": "ASSIGNMENT", + "variable": { + "endPosition": "12", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "11" + }, + "startPosition": "11" + } + ] + } + }, + { + "endPosition": "44", + "kind": "VARIABLE", + "binding": { + "endPosition": "28", + "kind": "IDENTIFIER", + "name": "f2", + "startPosition": "26" + }, + "startPosition": "22", + "initializer": { + "endPosition": "41", + "arrow": "true", + "kind": "FUNCTION_EXPRESSION", + "name": "null", + "body": { + "leftOperand": { + "endPosition": "42", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "41" + }, + "endPosition": "44", + "kind": "MULTIPLY", + "rightOperand": { + "endPosition": "44", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "43" + }, + "startPosition": "41" + }, + "strict": "false", + "startPosition": "41", + "parameters": [ + { + "endPosition": "38", + "kind": "OBJECT_LITERAL", + "startPosition": "32", + "properties": [ + { + "getter": "null", + "endPosition": "34", + "kind": "PROPERTY", + "setter": "null", + "value": { + "endPosition": "34", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "33" + }, + "startPosition": "33", + "key": { + "endPosition": "34", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "33" + } + }, + { + "getter": "null", + "endPosition": "37", + "kind": "PROPERTY", + "setter": "null", + "value": { + "endPosition": "37", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "36" + }, + "startPosition": "36", + "key": { + "endPosition": "37", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "36" + } + } + ] + } + ] + } + }, + { + "endPosition": "68", + "kind": "VARIABLE", + "binding": { + "endPosition": "52", + "kind": "IDENTIFIER", + "name": "f3", + "startPosition": "50" + }, + "startPosition": "46", + "initializer": { + "endPosition": "65", + "arrow": "true", + "kind": "FUNCTION_EXPRESSION", + "name": "null", + "body": { + "leftOperand": { + "endPosition": "66", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "65" + }, + "endPosition": "68", + "kind": "PLUS", + "rightOperand": { + "endPosition": "68", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "67" + }, + "startPosition": "65" + }, + "strict": "false", + "startPosition": "65", + "parameters": [ + { + "endPosition": "62", + "kind": "ARRAY_LITERAL", + "elements": [ + { + "endPosition": "58", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "57" + }, + { + "endPosition": "61", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "60" + } + ], + "startPosition": "56" + } + ] + } + }, + { + "endPosition": "105", + "kind": "VARIABLE", + "binding": { + "endPosition": "76", + "kind": "IDENTIFIER", + "name": "f4", + "startPosition": "74" + }, + "startPosition": "70", + "initializer": { + "endPosition": "102", + "arrow": "true", + "kind": "FUNCTION_EXPRESSION", + "name": "null", + "body": { + "leftOperand": { + "endPosition": "103", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "102" + }, + "endPosition": "105", + "kind": "MULTIPLY", + "rightOperand": { + "endPosition": "105", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "104" + }, + "startPosition": "102" + }, + "strict": "false", + "startPosition": "102", + "parameters": [ + { + "expression": { + "endPosition": "99", + "kind": "OBJECT_LITERAL", + "startPosition": "87", + "properties": [ + { + "getter": "null", + "endPosition": "92", + "kind": "PROPERTY", + "setter": "null", + "value": { + "endPosition": "92", + "kind": "NUMBER_LITERAL", + "value": "4", + "startPosition": "91" + }, + "startPosition": "88", + "key": { + "endPosition": "89", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "88" + } + }, + { + "getter": "null", + "endPosition": "98", + "kind": "PROPERTY", + "setter": "null", + "value": { + "endPosition": "98", + "kind": "NUMBER_LITERAL", + "value": "5", + "startPosition": "97" + }, + "startPosition": "94", + "key": { + "endPosition": "95", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "94" + } + } + ] + }, + "endPosition": "99", + "kind": "ASSIGNMENT", + "variable": { + "endPosition": "86", + "kind": "OBJECT_LITERAL", + "startPosition": "80", + "properties": [ + { + "getter": "null", + "endPosition": "82", + "kind": "PROPERTY", + "setter": "null", + "value": { + "endPosition": "82", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "81" + }, + "startPosition": "81", + "key": { + "endPosition": "82", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "81" + } + }, + { + "getter": "null", + "endPosition": "85", + "kind": "PROPERTY", + "setter": "null", + "value": { + "endPosition": "85", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "84" + }, + "startPosition": "84", + "key": { + "endPosition": "85", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "84" + } + } + ] + }, + "startPosition": "80" + } + ] + } + }, + { + "endPosition": "136", + "kind": "VARIABLE", + "binding": { + "endPosition": "113", + "kind": "IDENTIFIER", + "name": "f5", + "startPosition": "111" + }, + "startPosition": "107", + "initializer": { + "endPosition": "133", + "arrow": "true", + "kind": "FUNCTION_EXPRESSION", + "name": "null", + "body": { + "leftOperand": { + "endPosition": "134", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "133" + }, + "endPosition": "136", + "kind": "PLUS", + "rightOperand": { + "endPosition": "136", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "135" + }, + "startPosition": "133" + }, + "strict": "false", + "startPosition": "133", + "parameters": [ + { + "expression": { + "endPosition": "130", + "kind": "ARRAY_LITERAL", + "elements": [ + { + "endPosition": "126", + "kind": "NUMBER_LITERAL", + "value": "3", + "startPosition": "125" + }, + { + "endPosition": "129", + "kind": "NUMBER_LITERAL", + "value": "6", + "startPosition": "128" + } + ], + "startPosition": "124" + }, + "endPosition": "130", + "kind": "ASSIGNMENT", + "variable": { + "endPosition": "123", + "kind": "ARRAY_LITERAL", + "elements": [ + { + "endPosition": "119", + "kind": "IDENTIFIER", + "name": "x", + "startPosition": "118" + }, + { + "endPosition": "122", + "kind": "IDENTIFIER", + "name": "y", + "startPosition": "121" + } + ], + "startPosition": "117" + }, + "startPosition": "117" + } + ] + } + } +] diff --git a/nashorn/test/script/nosecurity/treeapi/assignment.js.EXPECTED b/nashorn/test/script/nosecurity/treeapi/assignment.js.EXPECTED index bac257f888a..bb86c2aa69e 100644 --- a/nashorn/test/script/nosecurity/treeapi/assignment.js.EXPECTED +++ b/nashorn/test/script/nosecurity/treeapi/assignment.js.EXPECTED @@ -146,4 +146,4 @@ }, "startPosition": "61" } -] +] diff --git a/nashorn/test/script/nosecurity/treeapi/class.js b/nashorn/test/script/nosecurity/treeapi/class.js new file mode 100644 index 00000000000..ce48d423a3e --- /dev/null +++ b/nashorn/test/script/nosecurity/treeapi/class.js @@ -0,0 +1,91 @@ +/* + * Copyright (c) 2016, 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. + */ + +/** + * Tests to check representation of ES6 class. + * + * @test + * @option -scripting + * @run + */ + +load(__DIR__ + "utils.js") + +var code = <