/*
* [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
{
using System.Collections.Generic;
using System.Collections.ObjectModel;
using ArgumentNullException = System.ArgumentNullException;
using Exception = System.Exception;
using SerializationInfo = System.Runtime.Serialization.SerializationInfo;
using StreamingContext = System.Runtime.Serialization.StreamingContext;
/** A mismatched char or Token or tree node */
[System.Serializable]
public class MismatchedTokenException : RecognitionException
{
private readonly int _expecting = TokenTypes.Invalid;
private readonly ReadOnlyCollection _tokenNames;
public MismatchedTokenException()
{
}
public MismatchedTokenException(string message)
: base(message)
{
}
public MismatchedTokenException(string message, Exception innerException)
: base(message, innerException)
{
}
public MismatchedTokenException(int expecting, IIntStream input)
: this(expecting, input, null)
{
}
public MismatchedTokenException(int expecting, IIntStream input, IList tokenNames)
: base(input)
{
this._expecting = expecting;
if (tokenNames != null)
this._tokenNames = new List(tokenNames).AsReadOnly();
}
public MismatchedTokenException(string message, int expecting, IIntStream input, IList tokenNames)
: base(message, input)
{
this._expecting = expecting;
if (tokenNames != null)
this._tokenNames = new List(tokenNames).AsReadOnly();
}
public MismatchedTokenException(string message, int expecting, IIntStream input, IList tokenNames, Exception innerException)
: base(message, input, innerException)
{
this._expecting = expecting;
if (tokenNames != null)
this._tokenNames = new List(tokenNames).AsReadOnly();
}
protected MismatchedTokenException(SerializationInfo info, StreamingContext context)
: base(info, context)
{
if (info == null)
throw new ArgumentNullException("info");
this._expecting = info.GetInt32("Expecting");
this._tokenNames = new ReadOnlyCollection((string[])info.GetValue("TokenNames", typeof(string[])));
}
public int Expecting
{
get
{
return _expecting;
}
}
public ReadOnlyCollection TokenNames
{
get
{
return _tokenNames;
}
}
public override void GetObjectData(SerializationInfo info, StreamingContext context)
{
if (info == null)
throw new ArgumentNullException("info");
base.GetObjectData(info, context);
info.AddValue("Expecting", _expecting);
info.AddValue("TokenNames", (_tokenNames != null) ? new List(_tokenNames).ToArray() : default(string[]));
}
public override string ToString()
{
int unexpectedType = UnexpectedType;
string unexpected = ( TokenNames != null && unexpectedType >= 0 && unexpectedType < TokenNames.Count ) ? TokenNames[unexpectedType] : unexpectedType.ToString();
string expected = ( TokenNames != null && Expecting >= 0 && Expecting < TokenNames.Count ) ? TokenNames[Expecting] : Expecting.ToString();
return "MismatchedTokenException(" + unexpected + "!=" + expected + ")";
}
}
}