From b5cfa7ea46ed8da2ead6d4161de0f8ba1fab81ec Mon Sep 17 00:00:00 2001 From: Even Rouault Date: Fri, 8 Nov 2024 20:48:15 +0100 Subject: [PATCH 1/2] tidy-analysis-stage-01.yml: update to actions/upload-artifact@v4 since v2 is no longer working --- .github/workflows/tidy-analysis-stage-01.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/tidy-analysis-stage-01.yml b/.github/workflows/tidy-analysis-stage-01.yml index 66ca0a1d..7a0c7afb 100644 --- a/.github/workflows/tidy-analysis-stage-01.yml +++ b/.github/workflows/tidy-analysis-stage-01.yml @@ -36,7 +36,7 @@ jobs: echo ${{ github.event.pull_request.head.repo.full_name }} > clang-tidy-result/pr-head-repo.txt echo ${{ github.event.pull_request.head.ref }} > clang-tidy-result/pr-head-ref.txt - - uses: actions/upload-artifact@v2 + - uses: actions/upload-artifact@v4 with: name: clang-tidy-result path: clang-tidy-result/ From 097bac18547e9cfa33f97dc9977be1246da87a8c Mon Sep 17 00:00:00 2001 From: Even Rouault Date: Fri, 8 Nov 2024 20:19:16 +0100 Subject: [PATCH 2/2] subparser: use full parser path instead of just parser name in usage() message --- include/argparse/argparse.hpp | 2 +- test/test_subparsers.cpp | 26 ++++++++++++++++++++++++++ 2 files changed, 27 insertions(+), 1 deletion(-) diff --git a/include/argparse/argparse.hpp b/include/argparse/argparse.hpp index e7695e5c..c8c99b68 100644 --- a/include/argparse/argparse.hpp +++ b/include/argparse/argparse.hpp @@ -2067,7 +2067,7 @@ class ArgumentParser { std::stringstream stream; std::string curline("Usage: "); - curline += this->m_program_name; + curline += this->m_parser_path; const bool multiline_usage = this->m_usage_max_line_width < (std::numeric_limits::max)(); const size_t indent_size = curline.size(); diff --git a/test/test_subparsers.cpp b/test/test_subparsers.cpp index 532c9a7e..d2bd7863 100644 --- a/test/test_subparsers.cpp +++ b/test/test_subparsers.cpp @@ -280,3 +280,29 @@ TEST_CASE("Check set_suppress" * test_suite("subparsers")) { REQUIRE(contains(program.help().str(), "command_2") == true); } } + + +TEST_CASE("Help of subparsers" * test_suite("subparsers")) { + argparse::ArgumentParser program("test"); + + argparse::ArgumentParser command_1("add", "1.0", argparse::default_arguments::version); + + std::stringstream buffer; + command_1.add_argument("--help") + .action([&](const auto &) { buffer << command_1; }) + .default_value(false) + .implicit_value(true) + .nargs(0); + + program.add_subparser(command_1); + + REQUIRE(command_1.usage() == "Usage: test add [--version] [--help]"); + + REQUIRE(buffer.str().empty()); + program.parse_args({"test", "add", "--help"}); + REQUIRE(buffer.str() == "Usage: test add [--version] [--help]\n" + "\n" + "Optional arguments:\n" + " -v, --version prints version information and exits \n" + " --help \n"); +}