diff options
author | Daniel Dunbar <daniel@zuster.org> | 2010-05-06 14:46:38 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2010-05-06 14:46:38 +0000 |
commit | 5fe03c023cd47a718759a3a4dc1d8e33297ae0fc (patch) | |
tree | 9a0e339dc81e4fe36c07507505414951e1e0206d /lib/MC/MCParser | |
parent | b63387afc6b10e88631d1ef232c41ab6c18c8581 (diff) | |
download | external_llvm-5fe03c023cd47a718759a3a4dc1d8e33297ae0fc.zip external_llvm-5fe03c023cd47a718759a3a4dc1d8e33297ae0fc.tar.gz external_llvm-5fe03c023cd47a718759a3a4dc1d8e33297ae0fc.tar.bz2 |
Revert r103137, fix for $ in labels. It looks like we can't actually handle this
at the token level. Consider the following horrible test case:
a = 1
.globl $a
movl ($a), %eax
movl $a, %eax
movl $$a, %eax
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103178 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/MC/MCParser')
-rw-r--r-- | lib/MC/MCParser/AsmLexer.cpp | 23 |
1 files changed, 7 insertions, 16 deletions
diff --git a/lib/MC/MCParser/AsmLexer.cpp b/lib/MC/MCParser/AsmLexer.cpp index f157a89..1183312 100644 --- a/lib/MC/MCParser/AsmLexer.cpp +++ b/lib/MC/MCParser/AsmLexer.cpp @@ -69,26 +69,16 @@ int AsmLexer::getNextChar() { } } -/// LexIdentifier: [a-zA-Z_.$][a-zA-Z0-9_$.@]* -/// LexIdentifier: . -/// LexIdentifier: $ +/// LexIdentifier: [a-zA-Z_.][a-zA-Z0-9_$.@]* AsmToken AsmLexer::LexIdentifier() { while (isalnum(*CurPtr) || *CurPtr == '_' || *CurPtr == '$' || *CurPtr == '.' || *CurPtr == '@') ++CurPtr; // Handle . as a special case. - if (CurPtr == TokStart+1) - if (TokStart[0] == '.') - return AsmToken(AsmToken::Dot, StringRef(TokStart, 1)); - - // Handle $ as a special case. $foo is an identifier, $42 is not. - if (TokStart[0] == '$' && - (CurPtr-TokStart == 1 || isdigit(TokStart[1]) || TokStart[1] == '"')) { - CurPtr = TokStart+1; - return AsmToken(AsmToken::Dollar, StringRef(TokStart, 1)); - } - + if (CurPtr == TokStart+1 && TokStart[0] == '.') + return AsmToken(AsmToken::Dot, StringRef(TokStart, 1)); + return AsmToken(AsmToken::Identifier, StringRef(TokStart, CurPtr - TokStart)); } @@ -262,8 +252,8 @@ AsmToken AsmLexer::LexToken() { switch (CurChar) { default: - // Handle identifier: [a-zA-Z_.$][a-zA-Z0-9_$.@]* - if (isalpha(CurChar) || CurChar == '_' || CurChar == '.' || CurChar == '$') + // Handle identifier: [a-zA-Z_.][a-zA-Z0-9_$.@]* + if (isalpha(CurChar) || CurChar == '_' || CurChar == '.') return LexIdentifier(); // Unknown character, emit an error. @@ -289,6 +279,7 @@ AsmToken AsmLexer::LexToken() { case '}': return AsmToken(AsmToken::RCurly, StringRef(TokStart, 1)); case '*': return AsmToken(AsmToken::Star, StringRef(TokStart, 1)); case ',': return AsmToken(AsmToken::Comma, StringRef(TokStart, 1)); + case '$': return AsmToken(AsmToken::Dollar, StringRef(TokStart, 1)); case '=': if (*CurPtr == '=') return ++CurPtr, AsmToken(AsmToken::EqualEqual, StringRef(TokStart, 2)); |