#ifndef INC_Parser_hpp__ #define INC_Parser_hpp__ /** * SOFTWARE RIGHTS *

* ANTLR 2.6.0 MageLang Insitute, 1999 *

* We reserve no legal rights to the ANTLR--it is fully in the * public domain. An individual or company may do whatever * they wish with source code distributed with ANTLR or the * code generated by ANTLR, including the incorporation of * ANTLR, or its output, into commerical software. *

* We encourage users to develop software with ANTLR. However, * we do ask that credit is given to us for developing * ANTLR. By "credit", we mean that if you use ANTLR or * incorporate any source code into one of your programs * (commercial product, research project, or otherwise) that * you acknowledge this fact somewhere in the documentation, * research report, etc... If you like ANTLR and have * developed a nice tool with the output, please mention that * you developed it using ANTLR. In addition, we ask that the * headers remain intact in our source code. As long as these * guidelines are kept, we expect to continue enhancing this * system and expect to make other tools available as they are * completed. *

* The ANTLR gang: * @version ANTLR 2.6.0 MageLang Insitute, 1999 * @author Terence Parr, MageLang Institute * @author
John Lilley, Empathy Software * @author
Pete Wells */ #include "antlr/config.h" #include "antlr/BitSet.h" #include "antlr/TokenBuffer.h" #include "antlr/RecognitionException.h" #include "antlr/ASTFactory.h" #include "antlr/ParserSharedInputState.h" ANTLR_BEGIN_NAMESPACE(antlr) /**A generic ANTLR parser (LL(k) for k>=1) containing a bunch of * utility routines useful at any lookahead depth. We distinguish between * the LL(1) and LL(k) parsers because of efficiency. This may not be * necessary in the near future. * * Each parser object contains the state of the parse including a lookahead * cache (the form of which is determined by the subclass), whether or * not the parser is in guess mode, where tokens come from, etc... * *

* During guess mode, the current lookahead token(s) and token type(s) * cache must be saved because the token stream may not have been informed * to save the token (via mark) before the try block. * Guessing is started by: *

    *
  1. saving the lookahead cache. *
  2. marking the current position in the TokenBuffer. *
  3. increasing the guessing level. *
* * After guessing, the parser state is restored by: *
    *
  1. restoring the lookahead cache. *
  2. rewinding the TokenBuffer. *
  3. decreasing the guessing level. *
* * @see antlr.Token * @see antlr.TokenBuffer * @see antlr.TokenStream * @see antlr.LL1Parser * @see antlr.LLkParser */ extern bool DEBUG_PARSER; class Parser { protected: ParserSharedInputState inputState; /** Nesting level of registered handlers */ // int exceptionLevel; /** Table of token type to token names */ ANTLR_USE_NAMESPACE(std)vector tokenNames; /** AST return value for a rule is squirreled away here */ RefAST returnAST; /** AST support code; parser and treeparser delegate to this object */ ASTFactory astFactory; // Parser(); Parser(TokenBuffer& input_); Parser(TokenBuffer* input_); Parser(const ParserSharedInputState& state); public: virtual ~Parser(); protected: void setTokenNames(const char** tokenNames_); public: /**Get another token object from the token stream */ virtual void consume()=0; /** Consume tokens until one matches the given token */ void consumeUntil(int tokenType); /** Consume tokens until one matches the given token set */ void consumeUntil(const BitSet& set); /** Get the AST return value squirreled away in the parser */ RefAST getAST(); ASTFactory& getASTFactory(); ANTLR_USE_NAMESPACE(std)string getFilename() const; virtual ParserSharedInputState getInputState() const; ANTLR_USE_NAMESPACE(std)string getTokenName(int num) const; ANTLR_USE_NAMESPACE(std)vector getTokenNames() const; /** Return the token type of the ith token of lookahead where i=1 * is the current token being examined by the parser (i.e., it * has not been matched yet). */ virtual int LA(int i)=0; /**Return the ith token of lookahead */ virtual RefToken LT(int i)=0; // Forwarded to TokenBuffer virtual int mark(); /**Make sure current lookahead symbol matches token type t. * Throw an exception upon mismatch, which is catch by either the * error handler or by the syntactic predicate. */ void match(int t); /**Make sure current lookahead symbol matches the given set * Throw an exception upon mismatch, which is catch by either the * error handler or by the syntactic predicate. */ void match(const BitSet& b); void matchNot(int t); static void panic(); /** Parser error-reporting function can be overridden in subclass */ virtual void reportError(const RecognitionException& ex); /** Parser error-reporting function can be overridden in subclass */ virtual void reportError(const ANTLR_USE_NAMESPACE(std)string& s); /** Parser warning-reporting function can be overridden in subclass */ virtual void reportWarning(const ANTLR_USE_NAMESPACE(std)string& s); virtual void rewind(int pos); /** Set the object used to generate ASTs */ // void setASTFactory(ASTFactory astFactory_); /** Specify the type of node to create during tree building */ void setASTNodeFactory(ASTFactory::factory_type factory); void setFilename(const ANTLR_USE_NAMESPACE(std)string& f); void setInputState(ParserSharedInputState state); /** Set or change the input token buffer */ // void setTokenBuffer(TokenBuffer* t); virtual void traceIndent(); virtual void traceIn(const ANTLR_USE_NAMESPACE(std)string& rname); virtual void traceOut(const ANTLR_USE_NAMESPACE(std)string& rname); protected: int traceDepth; // used to keep track of the indentation for the trace protected: /** Utility class which allows tracing to work even when exceptions are * thrown. */ class Tracer { private: Parser* parser; ANTLR_USE_NAMESPACE(std)string text; public: Tracer(Parser* p,const ANTLR_USE_NAMESPACE(std)string& t) : parser(p), text(t) { parser->traceIn(text); } ~Tracer() { parser->traceOut(text); } private: Tracer(const Tracer&); // undefined const Tracer& operator=(const Tracer&); // undefined }; private: Parser(const Parser&); // undefined const Parser& operator=(const Parser&); // undefined }; ANTLR_END_NAMESPACE #endif //INC_Parser_hpp__