/* * [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.Debug { using Obsolete = System.ObsoleteAttribute; using ITreeAdaptor = Antlr.Runtime.Tree.ITreeAdaptor; using ITreeNodeStream = Antlr.Runtime.Tree.ITreeNodeStream; /** <summary> * Debug any tree node stream. The constructor accepts the stream * and a debug listener. As node stream calls come in, debug events * are triggered. * </summary> */ public class DebugTreeNodeStream : ITreeNodeStream { protected IDebugEventListener dbg; protected ITreeAdaptor adaptor; protected ITreeNodeStream input; protected bool initialStreamState = true; /** <summary>Track the last mark() call result value for use in rewind().</summary> */ protected int lastMarker; public DebugTreeNodeStream(ITreeNodeStream input, IDebugEventListener dbg) { this.input = input; this.adaptor = input.TreeAdaptor; this.input.UniqueNavigationNodes = true; DebugListener = dbg; } #region Properties public virtual IDebugEventListener DebugListener { get { return dbg; } set { dbg = value; } } public virtual int Index { get { return input.Index; } } public virtual ITokenStream TokenStream { get { return input.TokenStream; } } public virtual ITreeAdaptor TreeAdaptor { get { return adaptor; } } public virtual object TreeSource { get { return input; } } /** <summary> * It is normally this object that instructs the node stream to * create unique nav nodes, but to satisfy interface, we have to * define it. It might be better to ignore the parameter but * there might be a use for it later, so I'll leave. * </summary> */ public bool UniqueNavigationNodes { get { return input.UniqueNavigationNodes; } set { input.UniqueNavigationNodes = value; } } #endregion public virtual void Consume() { object node = input.LT(1); input.Consume(); dbg.ConsumeNode(node); } public virtual object this[int i] { get { return input[i]; } } public virtual object LT(int i) { object node = input.LT(i); int ID = adaptor.GetUniqueID(node); string text = adaptor.GetText(node); int type = adaptor.GetType(node); dbg.LT(i, node); return node; } public virtual int LA(int i) { object node = input.LT(i); int ID = adaptor.GetUniqueID(node); string text = adaptor.GetText(node); int type = adaptor.GetType(node); dbg.LT(i, node); return type; } public virtual int Mark() { lastMarker = input.Mark(); dbg.Mark(lastMarker); return lastMarker; } public virtual void Rewind(int marker) { dbg.Rewind(marker); input.Rewind(marker); } public virtual void Rewind() { dbg.Rewind(); input.Rewind(lastMarker); } public virtual void Release(int marker) { } public virtual void Seek(int index) { // TODO: implement seek in dbg interface // db.seek(index); input.Seek(index); } public virtual int Count { get { return input.Count; } } public virtual string SourceName { get { return TokenStream.SourceName; } } public virtual void ReplaceChildren(object parent, int startChildIndex, int stopChildIndex, object t) { input.ReplaceChildren(parent, startChildIndex, stopChildIndex, t); } public virtual string ToString(object start, object stop) { return input.ToString(start, stop); } } }