00001 /* 00002 [The "BSD licence"] 00003 Copyright (c) 2005-2008 Terence Parr 00004 All rights reserved. 00005 00006 Redistribution and use in source and binary forms, with or without 00007 modification, are permitted provided that the following conditions 00008 are met: 00009 1. Redistributions of source code must retain the above copyright 00010 notice, this list of conditions and the following disclaimer. 00011 2. Redistributions in binary form must reproduce the above copyright 00012 notice, this list of conditions and the following disclaimer in the 00013 documentation and/or other materials provided with the distribution. 00014 3. The name of the author may not be used to endorse or promote products 00015 derived from this software without specific prior written permission. 00016 00017 THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 00018 IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00019 OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 00020 IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 00021 INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 00022 NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 00023 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 00024 THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00025 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 00026 THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 package org.antlr.runtime.tree; 00029 00030 import org.antlr.runtime.Token; 00031 00042 public interface Tree { 00043 public static final Tree INVALID_NODE = new CommonTree(Token.INVALID_TOKEN); 00044 00045 Tree getChild(int i); 00046 00047 int getChildCount(); 00048 00049 // Tree tracks parent and child index now > 3.0 00050 00051 public Tree getParent(); 00052 00053 public void setParent(Tree t); 00054 00056 public int getChildIndex(); 00057 00058 public void setChildIndex(int index); 00059 00061 public void freshenParentAndChildIndexes(); 00062 00066 void addChild(Tree t); 00067 00069 public void setChild(int i, Tree t); 00070 00071 public Object deleteChild(int i); 00072 00078 public void replaceChildren(int startChildIndex, int stopChildIndex, Object t); 00079 00083 boolean isNil(); 00084 00088 int getTokenStartIndex(); 00089 00090 void setTokenStartIndex(int index); 00091 00095 int getTokenStopIndex(); 00096 00097 void setTokenStopIndex(int index); 00098 00099 Tree dupNode(); 00100 00102 int getType(); 00103 00104 String getText(); 00105 00107 int getLine(); 00108 00109 int getCharPositionInLine(); 00110 00111 String toStringTree(); 00112 00113 String toString(); 00114 }
1.5.5