| /* |
| * [The "BSD licence"] |
| * Copyright (c) 2005-2008 Terence Parr |
| * All rights reserved. |
| * |
| * Conversion to C#: |
| * Copyright (c) 2008-2009 Sam Harwell, Pixel Mine, Inc. |
| * All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * 3. The name of the author may not be used to endorse or promote products |
| * derived from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR |
| * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES |
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. |
| * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, |
| * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT |
| * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
| * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| namespace Antlr.Runtime.Tree |
| { |
| |
| /** <summary>A node representing erroneous token range in token stream</summary> */ |
| [System.Serializable] |
| public class CommonErrorNode : CommonTree |
| { |
| public IIntStream input; |
| public IToken start; |
| public IToken stop; |
| public RecognitionException trappedException; |
| |
| public CommonErrorNode( ITokenStream input, IToken start, IToken stop, |
| RecognitionException e ) |
| { |
| //System.out.println("start: "+start+", stop: "+stop); |
| if ( stop == null || |
| ( stop.TokenIndex < start.TokenIndex && |
| stop.Type != TokenTypes.EndOfFile ) ) |
| { |
| // sometimes resync does not consume a token (when LT(1) is |
| // in follow set. So, stop will be 1 to left to start. adjust. |
| // Also handle case where start is the first token and no token |
| // is consumed during recovery; LT(-1) will return null. |
| stop = start; |
| } |
| this.input = input; |
| this.start = start; |
| this.stop = stop; |
| this.trappedException = e; |
| } |
| |
| #region Properties |
| public override bool IsNil |
| { |
| get |
| { |
| return false; |
| } |
| } |
| public override string Text |
| { |
| get |
| { |
| string badText = null; |
| if ( start is IToken ) |
| { |
| int i = ( (IToken)start ).TokenIndex; |
| int j = ( (IToken)stop ).TokenIndex; |
| if ( ( (IToken)stop ).Type == TokenTypes.EndOfFile ) |
| { |
| j = ( (ITokenStream)input ).Count; |
| } |
| badText = ( (ITokenStream)input ).ToString( i, j ); |
| } |
| else if ( start is ITree ) |
| { |
| badText = ( (ITreeNodeStream)input ).ToString( start, stop ); |
| } |
| else |
| { |
| // people should subclass if they alter the tree type so this |
| // next one is for sure correct. |
| badText = "<unknown>"; |
| } |
| return badText; |
| } |
| set |
| { |
| } |
| } |
| public override int Type |
| { |
| get |
| { |
| return TokenTypes.Invalid; |
| } |
| set |
| { |
| } |
| } |
| #endregion |
| |
| public override string ToString() |
| { |
| if ( trappedException is MissingTokenException ) |
| { |
| return "<missing type: " + |
| ( (MissingTokenException)trappedException ).MissingType + |
| ">"; |
| } |
| else if ( trappedException is UnwantedTokenException ) |
| { |
| return "<extraneous: " + |
| ( (UnwantedTokenException)trappedException ).UnexpectedToken + |
| ", resync=" + Text + ">"; |
| } |
| else if ( trappedException is MismatchedTokenException ) |
| { |
| return "<mismatched token: " + trappedException.Token + ", resync=" + Text + ">"; |
| } |
| else if ( trappedException is NoViableAltException ) |
| { |
| return "<unexpected: " + trappedException.Token + |
| ", resync=" + Text + ">"; |
| } |
| return "<error: " + Text + ">"; |
| } |
| } |
| } |