1324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/*
2324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver [The "BSD licence"]
3324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver Copyright (c) 2005-2006 Terence Parr
4324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver All rights reserved.
5324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
6324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver Redistribution and use in source and binary forms, with or without
7324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver modification, are permitted provided that the following conditions
8324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver are met:
9324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 1. Redistributions of source code must retain the above copyright
10324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    notice, this list of conditions and the following disclaimer.
11324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 2. Redistributions in binary form must reproduce the above copyright
12324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    notice, this list of conditions and the following disclaimer in the
13324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    documentation and/or other materials provided with the distribution.
14324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 3. The name of the author may not be used to endorse or promote products
15324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    derived from this software without specific prior written permission.
16324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
17324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver*/
28324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverpackage org.antlr.runtime {
29324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    import org.antlr.runtime.tree.TreeAdaptor;
30324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
31324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	/** A parser for TokenStreams.  "parser grammars" result in a subclass
32324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	 *  of this.
33324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	 */
34324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	public class Parser extends BaseRecognizer {
35324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	    protected var input:TokenStream;
36324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
37324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public function Parser(input:TokenStream, state:RecognizerSharedState = null) {
38324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			super(state);
39324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			tokenStream = input;
40324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	    }
41324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
42324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public override function reset():void {
43324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			super.reset(); // reset all recognizer state variables
44324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			if ( input!=null ) {
45324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver				input.seek(0); // rewind the input
46324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			}
47324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
48324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
49324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		protected override function getCurrentInputSymbol(input:IntStream):Object {
50324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			return TokenStream(input).LT(1);
51324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
52324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
53324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		protected override function getMissingSymbol(input:IntStream,
54324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver										    e:RecognitionException,
55324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver										    expectedTokenType:int,
56324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver										    follow:BitSet):Object {
57324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		    var tokenText:String = null;
58324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver            if ( expectedTokenType==TokenConstants.EOF ) tokenText = "<missing EOF>";
59324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver            else tokenText = "<missing "+tokenNames[expectedTokenType]+">";
60324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			var t:CommonToken = new CommonToken(expectedTokenType, tokenText);
61324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			var current:Token = TokenStream(input).LT(1);
62324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			if ( current.type == TokenConstants.EOF ) {
63324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver				current = TokenStream(input).LT(-1);
64324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			}
65324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			t.line = current.line;
66324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			t.charPositionInLine = current.charPositionInLine;
67324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			t.channel = DEFAULT_TOKEN_CHANNEL;
68324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			return t;
69324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
70324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
71324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		/** Set the token stream and reset the parser */
72324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public function set tokenStream(input:TokenStream):void {
73324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			this.input = null;
74324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			reset();
75324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			this.input = input;
76324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
77324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
78324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	    public function get tokenStream():TokenStream {
79324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			return input;
80324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
81324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
82324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public override function get sourceName():String {
83324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			return input.sourceName;
84324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
85324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
86324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public function set treeAdaptor(adaptor:TreeAdaptor):void {
87324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		    // do nothing, implemented in generated code
88324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
89324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
90324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public function get treeAdaptor():TreeAdaptor {
91324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		    // implementation provided in generated code
92324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		    return null;
93324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
94324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
95324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public function traceIn(ruleName:String, ruleIndex:int):void  {
96324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			super.traceInSymbol(ruleName, ruleIndex, input.LT(1));
97324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
98324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
99324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		public function traceOut(ruleName:String, ruleIndex:int):void {
100324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver			super.traceOutSymbol(ruleName, ruleIndex, input.LT(1));
101324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver		}
102324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver	}
103324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
104324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}