Examples of AstNode

  • org.eclipse.dltk.ast.ASTNode
  • org.eclipse.jdt.core.dom.ASTNode
    Abstract superclass of all Abstract Syntax Tree (AST) node types.

    An AST node represents a Java source code construct, such as a name, type, expression, statement, or declaration.

    Each AST node belongs to a unique AST instance, called the owning AST. The children of an AST node always have the same owner as their parent node. If a node from one AST is to be added to a different AST, the subtree must be cloned first to ensure that the added nodes have the correct owning AST.

    When an AST node is part of an AST, it has a unique parent node. Clients can navigate upwards, from child to parent, as well as downwards, from parent to child. Newly created nodes are unparented. When an unparented node is set as a child of a node (using a setCHILD method), its parent link is set automatically and the parent link of the former child is set to null. For nodes with properties that include a list of children (for example, Block whose statements property is a list of statements), adding or removing an element to/for the list property automatically updates the parent links. These lists support the List.set method; however, the constraint that the same node cannot appear more than once means that this method cannot be used to swap elements without first removing the node.

    ASTs must not contain cycles. All operations that could create a cycle detect this possibility and fail.

    ASTs do not contain "holes" (missing subtrees). If a node is required to have a certain property, a syntactically plausible initial value is always supplied.

    The hierarchy of AST node types has some convenient groupings marked by abstract superclasses:

    Abstract syntax trees may be hand constructed by clients, using the newTYPE factory methods (see AST) to create new nodes, and the various setCHILD methods to connect them together.

    The class {@link ASTParser} parses a stringcontaining a Java source code and returns an abstract syntax tree for it. The resulting nodes carry source ranges relating the node back to the original source characters. The source range covers the construct as a whole.

    Each AST node carries bit flags, which may convey additional information about the node. For instance, the parser uses a flag to indicate a syntax error. Newly created nodes have no flags set.

    Each AST node is capable of carrying an open-ended collection of client-defined properties. Newly created nodes have none. getProperty and setProperty are used to access these properties.

    AST nodes are thread-safe for readers provided there are no active writers. If one thread is modifying an AST, including creating new nodes or cloning existing ones, it is not safe for another thread to read, visit, write, create, or clone any of the nodes on the same AST. When synchronization is required, consider using the common AST object that owns the node; that is, use synchronize (node.getAST()) {...}.

    ASTs also support the visitor pattern; see the class ASTVisitor for details. The NodeFinder class can be used to find a specific node inside a tree.

    Compilation units created by ASTParser from a source document can be serialized after arbitrary modifications with minimal loss of original formatting. See {@link CompilationUnit#recordModifications()} for details.See also {@link org.eclipse.jdt.core.dom.rewrite.ASTRewrite} foran alternative way to describe and serialize changes to a read-only AST.

    @see ASTParser @see ASTVisitor @see NodeFinder @since 2.0 @noextend This class is not intended to be subclassed by clients.
  • org.eclipse.jdt.internal.compiler.ast.ASTNode
  • org.eclipse.php.internal.core.ast.nodes.ASTNode
    Abstract superclass of all Abstract Syntax Tree (AST) node types.

    An AST node represents a PHP source code construct, such as a name, type, expression, statement, or declaration.

    ASTs do not contain cycles.

    @see Visitable @author Modhe S., Roy G. ,2007

  • org.erlide.engine.new_model.internal.ASTNode
  • org.jboss.dna.sequencer.ddl.node.AstNode
    Utility object class designed to facilitate constructing an AST or Abstract Syntax Tree representing nodes and properties that are compatible with DNA graph component structure.
  • org.modeshape.sequencer.ddl.node.AstNode
    Utility object class designed to facilitate constructing an AST or Abstract Syntax Tree representing nodes and properties that are compatible with ModeShape graph component structure.
  • org.mozilla.javascript.ast.AstNode
    Base class for AST node types. The goal of the AST is to represent the physical source code, to make it useful for code-processing tools such as IDEs or pretty-printers. The parser must not rewrite the parse tree when producing this representation.

    The {@code AstNode} hierarchy sits atop the older {@link Node} class,which was designed for code generation. The {@code Node} class is aflexible, weakly-typed class suitable for creating and rewriting code trees, but using it requires you to remember the exact ordering of the child nodes, which are kept in a linked list. The {@code AstNode}hierarchy is a strongly-typed facade with named accessors for children and common properties, but under the hood it's still using a linked list of child nodes. It isn't a very good idea to use the child list directly unless you know exactly what you're doing.

    Note that {@code AstNode} records additional information, includingthe node's position, length, and parent node. Also, some {@code AstNode}subclasses record some of their child nodes in instance members, since they are not needed for code generation. In a nutshell, only the code generator should be mixing and matching {@code AstNode} and {@code Node}objects.

    All offset fields in all subclasses of AstNode are relative to their parent. For things like paren, bracket and keyword positions, the position is relative to the current node. The node start position is relative to the parent node.

    During the actual parsing, node positions are absolute; adding the node to its parent fixes up the offsets to be relative. By the time you see the AST (e.g. using the {@code Visitor} interface), the offsets are relative.

    {@code AstNode} objects have property lists accessible via the{@link #getProp} and {@link #putProp} methods. The property lists areinteger-keyed with arbitrary {@code Object} values. For the most part theparser generating the AST avoids using properties, preferring fields for elements that are always set. Property lists are intended for user-defined annotations to the tree. The Rhino code generator acts as a client and uses node properties extensively. You are welcome to use the property-list API for anything your client needs.

    This hierarchy does not have separate branches for expressions and statements, as the distinction in JavaScript is not as clear-cut as in Java or C++.

  • org.mvel2.ast.ASTNode
  • org.netbeans.api.languages.ASTNode
  • org.openntf.formula.ASTNode
    represents an AST node and is returned by a parser.parse (as root of the AST-Node) @author Roland Praml, Foconis AG
  • org.sbml.jsbml.ASTNode
    A node in the Abstract Syntax Tree (AST) representation of a mathematical expression. @author Andreas Dräger @author Nicolas Rodriguez @author Alexander Dörr @since 0.8 @version $Rev: 1533 $
  • sicel.compiler.parser.ASTNode
  • symboltable.ASTNode

  • Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

        if (this.listEntries == null) {
          // create if not yet existing
          int nNodes= this.originalNodes.size();
          this.listEntries= new ArrayList(nNodes * 2);
          for (int i= 0; i < nNodes; i++) {
            ASTNode node= (ASTNode) this.originalNodes.get(i);
            // all nodes unchanged
            this.listEntries.add(new NodeRewriteEvent(node, node));
          }
        }
        return this.listEntries;
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

      }
      public void setLeft(PointcutDesignator left) {
        if (left == null) {
          throw new IllegalArgumentException();
        }
        ASTNode oldChild = this.left;
        preReplaceChild(oldChild, left, LEFT_PROPERTY);
        this.left = left;
        postReplaceChild(oldChild, left, LEFT_PROPERTY);
      }
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

      }
      public void setRight(PointcutDesignator right) {
        if (right == null) {
          throw new IllegalArgumentException();
        }
        ASTNode oldChild = this.right;
        preReplaceChild(oldChild, right, RIGHT_PROPERTY);
        this.right = right;
        postReplaceChild(oldChild, right, RIGHT_PROPERTY);
      }
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

      private void deleteElement(IJavaElement elementToRemove, ICompilationUnit cu) throws JavaModelException {
        // ensure cu is consistent (noop if already consistent)
        cu.makeConsistent(this.progressMonitor);
        this.parser.setSource(cu);
        CompilationUnit astCU = (CompilationUnit) this.parser.createAST(this.progressMonitor);
        ASTNode node = ((JavaElement) elementToRemove).findNode(astCU);
        if (node == null)
          Assert.isTrue(false, "Failed to locate " + elementToRemove.getElementName() + " in " + cu.getElementName()); //$NON-NLS-1$//$NON-NLS-2$
        IDocument document = getDocument(cu);
        AST ast = astCU.getAST();
        ASTRewrite rewriter = ASTRewrite.create(ast);
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

       * @param nodeType Type of the node to create. Use the type constants in {@link NodeInfoStore}.
       * @return Returns a place holder node.
       */
      public final ASTNode newPlaceholderNode(int nodeType) {
          try {
            ASTNode node= this.ast.createInstance(nodeType);
            switch (node.getNodeType()) {
            case ASTNode.FIELD_DECLARATION:
                ((FieldDeclaration) node).fragments().add(this.ast.newVariableDeclarationFragment());
                break;
            case ASTNode.MODIFIER:
                ((Modifier) node).setKeyword(Modifier.ModifierKeyword.ABSTRACT_KEYWORD);
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

          this.foundBinding = node.resolveBinding();
        return true;
      }
     
      public boolean visit(AnonymousClassDeclaration node) {
        ASTNode name;
        ASTNode parent = node.getParent();
        switch (parent.getNodeType()) {
          case ASTNode.CLASS_INSTANCE_CREATION:
            name = ((ClassInstanceCreation) parent).getType();
            break;
          case ASTNode.ENUM_CONSTANT_DECLARATION:
            name = ((EnumConstantDeclaration) parent).getName();
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

    }
    public ASTNode findNode(org.aspectj.org.eclipse.jdt.core.dom.CompilationUnit ast) {
      // For field declarations, a variable declaration fragment is returned
      // Return the FieldDeclaration instead
      // For enum constant declaration, we return the node directly
      ASTNode node = super.findNode(ast);
      if (node == null) return null;
      if (node.getNodeType() == ASTNode.ENUM_CONSTANT_DECLARATION) {
        return node;
      }
      return node.getParent();
    }
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.core.dom.ASTNode

        this.cuAST = parse(cu);
       
        AST ast = this.cuAST.getAST();
        ASTRewrite rewriter = ASTRewrite.create(ast);
        IDocument document = getDocument(cu);
        ASTNode child = generateElementAST(rewriter, document, cu);
        if (child != null) {
          ASTNode parent = ((JavaElement) getParentElement()).findNode(this.cuAST);
          if (parent == null)
            parent = this.cuAST;
          insertASTNode(rewriter, parent, child);
          apply(rewriter, document, cu.getJavaProject().getOptions(true));
        }
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode

        }

        traversedContext.recordReturnFrom(flowInfo.unconditionalInits());
       
        if (traversedContext instanceof InsideSubRoutineFlowContext) {
          ASTNode node = traversedContext.associatedNode;
          if (node instanceof TryStatement) {
            TryStatement tryStatement = (TryStatement) node;
            flowInfo.addInitializationsFrom(tryStatement.subRoutineInits); // collect inits     
          }
        }
    View Full Code Here

    Examples of org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode

          return;
         
        traversedContext.recordReturnFrom(flowInfo.unconditionalInits());
       
        if (traversedContext instanceof InsideSubRoutineFlowContext) {
          ASTNode node = traversedContext.associatedNode;
          if (node instanceof TryStatement) {
            TryStatement tryStatement = (TryStatement) node;
            flowInfo.addInitializationsFrom(tryStatement.subRoutineInits); // collect inits     
          }
        }   
    View Full Code Here
    TOP
    Copyright © 2018 www.massapi.com. All rights reserved.
    All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.