From 70aef29427b6127fd4c2424ab264de6478117469 Mon Sep 17 00:00:00 2001 From: Kyle Edwards Date: Tue, 25 Oct 2022 10:43:34 -0400 Subject: cmake --workflow: print usage message --- Source/cmakemain.cxx | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/Source/cmakemain.cxx b/Source/cmakemain.cxx index b754b72..47e34a6 100644 --- a/Source/cmakemain.cxx +++ b/Source/cmakemain.cxx @@ -956,7 +956,14 @@ int do_workflow(int ac, char const* const* av) } if (presetName.empty() && !listPresets) { - std::cerr << "TODO: Usage\n"; + /* clang-format off */ + std::cerr << + "Usage: cmake --workflow [options]\n" + "Options:\n" + " --preset = Workflow preset to execute.\n" + " --list-presets = List available workflow presets.\n" + ; + /* clang-format on */ return 1; } -- cgit v0.12 From 322193afcdfd3d3ba5a456e5e6f64e3637091736 Mon Sep 17 00:00:00 2001 From: Kyle Edwards Date: Tue, 25 Oct 2022 10:46:09 -0400 Subject: cmake --workflow: print usage and exit on unrecognized argument Issue: #24073 --- Source/cmakemain.cxx | 2 ++ Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-result.txt | 1 + Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stderr.txt | 6 ++++++ Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stdout.txt | 1 + Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake | 1 + 5 files changed, 11 insertions(+) create mode 100644 Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-result.txt create mode 100644 Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stderr.txt create mode 100644 Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stdout.txt diff --git a/Source/cmakemain.cxx b/Source/cmakemain.cxx index 47e34a6..15e3190 100644 --- a/Source/cmakemain.cxx +++ b/Source/cmakemain.cxx @@ -949,6 +949,8 @@ int do_workflow(int ac, char const* const* av) } if (!(matched && parsed)) { if (!matched) { + presetName.clear(); + listPresets = false; std::cerr << "Unknown argument " << arg << std::endl; } break; diff --git a/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-result.txt b/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-result.txt new file mode 100644 index 0000000..d00491f --- /dev/null +++ b/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-result.txt @@ -0,0 +1 @@ +1 diff --git a/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stderr.txt b/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stderr.txt new file mode 100644 index 0000000..049ff54 --- /dev/null +++ b/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stderr.txt @@ -0,0 +1,6 @@ +^Unknown argument -DINVALID_OPTION +Usage: cmake --workflow \[options\] +Options: + --preset = Workflow preset to execute\. + --list-presets = List available workflow presets\. + --fresh = Configure a fresh build tree, removing any existing cache file\.$ diff --git a/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stdout.txt b/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stdout.txt new file mode 100644 index 0000000..10f3293 --- /dev/null +++ b/Tests/RunCMake/CMakePresetsWorkflow/InvalidOption-stdout.txt @@ -0,0 +1 @@ +^$ diff --git a/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake b/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake index b89a11a..c620595 100644 --- a/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake +++ b/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake @@ -77,3 +77,4 @@ unset(CMakeUserPresets_FILE) unset(CMakePresets_ASSETS) run_cmake_workflow_presets(ListPresets --list-presets) +run_cmake_workflow_presets(InvalidOption -DINVALID_OPTION) -- cgit v0.12 From 7d9aa0f00cd9f7c2ed3d0c710090e9901c4430e9 Mon Sep 17 00:00:00 2001 From: Kyle Edwards Date: Tue, 25 Oct 2022 10:59:19 -0400 Subject: cmake::Workflow: Refactor to use enum class argument --- Source/cmake.cxx | 5 +++-- Source/cmake.h | 7 ++++++- Source/cmakemain.cxx | 12 ++++++++---- 3 files changed, 17 insertions(+), 7 deletions(-) diff --git a/Source/cmake.cxx b/Source/cmake.cxx index 67a8e01..169bf9e 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -3732,7 +3732,8 @@ std::function cmake::BuildWorkflowStep( } #endif -int cmake::Workflow(const std::string& presetName, bool listPresets) +int cmake::Workflow(const std::string& presetName, + WorkflowListPresets listPresets) { #ifndef CMAKE_BOOTSTRAP this->SetHomeDirectory(cmSystemTools::GetCurrentWorkingDirectory()); @@ -3747,7 +3748,7 @@ int cmake::Workflow(const std::string& presetName, bool listPresets) return 1; } - if (listPresets) { + if (listPresets == WorkflowListPresets::Yes) { settingsFile.PrintWorkflowPresetList(); return 0; } diff --git a/Source/cmake.h b/Source/cmake.h index 54d0bb5..b3b9f19 100644 --- a/Source/cmake.h +++ b/Source/cmake.h @@ -602,7 +602,12 @@ public: bool Open(const std::string& dir, bool dryRun); //! run the --workflow option - int Workflow(const std::string& presetName, bool listPresets); + enum class WorkflowListPresets + { + No, + Yes, + }; + int Workflow(const std::string& presetName, WorkflowListPresets listPresets); void UnwatchUnusedCli(const std::string& var); void WatchUnusedCli(const std::string& var); diff --git a/Source/cmakemain.cxx b/Source/cmakemain.cxx index 15e3190..a6938bc 100644 --- a/Source/cmakemain.cxx +++ b/Source/cmakemain.cxx @@ -917,8 +917,9 @@ int do_workflow(int ac, char const* const* av) std::cerr << "This cmake does not support --workflow\n"; return -1; #else + using WorkflowListPresets = cmake::WorkflowListPresets; std::string presetName; - bool listPresets = false; + auto listPresets = WorkflowListPresets::No; using CommandArgument = cmCommandLineArgument; @@ -927,7 +928,10 @@ int do_workflow(int ac, char const* const* av) CommandArgument{ "--preset", CommandArgument::Values::One, CommandArgument::setToValue(presetName) }, CommandArgument{ "--list-presets", CommandArgument::Values::Zero, - CommandArgument::setToTrue(listPresets) } + [&listPresets](const std::string&) -> bool { + listPresets = WorkflowListPresets::Yes; + return true; + } }, }; std::vector inputArgs; @@ -950,14 +954,14 @@ int do_workflow(int ac, char const* const* av) if (!(matched && parsed)) { if (!matched) { presetName.clear(); - listPresets = false; + listPresets = WorkflowListPresets::No; std::cerr << "Unknown argument " << arg << std::endl; } break; } } - if (presetName.empty() && !listPresets) { + if (presetName.empty() && listPresets == WorkflowListPresets::No) { /* clang-format off */ std::cerr << "Usage: cmake --workflow [options]\n" -- cgit v0.12 From 7ecbe324b0ef02f63676f8431dbbbe8b4217f64f Mon Sep 17 00:00:00 2001 From: Kyle Edwards Date: Tue, 25 Oct 2022 11:13:35 -0400 Subject: cmake --workflow: add --fresh option Fixes: #24073 --- Help/manual/cmake.1.rst | 6 ++++++ Source/cmake.cxx | 13 ++++++++----- Source/cmake.h | 8 +++++++- Source/cmakemain.cxx | 11 ++++++++++- Tests/RunCMake/CMakePresetsWorkflow/Fresh.cmake | 4 ++++ Tests/RunCMake/CMakePresetsWorkflow/Fresh.json.in | 21 +++++++++++++++++++++ .../CMakePresetsWorkflow/RunCMakeTest.cmake | 15 ++++++++++++--- 7 files changed, 68 insertions(+), 10 deletions(-) create mode 100644 Tests/RunCMake/CMakePresetsWorkflow/Fresh.cmake create mode 100644 Tests/RunCMake/CMakePresetsWorkflow/Fresh.json.in diff --git a/Help/manual/cmake.1.rst b/Help/manual/cmake.1.rst index 35bd05f..b31ad11 100644 --- a/Help/manual/cmake.1.rst +++ b/Help/manual/cmake.1.rst @@ -1286,6 +1286,12 @@ The options are: Lists the available workflow presets. The current working directory must contain CMake preset files. +.. option:: --fresh + + Perform a fresh configuration of the build tree. + This removes any existing ``CMakeCache.txt`` file and associated + ``CMakeFiles/`` directory, and recreates them from scratch. + View Help ========= diff --git a/Source/cmake.cxx b/Source/cmake.cxx index 169bf9e..013a87b 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -3733,7 +3733,7 @@ std::function cmake::BuildWorkflowStep( #endif int cmake::Workflow(const std::string& presetName, - WorkflowListPresets listPresets) + WorkflowListPresets listPresets, WorkflowFresh fresh) { #ifndef CMAKE_BOOTSTRAP this->SetHomeDirectory(cmSystemTools::GetCurrentWorkingDirectory()); @@ -3815,10 +3815,13 @@ int cmake::Workflow(const std::string& presetName, if (!configurePreset) { return 1; } - steps.emplace_back( - stepNumber, "configure"_s, step.PresetName, - this->BuildWorkflowStep({ cmSystemTools::GetCMakeCommand(), - "--preset", step.PresetName })); + std::vector args{ cmSystemTools::GetCMakeCommand(), + "--preset", step.PresetName }; + if (fresh == WorkflowFresh::Yes) { + args.emplace_back("--fresh"); + } + steps.emplace_back(stepNumber, "configure"_s, step.PresetName, + this->BuildWorkflowStep(args)); } break; case cmCMakePresetsGraph::WorkflowPreset::WorkflowStep::Type::Build: { auto const* buildPreset = this->FindPresetForWorkflow( diff --git a/Source/cmake.h b/Source/cmake.h index b3b9f19..3183577 100644 --- a/Source/cmake.h +++ b/Source/cmake.h @@ -607,7 +607,13 @@ public: No, Yes, }; - int Workflow(const std::string& presetName, WorkflowListPresets listPresets); + enum class WorkflowFresh + { + No, + Yes, + }; + int Workflow(const std::string& presetName, WorkflowListPresets listPresets, + WorkflowFresh fresh); void UnwatchUnusedCli(const std::string& var); void WatchUnusedCli(const std::string& var); diff --git a/Source/cmakemain.cxx b/Source/cmakemain.cxx index a6938bc..723932e 100644 --- a/Source/cmakemain.cxx +++ b/Source/cmakemain.cxx @@ -918,8 +918,10 @@ int do_workflow(int ac, char const* const* av) return -1; #else using WorkflowListPresets = cmake::WorkflowListPresets; + using WorkflowFresh = cmake::WorkflowFresh; std::string presetName; auto listPresets = WorkflowListPresets::No; + auto fresh = WorkflowFresh::No; using CommandArgument = cmCommandLineArgument; @@ -932,6 +934,11 @@ int do_workflow(int ac, char const* const* av) listPresets = WorkflowListPresets::Yes; return true; } }, + CommandArgument{ "--fresh", CommandArgument::Values::Zero, + [&fresh](const std::string&) -> bool { + fresh = WorkflowFresh::Yes; + return true; + } }, }; std::vector inputArgs; @@ -968,6 +975,8 @@ int do_workflow(int ac, char const* const* av) "Options:\n" " --preset = Workflow preset to execute.\n" " --list-presets = List available workflow presets.\n" + " --fresh = Configure a fresh build tree, removing any " + "existing cache file.\n" ; /* clang-format on */ return 1; @@ -982,7 +991,7 @@ int do_workflow(int ac, char const* const* av) cmakemainProgressCallback(msg, prog, &cm); }); - return cm.Workflow(presetName, listPresets); + return cm.Workflow(presetName, listPresets, fresh); #endif } diff --git a/Tests/RunCMake/CMakePresetsWorkflow/Fresh.cmake b/Tests/RunCMake/CMakePresetsWorkflow/Fresh.cmake new file mode 100644 index 0000000..4cf999f --- /dev/null +++ b/Tests/RunCMake/CMakePresetsWorkflow/Fresh.cmake @@ -0,0 +1,4 @@ +option(FRESH_CONFIGURE "" ON) +if(NOT FRESH_CONFIGURE) + message(FATAL_ERROR "FRESH_CONFIGURE is ${FRESH_CONFIGURE}, should be ON") +endif() diff --git a/Tests/RunCMake/CMakePresetsWorkflow/Fresh.json.in b/Tests/RunCMake/CMakePresetsWorkflow/Fresh.json.in new file mode 100644 index 0000000..4ce0ca5 --- /dev/null +++ b/Tests/RunCMake/CMakePresetsWorkflow/Fresh.json.in @@ -0,0 +1,21 @@ +{ + "version": 6, + "configurePresets": [ + { + "name": "default", + "generator": "@RunCMake_GENERATOR@", + "binaryDir": "${sourceDir}/build" + } + ], + "workflowPresets": [ + { + "name": "Fresh", + "steps": [ + { + "type": "configure", + "name": "default" + } + ] + } + ] +} diff --git a/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake b/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake index c620595..550600a 100644 --- a/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake +++ b/Tests/RunCMake/CMakePresetsWorkflow/RunCMakeTest.cmake @@ -10,10 +10,12 @@ function(run_cmake_workflow_presets name) set(RunCMake_TEST_BINARY_DIR "${RunCMake_TEST_SOURCE_DIR}/build") set(RunCMake_TEST_COMMAND_WORKING_DIRECTORY "${RunCMake_TEST_SOURCE_DIR}") - set(RunCMake_TEST_NO_CLEAN TRUE) + if(NOT RunCMake_TEST_NO_CLEAN) + file(REMOVE_RECURSE "${RunCMake_TEST_SOURCE_DIR}") + file(MAKE_DIRECTORY "${RunCMake_TEST_SOURCE_DIR}") + endif() - file(REMOVE_RECURSE "${RunCMake_TEST_SOURCE_DIR}") - file(MAKE_DIRECTORY "${RunCMake_TEST_SOURCE_DIR}") + set(RunCMake_TEST_NO_CLEAN TRUE) set(CASE_NAME "${name}") set(CASE_SOURCE_DIR "${RunCMake_SOURCE_DIR}") @@ -78,3 +80,10 @@ unset(CMakePresets_ASSETS) run_cmake_workflow_presets(ListPresets --list-presets) run_cmake_workflow_presets(InvalidOption -DINVALID_OPTION) + +set(RunCMake_TEST_NO_CLEAN TRUE) +file(REMOVE_RECURSE "${RunCMake_BINARY_DIR}/Fresh") +file(MAKE_DIRECTORY "${RunCMake_BINARY_DIR}/Fresh/build") +file(WRITE "${RunCMake_BINARY_DIR}/Fresh/build/CMakeCache.txt" "FRESH_CONFIGURE:BOOL=OFF\n") +run_cmake_workflow_presets(Fresh --fresh) +unset(RunCMake_TEST_NO_CLEAN) -- cgit v0.12