Skip to content

Commit

Permalink
resolve compatibility with old ctor
Browse files Browse the repository at this point in the history
  • Loading branch information
eseiler committed Feb 9, 2024
1 parent fc1f255 commit 33f3f2c
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 7 deletions.
13 changes: 9 additions & 4 deletions include/sharg/parser.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -681,8 +681,9 @@ class parser
*/
parser_meta_data info;

/*!\brief Adds subcommands to the parser.
* \param[in] subcommands A list of subcommands.
/*!\brief Adds a subcommand to the parser.
* \param[in] subcommand The subcommand to add.
* \returns A pointer to the sub-parser if subcommand is encountered, nullptr otherwise.
* \throws sharg::design_error if the subcommand name contains illegal characters.
*/
[[nodiscard]] parser * add_subcommand(std::string subcommand)
Expand All @@ -701,15 +702,19 @@ class parser
};

auto & parser_subcommands = this->subcommands;
parser_subcommands.emplace_back(std::move(subcommand));
parser_subcommands.emplace_back(subcommand);

std::ranges::sort(parser_subcommands);
auto const [first, last] = std::ranges::unique(parser_subcommands);
parser_subcommands.erase(first, last);

init();

return sub_parser.get();
// If a subcommand was already added via the constructor, we need to check if the subcommand is the same.
if (sub_parser && sub_parser->info.app_name == info.app_name + '-' + subcommand)
return sub_parser.get();
else
return nullptr;
}

private:
Expand Down
34 changes: 32 additions & 2 deletions test/snippet/readme_sneak_peek.cpp
Original file line number Diff line number Diff line change
@@ -1,9 +1,16 @@
// SPDX-FileCopyrightText: 2006-2024 Knut Reinert & Freie Universität Berlin
// SPDX-FileCopyrightText: 2016-2024 Knut Reinert & MPI für molekulare Genetik
// SPDX-License-Identifier: CC0-1.0

#define main test

#include <sharg/all.hpp>

#if 0
int main(int argc, char ** argv)
{
// sharg::parser git_parser{"git", argc, argv, sharg::update_notifications::on, {"pull", "push", "remote"}}; // NOT ALLOWED
sharg::parser git_parser{"git", argc, argv, sharg::update_notifications::on};
// -------- Optional --------
sharg::parser git_parser{"git", argc, argv, sharg::update_notifications::on, {"pull", "push", "remote"}};

if (auto pull_parser = git_parser.add_subcommand("pull"))
{
Expand Down Expand Up @@ -47,3 +54,26 @@ int main(int argc, char ** argv)

return 0;
}
#else
int main(int argc, char ** argv)
{
int val{};

sharg::parser parser{"Eat-Me-App", argc, argv};
parser.add_subsection("Eating Numbers");
parser.add_option(val, sharg::config{.short_id = 'i', .long_id = "int", .description = "Desc."});
parser.parse();

return 0;
}
#endif

#undef main

int main()
{
std::string argv1{"./Eat-Me-App"}, argv2{"-h"};
std::array argv{argv1.data(), argv2.data()};

return test(argv.size(), argv.data());
}
2 changes: 1 addition & 1 deletion test/unit/parser/parser_design_error_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -263,7 +263,7 @@ TEST(parse_test, subcommand_parser_error)
EXPECT_NO_THROW(top_level_parser.parse());
EXPECT_EQ(true, flag_value);

EXPECT_THROW(top_level_parser.get_sub_parser(), sharg::design_error);
EXPECT_THROW(std::ignore = top_level_parser.get_sub_parser(), sharg::design_error);
}

// subcommand key word must only contain alpha numeric characters
Expand Down

0 comments on commit 33f3f2c

Please sign in to comment.