aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-01-17 06:29:33 +0000
committerChris Lattner <sabre@nondot.org>2009-01-17 06:29:33 +0000
commit6b7b84036126a8f2a3e312cfec0a9a4f8ae9d8ed (patch)
tree50bcfc6617efa112aa3896ec7b96512744b4cd63
parent2b2453a7d8fe732561795431f39ceb2b2a832d84 (diff)
suck the call to "getSpellingLoc" that all clients do into
the implementation of PTHManager::getSpelling. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62408 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/clang/Lex/Preprocessor.h1
-rw-r--r--lib/Lex/PTHLexer.cpp5
-rw-r--r--lib/Lex/Preprocessor.cpp6
3 files changed, 5 insertions, 7 deletions
diff --git a/include/clang/Lex/Preprocessor.h b/include/clang/Lex/Preprocessor.h
index e453fd04d6..3956725ffa 100644
--- a/include/clang/Lex/Preprocessor.h
+++ b/include/clang/Lex/Preprocessor.h
@@ -455,7 +455,6 @@ public:
/// location in the appropriate MemoryBuffer.
char getSpelledCharacterAt(SourceLocation SL) const {
if (PTH) {
- SL = SourceMgr.getSpellingLoc(SL);
const char *Data;
if (PTH->getSpelling(SL, Data))
return *Data;
diff --git a/lib/Lex/PTHLexer.cpp b/lib/Lex/PTHLexer.cpp
index b2870f46fd..fd7c367c70 100644
--- a/lib/Lex/PTHLexer.cpp
+++ b/lib/Lex/PTHLexer.cpp
@@ -311,8 +311,9 @@ unsigned PTHManager::getSpelling(FileID FID, unsigned FPos,
}
unsigned PTHManager::getSpelling(SourceLocation Loc, const char *&Buffer) {
- std::pair<FileID, unsigned> LocInfo =
- PP->getSourceManager().getDecomposedFileLoc(Loc);
+ SourceManager &SM = PP->getSourceManager();
+ Loc = SM.getSpellingLoc(Loc);
+ std::pair<FileID, unsigned> LocInfo = SM.getDecomposedFileLoc(Loc);
return getSpelling(LocInfo.first, LocInfo.second, Buffer);
}
diff --git a/lib/Lex/Preprocessor.cpp b/lib/Lex/Preprocessor.cpp
index 976e1a2f7a..ff84b0abf3 100644
--- a/lib/Lex/Preprocessor.cpp
+++ b/lib/Lex/Preprocessor.cpp
@@ -199,8 +199,7 @@ std::string Preprocessor::getSpelling(const Token &Tok) const {
const char* TokStart;
if (PTH) {
- SourceLocation SLoc = SourceMgr.getSpellingLoc(Tok.getLocation());
- if (unsigned Len = PTH->getSpelling(SLoc, TokStart)) {
+ if (unsigned Len = PTH->getSpelling(Tok.getLocation(), TokStart)) {
assert(!Tok.needsCleaning());
return std::string(TokStart, TokStart+Len);
}
@@ -254,8 +253,7 @@ unsigned Preprocessor::getSpelling(const Token &Tok,
if (CurPTHLexer) {
Len = CurPTHLexer.get()->getSpelling(Tok.getLocation(), Buffer);
} else {
- Len = PTH->getSpelling(SourceMgr.getSpellingLoc(Tok.getLocation()),
- Buffer);
+ Len = PTH->getSpelling(Tok.getLocation(), Buffer);
}
// Did we find a spelling? If so return its length. Otherwise fall