cmCMakeHost*Command: Report keyword errors via argument parser results

This commit is contained in:
Brad King
2022-07-19 14:12:51 -04:00
parent 74ec6b63c2
commit 7e4a9afa1a
3 changed files with 12 additions and 12 deletions
@@ -474,7 +474,7 @@ bool QueryWindowsRegistry(Range args, cmExecutionStatus& status,
}
std::string const& key = *args.begin();
struct Arguments
struct Arguments : public ArgumentParser::ParseResult
{
std::string ValueName;
bool ValueNames = false;
@@ -491,19 +491,15 @@ bool QueryWindowsRegistry(Range args, cmExecutionStatus& status,
.Bind("SEPARATOR"_s, &Arguments::Separator)
.Bind("ERROR_VARIABLE"_s, &Arguments::ErrorVariable);
std::vector<std::string> invalidArgs;
std::vector<cm::string_view> keywordsMissingValue;
Arguments const arguments =
parser.Parse(args.advance(1), &invalidArgs, &keywordsMissingValue);
Arguments const arguments = parser.Parse(args.advance(1), &invalidArgs);
if (!invalidArgs.empty()) {
status.SetError(cmStrCat("given invalid argument(s) \"",
cmJoin(invalidArgs, ", "_s), "\"."));
return false;
}
if (!keywordsMissingValue.empty()) {
status.SetError(cmStrCat("missing expected value for argument(s) \"",
cmJoin(keywordsMissingValue, ", "_s), "\"."));
return false;
if (arguments.MaybeReportError(status.GetMakefile())) {
return true;
}
if ((!arguments.ValueName.empty() &&
(arguments.ValueNames || arguments.SubKeys)) ||