blob: efedcdc5a314d10e4c1882f0ad9095a136538bb7 [file] [log] [blame]
Daniel Dunbar3c2a8932009-07-20 18:55:04 +00001//===-- MCAsmParser.cpp - Abstract Asm Parser Interface -------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Chandler Carruth6bda14b2017-06-06 11:49:48 +000010#include "llvm/MC/MCParser/MCAsmParser.h"
Eugene Zelenko1d435522017-02-07 23:02:00 +000011#include "llvm/ADT/StringRef.h"
Chandler Carruthed0881b2012-12-03 16:50:05 +000012#include "llvm/ADT/Twine.h"
Nico Weber432a3882018-04-30 14:59:11 +000013#include "llvm/Config/llvm-config.h"
Chris Lattner00646cf2010-01-22 01:44:57 +000014#include "llvm/MC/MCParser/MCAsmLexer.h"
15#include "llvm/MC/MCParser/MCParsedAsmOperand.h"
Benjamin Kramerb3e8a6d2016-01-27 10:01:28 +000016#include "llvm/MC/MCParser/MCTargetAsmParser.h"
Chandler Carruthed0881b2012-12-03 16:50:05 +000017#include "llvm/Support/Debug.h"
Eugene Zelenko1d435522017-02-07 23:02:00 +000018#include "llvm/Support/SMLoc.h"
Jim Grosbach602aa902011-07-13 15:34:57 +000019#include "llvm/Support/raw_ostream.h"
Eugene Zelenko1d435522017-02-07 23:02:00 +000020#include <cassert>
21
Daniel Dunbar3c2a8932009-07-20 18:55:04 +000022using namespace llvm;
23
Reid Kleckner3d5c2e62018-10-22 22:29:09 +000024MCAsmParser::MCAsmParser() {}
Daniel Dunbar3c2a8932009-07-20 18:55:04 +000025
Eugene Zelenko1d435522017-02-07 23:02:00 +000026MCAsmParser::~MCAsmParser() = default;
Chris Lattner528d00b2010-01-15 19:28:38 +000027
Evan Cheng11424442011-07-26 00:24:13 +000028void MCAsmParser::setTargetParser(MCTargetAsmParser &P) {
Daniel Dunbar01e36072010-07-17 02:26:10 +000029 assert(!TargetParser && "Target parser is already initialized!");
30 TargetParser = &P;
31 TargetParser->Initialize(*this);
32}
33
Rafael Espindola804f43c2014-11-11 05:11:47 +000034const AsmToken &MCAsmParser::getTok() const {
Sean Callanan936b0d32010-01-19 21:44:56 +000035 return getLexer().getTok();
36}
37
Nirav Daved8858ca2016-08-30 14:15:43 +000038bool MCAsmParser::parseTokenLoc(SMLoc &Loc) {
39 Loc = getTok().getLoc();
40 return false;
41}
42
43bool MCAsmParser::parseEOL(const Twine &Msg) {
Nirav Daved8858ca2016-08-30 14:15:43 +000044 if (getTok().getKind() != AsmToken::EndOfStatement)
45 return Error(getTok().getLoc(), Msg);
46 Lex();
47 return false;
48}
49
50bool MCAsmParser::parseToken(AsmToken::TokenKind T, const Twine &Msg) {
51 if (T == AsmToken::EndOfStatement)
52 return parseEOL(Msg);
53 if (getTok().getKind() != T)
54 return Error(getTok().getLoc(), Msg);
55 Lex();
56 return false;
57}
58
59bool MCAsmParser::parseIntToken(int64_t &V, const Twine &Msg) {
60 if (getTok().getKind() != AsmToken::Integer)
61 return TokError(Msg);
62 V = getTok().getIntVal();
63 Lex();
64 return false;
65}
66
Nirav Dave1a9044b2016-10-24 14:35:29 +000067bool MCAsmParser::parseOptionalToken(AsmToken::TokenKind T) {
68 bool Present = (getTok().getKind() == T);
Nirav Daved8858ca2016-08-30 14:15:43 +000069 if (Present)
Nirav Dave1a9044b2016-10-24 14:35:29 +000070 parseToken(T);
71 return Present;
Nirav Daved8858ca2016-08-30 14:15:43 +000072}
73
74bool MCAsmParser::check(bool P, const Twine &Msg) {
75 return check(P, getTok().getLoc(), Msg);
76}
77
78bool MCAsmParser::check(bool P, SMLoc Loc, const Twine &Msg) {
79 if (P)
80 return Error(Loc, Msg);
81 return false;
82}
83
Nirav Dave2364748a2016-09-16 18:30:20 +000084bool MCAsmParser::TokError(const Twine &Msg, SMRange Range) {
85 return Error(getLexer().getLoc(), Msg, Range);
86}
87
88bool MCAsmParser::Error(SMLoc L, const Twine &Msg, SMRange Range) {
Nirav Dave2364748a2016-09-16 18:30:20 +000089
90 MCPendingError PErr;
91 PErr.Loc = L;
92 Msg.toVector(PErr.Msg);
93 PErr.Range = Range;
94 PendingErrors.push_back(PErr);
Nirav Dave1a9044b2016-10-24 14:35:29 +000095
96 // If we threw this parsing error after a lexing error, this should
97 // supercede the lexing error and so we remove it from the Lexer
98 // before it can propagate
99 if (getTok().is(AsmToken::Error))
100 getLexer().Lex();
Daniel Dunbar4be8f2f2010-07-12 17:18:45 +0000101 return true;
102}
103
Nirav Dave1a9044b2016-10-24 14:35:29 +0000104bool MCAsmParser::addErrorSuffix(const Twine &Suffix) {
105 // Make sure lexing errors have propagated to the parser.
106 if (getTok().is(AsmToken::Error))
107 Lex();
108 for (auto &PErr : PendingErrors)
109 Suffix.toVector(PErr.Msg);
110 return true;
111}
112
Benjamin Kramer061f4a52017-01-13 14:39:03 +0000113bool MCAsmParser::parseMany(function_ref<bool()> parseOne, bool hasComma) {
Nirav Dave1a9044b2016-10-24 14:35:29 +0000114 if (parseOptionalToken(AsmToken::EndOfStatement))
115 return false;
Eugene Zelenko1d435522017-02-07 23:02:00 +0000116 while (true) {
Nirav Dave1a9044b2016-10-24 14:35:29 +0000117 if (parseOne())
118 return true;
119 if (parseOptionalToken(AsmToken::EndOfStatement))
120 return false;
121 if (hasComma && parseToken(AsmToken::Comma))
122 return true;
123 }
124 return false;
125}
126
Jim Grosbachd2037eb2013-02-20 22:21:35 +0000127bool MCAsmParser::parseExpression(const MCExpr *&Res) {
Chris Lattner528d00b2010-01-15 19:28:38 +0000128 SMLoc L;
Jim Grosbachd2037eb2013-02-20 22:21:35 +0000129 return parseExpression(Res, L);
Chris Lattner528d00b2010-01-15 19:28:38 +0000130}
131
Matthias Braun8c209aa2017-01-28 02:02:38 +0000132void MCParsedAsmOperand::dump() const {
133 // Cannot completely remove virtual function even in release mode.
Aaron Ballman615eb472017-10-15 14:32:27 +0000134#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
Jim Grosbach602aa902011-07-13 15:34:57 +0000135 dbgs() << " " << *this;
Matthias Braun8c209aa2017-01-28 02:02:38 +0000136#endif
Jim Grosbach602aa902011-07-13 15:34:57 +0000137}