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 | |
| 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')
| -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(); +} +  | 

