[llvm] r314674 - [AsmParser] Support GAS's .print directive
Coby Tayree via llvm-commits
llvm-commits at lists.llvm.org
Mon Oct 2 07:36:31 PDT 2017
Author: coby
Date: Mon Oct 2 07:36:31 2017
New Revision: 314674
URL: http://llvm.org/viewvc/llvm-project?rev=314674&view=rev
Log:
[AsmParser] Support GAS's .print directive
Differential Revision: https://reviews.llvm.org/D38448
Added:
llvm/trunk/test/MC/AsmParser/directive_print.s
Modified:
llvm/trunk/lib/MC/MCParser/AsmParser.cpp
Modified: llvm/trunk/lib/MC/MCParser/AsmParser.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCParser/AsmParser.cpp?rev=314674&r1=314673&r2=314674&view=diff
==============================================================================
--- llvm/trunk/lib/MC/MCParser/AsmParser.cpp (original)
+++ llvm/trunk/lib/MC/MCParser/AsmParser.cpp Mon Oct 2 07:36:31 2017
@@ -538,6 +538,7 @@ private:
DK_ERR,
DK_ERROR,
DK_WARNING,
+ DK_PRINT,
DK_END
};
@@ -682,6 +683,9 @@ private:
// ".warning"
bool parseDirectiveWarning(SMLoc DirectiveLoc);
+ // .print <double-quotes-string>
+ bool parseDirectivePrint(SMLoc DirectiveLoc);
+
void initializeDirectiveKindMap();
};
@@ -2130,6 +2134,8 @@ bool AsmParser::parseStatement(ParseStat
case DK_DS_P:
case DK_DS_X:
return parseDirectiveDS(IDVal, 12);
+ case DK_PRINT:
+ return parseDirectivePrint(IDLoc);
}
return Error(IDLoc, "unknown directive");
@@ -5228,6 +5234,7 @@ void AsmParser::initializeDirectiveKindM
DirectiveKindMap[".ds.s"] = DK_DS_S;
DirectiveKindMap[".ds.w"] = DK_DS_W;
DirectiveKindMap[".ds.x"] = DK_DS_X;
+ DirectiveKindMap[".print"] = DK_PRINT;
}
MCAsmMacro *AsmParser::parseMacroLikeBody(SMLoc DirectiveLoc) {
@@ -5456,6 +5463,17 @@ bool AsmParser::parseDirectiveMSAlign(SM
return false;
}
+bool AsmParser::parseDirectivePrint(SMLoc DirectiveLoc) {
+ const AsmToken StrTok = getTok();
+ Lex();
+ if (StrTok.isNot(AsmToken::String) || StrTok.getString().front() != '"')
+ return Error(DirectiveLoc, "expected double quoted string after .print");
+ if (parseToken(AsmToken::EndOfStatement, "expected end of statement"))
+ return true;
+ llvm::outs() << StrTok.getStringContents() << '\n';
+ return false;
+}
+
// We are comparing pointers, but the pointers are relative to a single string.
// Thus, this should always be deterministic.
static int rewritesSort(const AsmRewrite *AsmRewriteA,
Added: llvm/trunk/test/MC/AsmParser/directive_print.s
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/AsmParser/directive_print.s?rev=314674&view=auto
==============================================================================
--- llvm/trunk/test/MC/AsmParser/directive_print.s (added)
+++ llvm/trunk/test/MC/AsmParser/directive_print.s Mon Oct 2 07:36:31 2017
@@ -0,0 +1,18 @@
+# RUN: not llvm-mc -triple i386-linux-gnu %s 2> %t.err | FileCheck %s
+# RUN: FileCheck < %t.err %s --check-prefix=CHECK-ERR
+
+T1:
+# CHECK: e
+# CHECK: 2.718281828459045235
+.print "e"
+.print "2.718281828459045235"
+
+T2:
+# CHECK-ERR: expected double quoted string after .print
+.altmacro
+.print <pi>
+.noaltmacro
+
+T3:
+# CHECK-ERR: expected end of statement
+.print "a" "misplaced-string"
More information about the llvm-commits
mailing list