// // Copyright (c) 2012 The ANGLE Project Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // #ifndef COMPILER_PREPROCESSOR_DIRECTIVE_PARSER_H_ #define COMPILER_PREPROCESSOR_DIRECTIVE_PARSER_H_ #include "Lexer.h" #include "Macro.h" #include "pp_utils.h" #include "SourceLocation.h" namespace pp { class Diagnostics; class DirectiveHandler; class Tokenizer; class DirectiveParser : public Lexer { public: DirectiveParser(Tokenizer* tokenizer, MacroSet* macroSet, Diagnostics* diagnostics, DirectiveHandler* directiveHandler); virtual void lex(Token* token); private: PP_DISALLOW_COPY_AND_ASSIGN(DirectiveParser); void parseDirective(Token* token); void parseDefine(Token* token); void parseUndef(Token* token); void parseIf(Token* token); void parseIfdef(Token* token); void parseIfndef(Token* token); void parseElse(Token* token); void parseElif(Token* token); void parseEndif(Token* token); void parseError(Token* token); void parsePragma(Token* token); void parseExtension(Token* token); void parseVersion(Token* token); void parseLine(Token* token); bool skipping() const; void parseConditionalIf(Token* token); int parseExpressionIf(Token* token); int parseExpressionIfdef(Token* token); struct ConditionalBlock { std::string type; SourceLocation location; bool skipBlock; bool skipGroup; bool foundValidGroup; bool foundElseGroup; ConditionalBlock() : skipBlock(false), skipGroup(false), foundValidGroup(false), foundElseGroup(false) { } }; bool mPastFirstStatement; std::vector mConditionalStack; Tokenizer* mTokenizer; MacroSet* mMacroSet; Diagnostics* mDiagnostics; DirectiveHandler* mDirectiveHandler; }; } // namespace pp #endif // COMPILER_PREPROCESSOR_DIRECTIVE_PARSER_H_