All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jscover.mozilla.javascript.ast.ConditionalExpression Maven / Gradle / Ivy

Go to download

Rhino is an open-source implementation of JavaScript written entirely in Java. It is typically embedded into Java applications to provide scripting to end users.

There is a newer version: 1.7R5pre05
Show newest version
/* -*- Mode: java; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

package jscover.mozilla.javascript.ast;

import jscover.mozilla.javascript.Token;

/**
 * AST node representing the ternary operator.  Node type is
 * {@link Token#HOOK}.
 *
 * 
ConditionalExpression :
 *        LogicalORExpression
 *        LogicalORExpression ? AssignmentExpression
 *                            : AssignmentExpression
* * ConditionalExpressionNoIn : * LogicalORExpressionNoIn * LogicalORExpressionNoIn ? AssignmentExpression * : AssignmentExpressionNoIn
*/ public class ConditionalExpression extends AstNode { private AstNode testExpression; private AstNode trueExpression; private AstNode falseExpression; private int questionMarkPosition = -1; private int colonPosition = -1; { type = Token.HOOK; } public ConditionalExpression() { } public ConditionalExpression(int pos) { super(pos); } public ConditionalExpression(int pos, int len) { super(pos, len); } /** * Returns test expression */ public AstNode getTestExpression() { return testExpression; } /** * Sets test expression, and sets its parent. * @param testExpression test expression * @throws IllegalArgumentException if testExpression is {@code null} */ public void setTestExpression(AstNode testExpression) { assertNotNull(testExpression); this.testExpression = testExpression; testExpression.setParent(this); } /** * Returns expression to evaluate if test is true */ public AstNode getTrueExpression() { return trueExpression; } /** * Sets expression to evaluate if test is true, and * sets its parent to this node. * @param trueExpression expression to evaluate if test is true * @throws IllegalArgumentException if expression is {@code null} */ public void setTrueExpression(AstNode trueExpression) { assertNotNull(trueExpression); this.trueExpression = trueExpression; trueExpression.setParent(this); } /** * Returns expression to evaluate if test is false */ public AstNode getFalseExpression() { return falseExpression; } /** * Sets expression to evaluate if test is false, and sets its * parent to this node. * @param falseExpression expression to evaluate if test is false * @throws IllegalArgumentException if {@code falseExpression} * is {@code null} */ public void setFalseExpression(AstNode falseExpression) { assertNotNull(falseExpression); this.falseExpression = falseExpression; falseExpression.setParent(this); } /** * Returns position of ? token */ public int getQuestionMarkPosition() { return questionMarkPosition; } /** * Sets position of ? token * @param questionMarkPosition position of ? token */ public void setQuestionMarkPosition(int questionMarkPosition) { this.questionMarkPosition = questionMarkPosition; } /** * Returns position of : token */ public int getColonPosition() { return colonPosition; } /** * Sets position of : token * @param colonPosition position of : token */ public void setColonPosition(int colonPosition) { this.colonPosition = colonPosition; } @Override public boolean hasSideEffects() { if (testExpression == null || trueExpression == null || falseExpression == null) codeBug(); return trueExpression.hasSideEffects() && falseExpression.hasSideEffects(); } @Override public String toSource(int depth) { StringBuilder sb = new StringBuilder(); sb.append(makeIndent(depth)); sb.append(testExpression.toSource(depth)); sb.append(" ? "); sb.append(trueExpression.toSource(0)); sb.append(" : "); sb.append(falseExpression.toSource(0)); return sb.toString(); } /** * Visits this node, then the test-expression, the true-expression, * and the false-expression. */ @Override public void visit(NodeVisitor v) { if (v.visit(this)) { testExpression.visit(v); trueExpression.visit(v); falseExpression.visit(v); } } }



© 2015 - 2024 Weber Informatics LLC | Privacy Policy