From 36e0212c163c931f11970192788f8b24d2489daa Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 21 Jun 2009 20:54:55 +0000 Subject: [PATCH] set up the top-level parsing loop. llvm-svn: 73860 --- llvm/tools/llvm-mc/AsmLexer.h | 2 ++ llvm/tools/llvm-mc/AsmParser.cpp | 54 ++++++++++++++++++++++++++++++++ llvm/tools/llvm-mc/AsmParser.h | 3 ++ 3 files changed, 59 insertions(+) diff --git a/llvm/tools/llvm-mc/AsmLexer.h b/llvm/tools/llvm-mc/AsmLexer.h index c5d1722e491d..c668e8639cdc 100644 --- a/llvm/tools/llvm-mc/AsmLexer.h +++ b/llvm/tools/llvm-mc/AsmLexer.h @@ -73,6 +73,8 @@ public: } asmtok::TokKind getKind() const { return CurKind; } + bool is(asmtok::TokKind K) const { return CurKind == K; } + bool isNot(asmtok::TokKind K) const { return CurKind != K; } const std::string &getCurStrVal() const { assert((CurKind == asmtok::Identifier || CurKind == asmtok::Register || diff --git a/llvm/tools/llvm-mc/AsmParser.cpp b/llvm/tools/llvm-mc/AsmParser.cpp index abb0d35b0865..9c0b4abb076b 100644 --- a/llvm/tools/llvm-mc/AsmParser.cpp +++ b/llvm/tools/llvm-mc/AsmParser.cpp @@ -12,8 +12,62 @@ //===----------------------------------------------------------------------===// #include "AsmParser.h" +#include "llvm/Support/SourceMgr.h" +#include "llvm/Support/raw_ostream.h" using namespace llvm; bool AsmParser::Run() { + // Prime the lexer. + Lexer.Lex(); + + while (Lexer.isNot(asmtok::Eof)) + if (ParseStatement()) + return true; + + return false; +} + + +/// ParseStatement: +/// ::= EndOfStatement +/// ::= Label* Identifier Operands* EndOfStatement +bool AsmParser::ParseStatement() { + switch (Lexer.getKind()) { + default: + Lexer.PrintError(Lexer.getLoc(), "unexpected token at start of statement"); + return true; + case asmtok::EndOfStatement: + Lexer.Lex(); + return false; + case asmtok::Identifier: + break; + // TODO: Recurse on local labels etc. + } + + // If we have an identifier, handle it as the key symbol. + //SMLoc IDLoc = Lexer.getLoc(); + std::string IDVal = Lexer.getCurStrVal(); + + // Consume the identifier, see what is after it. + if (Lexer.Lex() == asmtok::Colon) { + // identifier ':' -> Label. + Lexer.Lex(); + return ParseStatement(); + } + + // Otherwise, we have a normal instruction or directive. + if (IDVal[0] == '.') + outs() << "Found directive: " << IDVal << "\n"; + else + outs() << "Found instruction: " << IDVal << "\n"; + + // Skip to end of line for now. + while (Lexer.isNot(asmtok::EndOfStatement) && + Lexer.isNot(asmtok::Eof)) + Lexer.Lex(); + + // Eat EOL. + if (Lexer.is(asmtok::EndOfStatement)) + Lexer.Lex(); return false; } diff --git a/llvm/tools/llvm-mc/AsmParser.h b/llvm/tools/llvm-mc/AsmParser.h index adcd74c7a51b..5e1f6c65627f 100644 --- a/llvm/tools/llvm-mc/AsmParser.h +++ b/llvm/tools/llvm-mc/AsmParser.h @@ -27,6 +27,9 @@ public: bool Run(); +private: + bool ParseStatement(); + }; } // end namespace llvm