mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-27 21:50:40 +00:00
AsmParser: Fix error location for missing fields
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@226524 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0d7ab29889
commit
5d2d1f29e1
@ -2953,12 +2953,13 @@ bool LLParser::ParseMDField(LocTy Loc, StringRef Name, MDField &Result) {
|
||||
}
|
||||
|
||||
template <class ParserTy>
|
||||
bool LLParser::ParseMDFieldsImpl(ParserTy parseField) {
|
||||
bool LLParser::ParseMDFieldsImpl(ParserTy parseField, LocTy &ClosingLoc) {
|
||||
assert(Lex.getKind() == lltok::MetadataVar && "Expected metadata type name");
|
||||
Lex.Lex();
|
||||
|
||||
if (ParseToken(lltok::lparen, "expected '(' here"))
|
||||
return true;
|
||||
ClosingLoc = Lex.getLoc();
|
||||
if (EatIfPresent(lltok::rparen))
|
||||
return false;
|
||||
|
||||
@ -2970,6 +2971,7 @@ bool LLParser::ParseMDFieldsImpl(ParserTy parseField) {
|
||||
return true;
|
||||
} while (EatIfPresent(lltok::comma));
|
||||
|
||||
ClosingLoc = Lex.getLoc();
|
||||
return ParseToken(lltok::rparen, "expected ')' here");
|
||||
}
|
||||
|
||||
@ -3003,18 +3005,18 @@ bool LLParser::ParseMDLocation(MDNode *&Result, bool IsDistinct) {
|
||||
MDUnsignedField<uint32_t> column(0, ~0u >> 16);
|
||||
MDField scope;
|
||||
MDField inlinedAt;
|
||||
LocTy Loc;
|
||||
if (ParseMDFieldsImpl([&]() -> bool {
|
||||
PARSE_MD_FIELD(line);
|
||||
PARSE_MD_FIELD(column);
|
||||
PARSE_MD_FIELD(scope);
|
||||
PARSE_MD_FIELD(inlinedAt);
|
||||
return TokError(Twine("invalid field '") + Lex.getStrVal() + "'");
|
||||
}))
|
||||
PARSE_MD_FIELD(line);
|
||||
PARSE_MD_FIELD(column);
|
||||
PARSE_MD_FIELD(scope);
|
||||
PARSE_MD_FIELD(inlinedAt);
|
||||
return TokError(Twine("invalid field '") + Lex.getStrVal() + "'");
|
||||
}, Loc))
|
||||
return true;
|
||||
|
||||
if (!scope.Seen)
|
||||
return TokError("missing required field 'scope'");
|
||||
|
||||
return Error(Loc, "missing required field 'scope'");
|
||||
auto get = (IsDistinct ? MDLocation::getDistinct : MDLocation::get);
|
||||
Result = get(Context, line.Val, column.Val, scope.Val, inlinedAt.Val);
|
||||
return false;
|
||||
|
@ -421,7 +421,8 @@ namespace llvm {
|
||||
bool ParseMDField(LocTy Loc, StringRef Name,
|
||||
MDUnsignedField<uint32_t> &Result);
|
||||
bool ParseMDField(LocTy Loc, StringRef Name, MDField &Result);
|
||||
template <class ParserTy> bool ParseMDFieldsImpl(ParserTy parseField);
|
||||
template <class ParserTy>
|
||||
bool ParseMDFieldsImpl(ParserTy parseField, LocTy &ClosingLoc);
|
||||
bool ParseSpecializedMDNode(MDNode *&N, bool IsDistinct = false);
|
||||
bool ParseMDLocation(MDNode *&Result, bool IsDistinct);
|
||||
|
||||
|
4
test/Assembler/invalid-mdlocation-missing-scope-2.ll
Normal file
4
test/Assembler/invalid-mdlocation-missing-scope-2.ll
Normal file
@ -0,0 +1,4 @@
|
||||
; RUN: not llvm-as < %s -disable-output 2>&1 | FileCheck %s
|
||||
|
||||
; CHECK: <stdin>:[[@LINE+1]]:25: error: missing required field 'scope'
|
||||
!0 = !MDLocation(line: 7)
|
4
test/Assembler/invalid-mdlocation-missing-scope.ll
Normal file
4
test/Assembler/invalid-mdlocation-missing-scope.ll
Normal file
@ -0,0 +1,4 @@
|
||||
; RUN: not llvm-as < %s -disable-output 2>&1 | FileCheck %s
|
||||
|
||||
; CHECK: <stdin>:[[@LINE+1]]:18: error: missing required field 'scope'
|
||||
!0 = !MDLocation()
|
Loading…
Reference in New Issue
Block a user