diff options
author | Anna Zaks <ganna@apple.com> | 2012-01-18 20:17:16 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2012-01-18 20:17:16 +0000 |
commit | 1bea4bf590fd9d67ad64e6014b543970bfbaeb0b (patch) | |
tree | 00f78587a77efdfa1acacc7242823df6252548ac /clang/lib/Lex/Lexer.cpp | |
parent | 1997de01004196910e75c7319c19efda64bb3af7 (diff) | |
download | bcm5719-llvm-1bea4bf590fd9d67ad64e6014b543970bfbaeb0b.tar.gz bcm5719-llvm-1bea4bf590fd9d67ad64e6014b543970bfbaeb0b.zip |
Refactor: Pull getImmediateMacroName() out of DiagnosticRenderer and
into Lexer and Preprocessor; making it widely available.
llvm-svn: 148410
Diffstat (limited to 'clang/lib/Lex/Lexer.cpp')
-rw-r--r-- | clang/lib/Lex/Lexer.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/clang/lib/Lex/Lexer.cpp b/clang/lib/Lex/Lexer.cpp index c320b3c222e..bb1bbbbe7e6 100644 --- a/clang/lib/Lex/Lexer.cpp +++ b/clang/lib/Lex/Lexer.cpp @@ -785,6 +785,27 @@ bool Lexer::isAtEndOfMacroExpansion(SourceLocation loc, return isAtEndOfMacroExpansion(expansionLoc, SM, LangOpts); } +StringRef Lexer::getImmediateMacroName(SourceLocation Loc, + const SourceManager &SM, + const LangOptions &LangOpts) { + assert(Loc.isMacroID() && "Only reasonble to call this on macros"); + // Walk past macro argument expanions. + while (SM.isMacroArgExpansion(Loc)) + Loc = SM.getImmediateExpansionRange(Loc).first; + + // Find the spelling location of the start of the non-argument expansion + // range. This is where the macro name was spelled in order to begin + // expanding this macro. + Loc = SM.getSpellingLoc(SM.getImmediateExpansionRange(Loc).first); + + // Dig out the buffer where the macro name was spelled and the extents of the + // name so that we can render it into the expansion note. + std::pair<FileID, unsigned> ExpansionInfo = SM.getDecomposedLoc(Loc); + unsigned MacroTokenLength = Lexer::MeasureTokenLength(Loc, SM, LangOpts); + StringRef ExpansionBuffer = SM.getBufferData(ExpansionInfo.first); + return ExpansionBuffer.substr(ExpansionInfo.second, MacroTokenLength); +} + //===----------------------------------------------------------------------===// // Character information. //===----------------------------------------------------------------------===// |