[llvm-commits] [llvm] r111967 - /llvm/trunk/lib/MC/MCParser/AsmParser.cpp
Kevin Enderby
enderby at apple.com
Tue Aug 24 14:14:48 PDT 2010
Author: enderby
Date: Tue Aug 24 16:14:47 2010
New Revision: 111967
URL: http://llvm.org/viewvc/llvm-project?rev=111967&view=rev
Log:
Change the parsing of .loc back to allow the LineNumber field to be optional as
it is with other assemblers.
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=111967&r1=111966&r2=111967&view=diff
==============================================================================
--- llvm/trunk/lib/MC/MCParser/AsmParser.cpp (original)
+++ llvm/trunk/lib/MC/MCParser/AsmParser.cpp Tue Aug 24 16:14:47 2010
@@ -1838,7 +1838,7 @@
/// ParseDirectiveLoc
-/// ::= .loc FileNumber LineNumber [ColumnPos] [basic_block] [prologue_end]
+/// ::= .loc FileNumber [LineNumber] [ColumnPos] [basic_block] [prologue_end]
/// [epilogue_begin] [is_stmt VALUE] [isa VALUE]
/// The first number is a file number, must have been previously assigned with
/// a .file directive, the second number is the line number and optionally the
@@ -1855,12 +1855,13 @@
return TokError("unassigned file number in '.loc' directive");
Lex();
- if (getLexer().isNot(AsmToken::Integer))
- return TokError("unexpected token in '.loc' directive");
- int64_t LineNumber = getTok().getIntVal();
- if (LineNumber < 1)
- return TokError("line number less than one in '.loc' directive");
- Lex();
+ int64_t LineNumber = 0;
+ if (getLexer().is(AsmToken::Integer)) {
+ LineNumber = getTok().getIntVal();
+ if (LineNumber < 1)
+ return TokError("line number less than one in '.loc' directive");
+ Lex();
+ }
int64_t ColumnPos = 0;
if (getLexer().is(AsmToken::Integer)) {
More information about the llvm-commits
mailing list