/* * [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 + ">"; } } }