Class ExpressionStatement

  • All Implemented Interfaces:
    java.lang.Comparable<AstNode>, java.lang.Iterable<Node>

    public class ExpressionStatement
    extends AstNode
    AST node representing an expression in a statement context. The node type is Token.EXPR_VOID if inside a function, or else Token.EXPR_RESULT if inside a script.
    • Constructor Detail

      • ExpressionStatement

        public ExpressionStatement()
      • ExpressionStatement

        public ExpressionStatement​(AstNode expr,
                                   boolean hasResult)
        Constructs a new ExpressionStatement wrapping the specified expression. Sets this node's position to the position of the wrapped node, and sets the wrapped node's position to zero. Sets this node's length to the length of the wrapped node.
        Parameters:
        expr - the wrapped expression
        hasResult - true if this expression has side effects. If true, sets node type to EXPR_RESULT, else to EXPR_VOID.
      • ExpressionStatement

        public ExpressionStatement​(AstNode expr)
        Constructs a new ExpressionStatement wrapping the specified expression. Sets this node's position to the position of the wrapped node, and sets the wrapped node's position to zero. Sets this node's length to the length of the wrapped node.
        Parameters:
        expr - the wrapped expression
      • ExpressionStatement

        public ExpressionStatement​(int pos,
                                   int len)
      • ExpressionStatement

        public ExpressionStatement​(int pos,
                                   int len,
                                   AstNode expr)
        Constructs a new ExpressionStatement
        Parameters:
        expr - the wrapped AstNode. The ExpressionStatement's bounds are set to those of expr, and expr's parent is set to this node.
        Throws:
        java.lang.IllegalArgumentException - if expr is null
    • Method Detail

      • setHasResult

        public void setHasResult()
        Called by the parser to set node type to EXPR_RESULT if this node is not within a Function.
      • getExpression

        public AstNode getExpression()
        Returns the wrapped expression
      • setExpression

        public void setExpression​(AstNode expression)
        Sets the wrapped expression, and sets its parent to this node.
        Throws:
        java.lang.IllegalArgumentException - } if expression is null
      • hasSideEffects

        public boolean hasSideEffects()
        Returns true if this node has side effects
        Overrides:
        hasSideEffects in class AstNode
        Throws:
        java.lang.IllegalStateException - if expression has not yet been set.
      • toSource

        public java.lang.String toSource​(int depth)
        Description copied from class: AstNode
        Emits source code for this node. Callee is responsible for calling this function recursively on children, incrementing indent as appropriate.

        Note: if the parser was in error-recovery mode, some AST nodes may have null children that are expected to be non-null when no errors are present. In this situation, the behavior of the toSource method is undefined: toSource implementations may assume that the AST node is error-free, since it is intended to be invoked only at runtime after a successful parse.

        Specified by:
        toSource in class AstNode
        Parameters:
        depth - the current recursion depth, typically beginning at 0 when called on the root node.
      • visit

        public void visit​(NodeVisitor v)
        Visits this node, then the wrapped statement.
        Specified by:
        visit in class AstNode
        Parameters:
        v - the object to call with this node and its children