Class ExpressionStatement

All Implemented Interfaces:
Comparable<AstNode>, 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 Details

    • 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:
      IllegalArgumentException - if expr is null
  • Method Details

    • 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:
      IllegalArgumentException - } if expression is null
    • hasSideEffects

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

      public 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