aboutsummaryrefslogtreecommitdiff
path: root/lib/Lex/PTHLexer.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-12-17 18:38:19 +0000
committerTed Kremenek <kremenek@apple.com>2008-12-17 18:38:19 +0000
commit1c13c4f87ebdf4309d9b9b75336f15301b8ec8ce (patch)
treed5cc03313c01ba64ee8029792928d7e6befaf6a6 /lib/Lex/PTHLexer.cpp
parentc9ca4a23b1d2a2d923b283e7022a39c7aa5e87b2 (diff)
Shadow CurPtr with a local variable in ReadToken.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@61145 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Lex/PTHLexer.cpp')
-rw-r--r--lib/Lex/PTHLexer.cpp18
1 files changed, 12 insertions, 6 deletions
diff --git a/lib/Lex/PTHLexer.cpp b/lib/Lex/PTHLexer.cpp
index 49c7078b75..2ec01b27eb 100644
--- a/lib/Lex/PTHLexer.cpp
+++ b/lib/Lex/PTHLexer.cpp
@@ -271,21 +271,27 @@ void PTHLexer::ReadToken(Token& T) {
// FIXME: Setting the flags directly should obviate this step.
T.startToken();
+ // Shadow CurPtr into an automatic variable so that Read8 doesn't load and
+ // store back into the instance variable.
+ const char *CurPtrShadow = CurPtr;
+
// Read the type of the token.
- T.setKind((tok::TokenKind) Read8(CurPtr));
+ T.setKind((tok::TokenKind) Read8(CurPtrShadow));
// Set flags. This is gross, since we are really setting multiple flags.
- T.setFlag((Token::TokenFlags) Read8(CurPtr));
+ T.setFlag((Token::TokenFlags) Read8(CurPtrShadow));
// Set the IdentifierInfo* (if any).
- T.setIdentifierInfo(PTHMgr.ReadIdentifierInfo(CurPtr));
+ T.setIdentifierInfo(PTHMgr.ReadIdentifierInfo(CurPtrShadow));
// Set the SourceLocation. Since all tokens are constructed using a
- // raw lexer, they will all be offseted from the same FileID.
- T.setLocation(SourceLocation::getFileLoc(FileID, Read32(CurPtr)));
+ // raw, they will all be offseted from the same FileID.
+ T.setLocation(SourceLocation::getFileLoc(FileID, Read32(CurPtrShadow)));
// Finally, read and set the length of the token.
- T.setLength(Read32(CurPtr));
+ T.setLength(Read32(CurPtrShadow));
+
+ CurPtr = CurPtrShadow;
}
//===----------------------------------------------------------------------===//