From f95a5832c7ce6e88bd623e818471fa8c23fa77f4 Mon Sep 17 00:00:00 2001 From: Brad King Date: Wed, 20 Jul 2022 15:52:45 -0400 Subject: cmArgumentParser: Drop unused keywordsMissingValue argument to Parse() All clients have been converted to encoding this requirement in their bindings. --- Source/CTest/cmCTestHandlerCommand.cxx | 3 +-- Source/cmArgumentParser.cxx | 3 --- Source/cmArgumentParser.h | 13 +++---------- Source/cmFileCommand.cxx | 5 ++--- Tests/CMakeLib/testArgumentParser.cxx | 24 +++++++----------------- 5 files changed, 13 insertions(+), 35 deletions(-) diff --git a/Source/CTest/cmCTestHandlerCommand.cxx b/Source/CTest/cmCTestHandlerCommand.cxx index af365ad..528115e 100644 --- a/Source/CTest/cmCTestHandlerCommand.cxx +++ b/Source/CTest/cmCTestHandlerCommand.cxx @@ -83,8 +83,7 @@ bool cmCTestHandlerCommand::InitialPass(std::vector const& args, // Process input arguments. std::vector unparsedArguments; std::vector parsedKeywords; - this->Parse(args, &unparsedArguments, /*keywordsMissingValue=*/nullptr, - &parsedKeywords); + this->Parse(args, &unparsedArguments, &parsedKeywords); this->CheckArguments(); std::sort(parsedKeywords.begin(), parsedKeywords.end()); diff --git a/Source/cmArgumentParser.cxx b/Source/cmArgumentParser.cxx index fcced96..fafae13 100644 --- a/Source/cmArgumentParser.cxx +++ b/Source/cmArgumentParser.cxx @@ -113,9 +113,6 @@ void Instance::FinishKeyword() this->ParseResults->AddKeywordError(this->Keyword, " missing required value\n"); } - if (this->KeywordsMissingValue != nullptr) { - this->KeywordsMissingValue->emplace_back(this->Keyword); - } if (this->Bindings.KeywordMissingValue) { this->Bindings.KeywordMissingValue(*this, this->Keyword); } diff --git a/Source/cmArgumentParser.h b/Source/cmArgumentParser.h index ae3a000..70deaa6 100644 --- a/Source/cmArgumentParser.h +++ b/Source/cmArgumentParser.h @@ -115,13 +115,11 @@ class Instance public: Instance(ActionMap const& bindings, ParseResult* parseResult, std::vector* unparsedArguments, - std::vector* keywordsMissingValue, std::vector* parsedKeywords, void* result = nullptr) : Bindings(bindings) , ParseResults(parseResult) , UnparsedArguments(unparsedArguments) - , KeywordsMissingValue(keywordsMissingValue) , ParsedKeywords(parsedKeywords) , Result(result) { @@ -157,7 +155,6 @@ private: ActionMap const& Bindings; ParseResult* ParseResults = nullptr; std::vector* UnparsedArguments = nullptr; - std::vector* KeywordsMissingValue = nullptr; std::vector* ParsedKeywords = nullptr; void* Result = nullptr; @@ -193,25 +190,22 @@ public: template bool Parse(Result& result, Range const& args, std::vector* unparsedArguments, - std::vector* keywordsMissingValue = nullptr, std::vector* parsedKeywords = nullptr) const { using ArgumentParser::AsParseResultPtr; ParseResult* parseResultPtr = AsParseResultPtr(result); Instance instance(this->Bindings, parseResultPtr, unparsedArguments, - keywordsMissingValue, parsedKeywords, &result); + parsedKeywords, &result); instance.Parse(args); return parseResultPtr ? static_cast(*parseResultPtr) : true; } template Result Parse(Range const& args, std::vector* unparsedArguments, - std::vector* keywordsMissingValue = nullptr, std::vector* parsedKeywords = nullptr) const { Result result; - this->Parse(result, args, unparsedArguments, keywordsMissingValue, - parsedKeywords); + this->Parse(result, args, unparsedArguments, parsedKeywords); return result; } }; @@ -230,12 +224,11 @@ public: template ParseResult Parse( Range const& args, std::vector* unparsedArguments, - std::vector* keywordsMissingValue = nullptr, std::vector* parsedKeywords = nullptr) const { ParseResult parseResult; Instance instance(this->Bindings, &parseResult, unparsedArguments, - keywordsMissingValue, parsedKeywords); + parsedKeywords); instance.Parse(args); return parseResult; } diff --git a/Source/cmFileCommand.cxx b/Source/cmFileCommand.cxx index c7ba424..987f40e 100644 --- a/Source/cmFileCommand.cxx +++ b/Source/cmFileCommand.cxx @@ -2498,9 +2498,8 @@ bool HandleGenerateCommand(std::vector const& args, std::vector unparsedArguments; std::vector parsedKeywords; - Arguments const arguments = - parser.Parse(cmMakeRange(args).advance(1), &unparsedArguments, - /*keywordsMissingValue=*/nullptr, &parsedKeywords); + Arguments const arguments = parser.Parse( + cmMakeRange(args).advance(1), &unparsedArguments, &parsedKeywords); if (arguments.MaybeReportError(status.GetMakefile())) { return true; diff --git a/Tests/CMakeLib/testArgumentParser.cxx b/Tests/CMakeLib/testArgumentParser.cxx index f0ace50..9db7936 100644 --- a/Tests/CMakeLib/testArgumentParser.cxx +++ b/Tests/CMakeLib/testArgumentParser.cxx @@ -63,14 +63,10 @@ std::initializer_list const args = { }; bool verifyResult(Result const& result, - std::vector const& unparsedArguments, - std::vector const& keywordsMissingValue) + std::vector const& unparsedArguments) { static std::vector const foobar = { "foo", "bar" }; static std::vector const barfoo = { "bar", "foo" }; - static std::vector const missing = { "STRING_1"_s, - "LIST_1"_s, - "LIST_4"_s }; static std::map const keywordErrors = { { "STRING_1"_s, " missing required value\n" }, { "LIST_1"_s, " missing required value\n" }, @@ -117,7 +113,6 @@ bool verifyResult(Result const& result, ASSERT_TRUE(unparsedArguments.size() == 1); ASSERT_TRUE(unparsedArguments[0] == "bar"); - ASSERT_TRUE(keywordsMissingValue == missing); ASSERT_TRUE(result.GetKeywordErrors().size() == keywordErrors.size()); for (auto const& ke : result.GetKeywordErrors()) { @@ -133,7 +128,6 @@ bool testArgumentParserDynamic() { Result result; std::vector unparsedArguments; - std::vector keywordsMissingValue; static_cast(result) = cmArgumentParser{} @@ -153,9 +147,9 @@ bool testArgumentParserDynamic() .Bind("MULTI_2"_s, result.Multi2) .Bind("MULTI_3"_s, result.Multi3) .Bind("MULTI_4"_s, result.Multi4) - .Parse(args, &unparsedArguments, &keywordsMissingValue); + .Parse(args, &unparsedArguments); - return verifyResult(result, unparsedArguments, keywordsMissingValue); + return verifyResult(result, unparsedArguments); } static auto const parserStatic = // @@ -181,20 +175,16 @@ static auto const parserStatic = // bool testArgumentParserStatic() { std::vector unparsedArguments; - std::vector keywordsMissingValue; - Result const result = - parserStatic.Parse(args, &unparsedArguments, &keywordsMissingValue); - return verifyResult(result, unparsedArguments, keywordsMissingValue); + Result const result = parserStatic.Parse(args, &unparsedArguments); + return verifyResult(result, unparsedArguments); } bool testArgumentParserStaticBool() { std::vector unparsedArguments; - std::vector keywordsMissingValue; Result result; - ASSERT_TRUE(parserStatic.Parse(result, args, &unparsedArguments, - &keywordsMissingValue) == false); - return verifyResult(result, unparsedArguments, keywordsMissingValue); + ASSERT_TRUE(parserStatic.Parse(result, args, &unparsedArguments) == false); + return verifyResult(result, unparsedArguments); } } // namespace -- cgit v0.12