diff options
-rw-r--r-- | include/clang/Lex/PPCallbacks.h | 9 | ||||
-rw-r--r-- | lib/Lex/PPDirectives.cpp | 4 |
2 files changed, 11 insertions, 2 deletions
diff --git a/include/clang/Lex/PPCallbacks.h b/include/clang/Lex/PPCallbacks.h index cd7c5e4215..d2e3f353cb 100644 --- a/include/clang/Lex/PPCallbacks.h +++ b/include/clang/Lex/PPCallbacks.h @@ -55,10 +55,15 @@ public: const std::string &Str) { } - /// MacroExpands - This is called Preprocessor::HandleMacroExpandedIdentifier - /// when a macro invocation is found. + /// MacroExpands - This is called by + /// Preprocessor::HandleMacroExpandedIdentifier when a macro invocation is + /// found. virtual void MacroExpands(const Token &Id, const MacroInfo* MI) { } + + /// MacroDefined - This hook is called whenever a macro definition is seen. + virtual void MacroDefined(const IdentifierInfo *II, const MacroInfo *MI) { + } }; } // end namespace clang diff --git a/lib/Lex/PPDirectives.cpp b/lib/Lex/PPDirectives.cpp index ba321a7f67..52f673c6d3 100644 --- a/lib/Lex/PPDirectives.cpp +++ b/lib/Lex/PPDirectives.cpp @@ -1402,6 +1402,10 @@ void Preprocessor::HandleDefineDirective(Token &DefineTok) { } setMacroInfo(MacroNameTok.getIdentifierInfo(), MI); + + // If the callbacks want to know, tell them about the macro definition. + if (Callbacks) + Callbacks->MacroDefined(MacroNameTok.getIdentifierInfo(), MI); } /// HandleUndefDirective - Implements #undef. |