From cb96a3132c32f09b7ca90ea418653149511a620b Mon Sep 17 00:00:00 2001 From: "Duncan P. N. Exon Smith" Date: Tue, 20 Jan 2015 02:42:29 +0000 Subject: [PATCH] AsmParser: PARSE_MD_FIELD() => ParseMDField(), NFC Extract most of `PARSE_MD_FIELD()` into a function. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@226539 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/AsmParser/LLParser.cpp | 25 ++++++++++++------------- lib/AsmParser/LLParser.h | 1 + 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/lib/AsmParser/LLParser.cpp b/lib/AsmParser/LLParser.cpp index 442a49c43ac..0ad921ae4be 100644 --- a/lib/AsmParser/LLParser.cpp +++ b/lib/AsmParser/LLParser.cpp @@ -2972,6 +2972,16 @@ bool LLParser::ParseMDFieldsImpl(ParserTy parseField, LocTy &ClosingLoc) { return ParseToken(lltok::rparen, "expected ')' here"); } +template +bool LLParser::ParseMDField(StringRef Name, FieldTy &Result) { + if (Result.Seen) + return TokError("field '" + Name + "' cannot be specified more than once"); + + LocTy Loc = Lex.getLoc(); + Lex.Lex(); + return ParseMDField(Loc, Name, Result); +} + bool LLParser::ParseSpecializedMDNode(MDNode *&N, bool IsDistinct) { assert(Lex.getKind() == lltok::MetadataVar && "Expected metadata type name"); #define DISPATCH_TO_PARSER(CLASS) \ @@ -2990,19 +3000,8 @@ bool LLParser::ParseSpecializedMDNode(MDNode *&N, bool IsDistinct) { if (!NAME.Seen) \ return Error(ClosingLoc, "missing required field '" #NAME "'"); #define PARSE_MD_FIELD(NAME, TYPE, DEFAULT) \ - do { \ - if (Lex.getStrVal() == #NAME) { \ - if (NAME.Seen) \ - return TokError("field '" #NAME \ - "' cannot be specified more than once"); \ - \ - LocTy Loc = Lex.getLoc(); \ - Lex.Lex(); \ - if (ParseMDField(Loc, #NAME, NAME)) \ - return true; \ - return false; \ - } \ - } while (0) + if (Lex.getStrVal() == #NAME) \ + return ParseMDField(#NAME, NAME); #define PARSE_MD_FIELDS() \ VISIT_MD_FIELDS(DECLARE_FIELD, DECLARE_FIELD) \ do { \ diff --git a/lib/AsmParser/LLParser.h b/lib/AsmParser/LLParser.h index ad311910a6f..235e2642ef2 100644 --- a/lib/AsmParser/LLParser.h +++ b/lib/AsmParser/LLParser.h @@ -421,6 +421,7 @@ namespace llvm { bool ParseMDField(LocTy Loc, StringRef Name, MDUnsignedField &Result); bool ParseMDField(LocTy Loc, StringRef Name, MDField &Result); + template bool ParseMDField(StringRef Name, FieldTy &Result); template bool ParseMDFieldsImplBody(ParserTy parseField); template -- 2.34.1