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

org.apache.royale.compiler.tree.as.IASNode Maven / Gradle / Ivy

The newest version!
/*
 *
 *  Licensed to the Apache Software Foundation (ASF) under one or more
 *  contributor license agreements.  See the NOTICE file distributed with
 *  this work for additional information regarding copyright ownership.
 *  The ASF licenses this file to You under the Apache License, Version 2.0
 *  (the "License"); you may not use this file except in compliance with
 *  the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 */

package org.apache.royale.compiler.tree.as;

import org.apache.royale.compiler.common.ISourceLocation;
import org.apache.royale.compiler.filespecs.IFileSpecification;
import org.apache.royale.compiler.tree.ASTNodeID;

/**
 * The base interface for all AST (abstract syntax tree) nodes.
 */
public interface IASNode extends ISourceLocation /* extends IAdaptable */
{
    /**
     * Get the opcode of this node
     * 
     * @return the opcode - this is one of the constants defined in ASTConstants
     */
    ASTNodeID getNodeID();

    /**
     * Determine whether the offset fits within this node.
     * 
     * @param offset the offset to test
     * @return true if the offset is contained within this node
     */
    boolean contains(int offset);

    /**
     * Get the nearest ancestor of this node that has the specified type.
     * 
     * @param nodeType the node type for which to search
     * @return the nearest ancestor that has the specified type (null if no such
     * node exists)
     */
    IASNode getAncestorOfType(Class nodeType);

    /**
     * Get a particular child of this node
     * 
     * @param i the child's index
     * @return the specified child
     */
    IASNode getChild(int i);

    /**
     * Get the number of children
     * 
     * @return the number of children
     */
    int getChildCount();

    /**
     * Gets the child node that contains the offset
     * 
     * @param offset an offest
     * @return an IASNode or null
     */
    IASNode getContainingNode(int offset);

    /**
     * Gets the containing scope for this node
     * 
     * @return the current {@link IScopedNode}
     */
    IScopedNode getContainingScope();

    /**
     * Get package name that applies to this node. If this node doesn't reside
     * inside a package definition, this method will return null.
     * 
     * @return String containing fully-qualified package name
     */
    String getPackageName();

    /**
     * Get the parent of this node
     * 
     * @return the parent of this node
     */
    IASNode getParent();

    /**
     * Get the {@link IFileSpecification} that produced this node
     * 
     * @return the source of this node
     */
    IFileSpecification getFileSpecification();

    /**
     * Gets the local offset where the node starts, including any extra items that may
     * change the appearance of the node's start. These can include namespaces,
     * keywords, modifiers, etc
     * 
     * @return the start of the span
     */
    int getSpanningStart();

    /**
     * Get the first node that succeeds the offset (i.e. which starts after the
     * offset).
     * 
     * @param offset the offset for which to search
     * @return the most general node that starts after the offset (or null, if
     * the offset isn't contained within this node)
     */
    IASNode getSucceedingNode(int offset);

    /**
     * Determines if this node is a terminal node, meaning it cannot have
     * children
     * 
     * @return true if this node is terminal
     */
    boolean isTerminal();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy