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.debug; 00029 00030 import org.antlr.runtime.RecognitionException; 00031 import org.antlr.runtime.Token; 00032 import org.antlr.runtime.tree.ParseTree; 00033 00034 import java.util.Stack; 00035 import java.util.ArrayList; 00036 import java.util.List; 00037 00041 public class ParseTreeBuilder extends BlankDebugEventListener { 00042 public static final String EPSILON_PAYLOAD = "<epsilon>"; 00043 00044 Stack callStack = new Stack(); 00045 List hiddenTokens = new ArrayList(); 00046 int backtracking = 0; 00047 00048 public ParseTreeBuilder(String grammarName) { 00049 ParseTree root = create("<grammar "+grammarName+">"); 00050 callStack.push(root); 00051 } 00052 00053 public ParseTree getTree() { 00054 return (ParseTree)callStack.elementAt(0); 00055 } 00056 00060 public ParseTree create(Object payload) { 00061 return new ParseTree(payload); 00062 } 00063 00064 public ParseTree epsilonNode() { 00065 return create(EPSILON_PAYLOAD); 00066 } 00067 00069 public void enterDecision(int d) { backtracking++; } 00070 public void exitDecision(int i) { backtracking--; } 00071 00072 public void enterRule(String filename, String ruleName) { 00073 if ( backtracking>0 ) return; 00074 ParseTree parentRuleNode = (ParseTree)callStack.peek(); 00075 ParseTree ruleNode = create(ruleName); 00076 parentRuleNode.addChild(ruleNode); 00077 callStack.push(ruleNode); 00078 } 00079 00080 public void exitRule(String filename, String ruleName) { 00081 if ( backtracking>0 ) return; 00082 ParseTree ruleNode = (ParseTree)callStack.peek(); 00083 if ( ruleNode.getChildCount()==0 ) { 00084 ruleNode.addChild(epsilonNode()); 00085 } 00086 callStack.pop(); 00087 } 00088 00089 public void consumeToken(Token token) { 00090 if ( backtracking>0 ) return; 00091 ParseTree ruleNode = (ParseTree)callStack.peek(); 00092 ParseTree elementNode = create(token); 00093 elementNode.hiddenTokens = this.hiddenTokens; 00094 this.hiddenTokens = new ArrayList(); 00095 ruleNode.addChild(elementNode); 00096 } 00097 00098 public void consumeHiddenToken(Token token) { 00099 if ( backtracking>0 ) return; 00100 hiddenTokens.add(token); 00101 } 00102 00103 public void recognitionException(RecognitionException e) { 00104 if ( backtracking>0 ) return; 00105 ParseTree ruleNode = (ParseTree)callStack.peek(); 00106 ParseTree errorNode = create(e); 00107 ruleNode.addChild(errorNode); 00108 } 00109 }
1.5.5