diff options
author | Anna Zaks <ganna@apple.com> | 2012-01-20 00:11:12 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2012-01-20 00:11:12 +0000 |
commit | 43de767b55c079101a466027bf1c5acab698811d (patch) | |
tree | 062b586ccec9fff4e2093c2cb0fa811e3f42ab92 /clang/lib/StaticAnalyzer/Core/CheckerContext.cpp | |
parent | 9796f2aa565125fed90914cb97c7765ef1f738d4 (diff) | |
download | bcm5719-llvm-43de767b55c079101a466027bf1c5acab698811d.tar.gz bcm5719-llvm-43de767b55c079101a466027bf1c5acab698811d.zip |
[analyzer] Add a utility method that allows to find the macro name used
at the given location.
This could be useful when checkers' logic depends on whether a function
is called with a given macro argument.
llvm-svn: 148516
Diffstat (limited to 'clang/lib/StaticAnalyzer/Core/CheckerContext.cpp')
-rw-r--r-- | clang/lib/StaticAnalyzer/Core/CheckerContext.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp b/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp index cb272fb1c33..6aaa3773259 100644 --- a/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp +++ b/clang/lib/StaticAnalyzer/Core/CheckerContext.cpp @@ -14,6 +14,7 @@ #include "clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h" #include "clang/Basic/Builtins.h" +#include "clang/Lex/Lexer.h" using namespace clang; using namespace ento; @@ -53,3 +54,15 @@ bool CheckerContext::isCLibraryFunction(const FunctionDecl *FD, return false; } + +StringRef CheckerContext::getMacroNameOrSpelling(SourceLocation &Loc) { + if (!Loc.isMacroID()) { + SmallVector<char, 16> buf; + return Lexer::getSpelling(Loc, buf, getSourceManager(), getLangOptions()); + } else { + return Lexer::getImmediateMacroName(Loc, getSourceManager(), + getLangOptions()); + } + return StringRef(); +} + |