FunctionExpressionTreeImpl.java revision 1786:80120e9b3273
1/* 2 * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Oracle designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26package jdk.nashorn.api.tree; 27 28import java.util.List; 29import jdk.nashorn.internal.ir.FunctionNode; 30 31final class FunctionExpressionTreeImpl extends ExpressionTreeImpl 32 implements FunctionExpressionTree { 33 private final FunctionNode funcNode; 34 private final IdentifierTree funcName; 35 private final List<? extends ExpressionTree> params; 36 private final Tree body; 37 38 FunctionExpressionTreeImpl(final FunctionNode node, 39 final List<? extends ExpressionTree> params, 40 final BlockTree body) { 41 super(node); 42 funcNode = node; 43 assert !funcNode.isDeclared() || funcNode.isAnonymous() : "function expression expected"; 44 45 final FunctionNode.Kind kind = node.getKind(); 46 if (node.isAnonymous() || kind == FunctionNode.Kind.GETTER || kind == FunctionNode.Kind.SETTER) { 47 funcName = null; 48 } else { 49 funcName = new IdentifierTreeImpl(node.getIdent()); 50 } 51 52 this.params = params; 53 if (node.getFlag(FunctionNode.HAS_EXPRESSION_BODY)) { 54 final StatementTree first = body.getStatements().get(0); 55 assert first instanceof ReturnTree : "consise func. expression should have a return statement"; 56 this.body = ((ReturnTree)first).getExpression(); 57 } else { 58 this.body = body; 59 } 60 } 61 62 @Override 63 public Tree.Kind getKind() { 64 return Tree.Kind.FUNCTION_EXPRESSION; 65 } 66 67 @Override 68 public IdentifierTree getName() { 69 return funcName; 70 } 71 72 @Override 73 public List<? extends ExpressionTree> getParameters() { 74 return params; 75 } 76 77 @Override 78 public Tree getBody() { 79 return body; 80 } 81 82 @Override 83 public boolean isStrict() { 84 return funcNode.isStrict(); 85 } 86 87 @Override 88 public boolean isArrow() { 89 return funcNode.getKind() == FunctionNode.Kind.ARROW; 90 } 91 92 @Override 93 public boolean isGenerator() { 94 return funcNode.getKind() == FunctionNode.Kind.GENERATOR; 95 } 96 97 @Override 98 public <R,D> R accept(final TreeVisitor<R,D> visitor, final D data) { 99 return visitor.visitFunctionExpression(this, data); 100 } 101} 102