forked from OSchip/llvm-project
Cache AllowAtInIdentifier as class variable in AsmLexer
This commit caches the value of the AllowAtInIdentifier variable as a class variable in AsmLexer. We do this to avoid repeated MAI queries and string comparisons each time we lex an identifier. llvm-svn: 196622
This commit is contained in:
parent
9ca8df1e3f
commit
27aa001558
|
@ -30,6 +30,7 @@ class AsmLexer : public MCAsmLexer {
|
|||
const char *CurPtr;
|
||||
const MemoryBuffer *CurBuf;
|
||||
bool isAtStartOfLine;
|
||||
bool AllowAtInIdentifier; // Cached here to avoid repeated MAI query.
|
||||
|
||||
void operator=(const AsmLexer&) LLVM_DELETED_FUNCTION;
|
||||
AsmLexer(const AsmLexer&) LLVM_DELETED_FUNCTION;
|
||||
|
|
|
@ -25,6 +25,7 @@ AsmLexer::AsmLexer(const MCAsmInfo &_MAI) : MAI(_MAI) {
|
|||
CurBuf = NULL;
|
||||
CurPtr = NULL;
|
||||
isAtStartOfLine = true;
|
||||
AllowAtInIdentifier = !StringRef(MAI.getCommentString()).startswith("@");
|
||||
}
|
||||
|
||||
AsmLexer::~AsmLexer() {
|
||||
|
@ -144,7 +145,6 @@ static bool IsIdentifierChar(char c, bool AllowAt) {
|
|||
(c == '@' && AllowAt) || c == '?';
|
||||
}
|
||||
AsmToken AsmLexer::LexIdentifier() {
|
||||
bool AllowAtInIdentifier = !StringRef(MAI.getCommentString()).startswith("@");
|
||||
// Check for floating point literals.
|
||||
if (CurPtr[-1] == '.' && isdigit(*CurPtr)) {
|
||||
// Disambiguate a .1243foo identifier from a floating literal.
|
||||
|
|
Loading…
Reference in New Issue