Class XmlMemberGet

All Implemented Interfaces:
Comparable<AstNode>, Iterable<Node>

public class XmlMemberGet extends InfixExpression
AST node for E4X ".@" and ".." expressions, such as foo..bar, foo..@bar, @foo.@bar, and foo..@ns::*. The right-hand node is always an XmlRef.

Node type is Token.DOT or Token.DOTDOT.

  • Constructor Details

    • XmlMemberGet

      public XmlMemberGet()
    • XmlMemberGet

      public XmlMemberGet(int pos)
    • XmlMemberGet

      public XmlMemberGet(int pos, int len)
    • XmlMemberGet

      public XmlMemberGet(int pos, int len, AstNode target, XmlRef ref)
    • XmlMemberGet

      public XmlMemberGet(AstNode target, XmlRef ref)
      Constructs a new XmlMemberGet node. Updates bounds to include target and ref nodes.
    • XmlMemberGet

      public XmlMemberGet(AstNode target, XmlRef ref, int opPos)
  • Method Details

    • getTarget

      public AstNode getTarget()
      Returns the object on which the XML member-ref expression is being evaluated. Should never be null.
    • setTarget

      public void setTarget(AstNode target)
      Sets target object, and sets its parent to this node.
      Throws:
      IllegalArgumentException - if target is null
    • getMemberRef

      public XmlRef getMemberRef()
      Returns the right-side XML member ref expression. Should never be null unless the code is malformed.
    • setProperty

      public void setProperty(XmlRef ref)
      Sets the XML member-ref expression, and sets its parent to this node.
      Throws:
      IllegalArgumentException - if property is null
    • 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.

      Overrides:
      toSource in class InfixExpression
      Parameters:
      depth - the current recursion depth, typically beginning at 0 when called on the root node.