From 54f0a625b0eb9afeece652a8462755010d237c78 Mon Sep 17 00:00:00 2001 From: Daniel Dunbar Date: Fri, 24 Sep 2010 01:59:31 +0000 Subject: [PATCH] MC/Lexer: Add 'Real' token type for floating point literals. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114718 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/MC/MCParser/MCAsmLexer.h | 3 +++ lib/MC/MCParser/AsmLexer.cpp | 29 ++++++++++++++++++++++----- tools/llvm-mc/llvm-mc.cpp | 3 +++ 3 files changed, 30 insertions(+), 5 deletions(-) diff --git a/include/llvm/MC/MCParser/MCAsmLexer.h b/include/llvm/MC/MCParser/MCAsmLexer.h index d690e810bd3..b0039fe2bab 100644 --- a/include/llvm/MC/MCParser/MCAsmLexer.h +++ b/include/llvm/MC/MCParser/MCAsmLexer.h @@ -33,6 +33,9 @@ public: // Integer values. Integer, + // Real values. + Real, + // Register values (stored in IntVal). Only used by TargetAsmLexer. Register, diff --git a/lib/MC/MCParser/AsmLexer.cpp b/lib/MC/MCParser/AsmLexer.cpp index 086df081a93..59da3817c18 100644 --- a/lib/MC/MCParser/AsmLexer.cpp +++ b/lib/MC/MCParser/AsmLexer.cpp @@ -65,9 +65,21 @@ int AsmLexer::getNextChar() { } /// LexIdentifier: [a-zA-Z_.][a-zA-Z0-9_$.@]* +static bool IsIdentifierChar(char c) { + return isalnum(c) || c == '_' || c == '$' || c == '.' || c == '@'; +} AsmToken AsmLexer::LexIdentifier() { - while (isalnum(*CurPtr) || *CurPtr == '_' || *CurPtr == '$' || - *CurPtr == '.' || *CurPtr == '@') + // Check for floating point literals. + if (CurPtr[-1] == '.' && isdigit(*CurPtr)) { + while (isdigit(*CurPtr)) + ++CurPtr; + if (!IsIdentifierChar(*CurPtr)) { + return AsmToken(AsmToken::Real, + StringRef(TokStart, CurPtr - TokStart)); + } + } + + while (IsIdentifierChar(*CurPtr)) ++CurPtr; // Handle . as a special case. @@ -124,7 +136,6 @@ static void SkipIgnoredIntegerSuffix(const char *&CurPtr) { CurPtr += 3; } - /// LexDigit: First character is [0-9]. /// Local Label: [0-9][:] /// Forward/Backward Label: [0-9][fb] @@ -132,13 +143,21 @@ static void SkipIgnoredIntegerSuffix(const char *&CurPtr) { /// Octal integer: 0[0-7]+ /// Hex integer: 0x[0-9a-fA-F]+ /// Decimal integer: [1-9][0-9]* -/// TODO: FP literal. AsmToken AsmLexer::LexDigit() { // Decimal integer: [1-9][0-9]* if (CurPtr[-1] != '0') { while (isdigit(*CurPtr)) ++CurPtr; - + + // Check for floating point literals. + if (*CurPtr == '.') { + ++CurPtr; + while (isdigit(*CurPtr)) + ++CurPtr; + + return AsmToken(AsmToken::Real, StringRef(TokStart, CurPtr - TokStart)); + } + StringRef Result(TokStart, CurPtr - TokStart); long long Value; diff --git a/tools/llvm-mc/llvm-mc.cpp b/tools/llvm-mc/llvm-mc.cpp index 424cc08890d..6622f94d89c 100644 --- a/tools/llvm-mc/llvm-mc.cpp +++ b/tools/llvm-mc/llvm-mc.cpp @@ -208,6 +208,9 @@ static int AsLexInput(const char *ProgName) { case AsmToken::Integer: Out->os() << "int: " << Lexer.getTok().getString() << '\n'; break; + case AsmToken::Real: + Out->os() << "real: " << Lexer.getTok().getString() << '\n'; + break; case AsmToken::Register: Out->os() << "register: " << Lexer.getTok().getRegVal() << '\n'; break;