| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
- file Copyright.txt or https://cmake.org/licensing for details. */
- #include "cmCTestConfigureCommand.h"
- #include <cstring>
- #include <sstream>
- #include <utility>
- #include <vector>
- #include <cm/memory>
- #include <cmext/string_view>
- #include "cmArgumentParser.h"
- #include "cmCTest.h"
- #include "cmCTestConfigureHandler.h"
- #include "cmCTestGenericHandler.h"
- #include "cmCommand.h"
- #include "cmExecutionStatus.h"
- #include "cmGlobalGenerator.h"
- #include "cmList.h"
- #include "cmMakefile.h"
- #include "cmStringAlgorithms.h"
- #include "cmSystemTools.h"
- #include "cmValue.h"
- #include "cmake.h"
- std::unique_ptr<cmCommand> cmCTestConfigureCommand::Clone()
- {
- auto ni = cm::make_unique<cmCTestConfigureCommand>();
- ni->CTest = this->CTest;
- return std::unique_ptr<cmCommand>(std::move(ni));
- }
- std::unique_ptr<cmCTestGenericHandler>
- cmCTestConfigureCommand::InitializeHandler(HandlerArguments& arguments,
- cmExecutionStatus& status) const
- {
- cmMakefile& mf = status.GetMakefile();
- auto const& args = static_cast<ConfigureArguments&>(arguments);
- cmList options;
- if (!args.Options.empty()) {
- options.assign(args.Options);
- }
- if (this->CTest->GetCTestConfiguration("BuildDirectory").empty()) {
- status.SetError(
- "Build directory not specified. Either use BUILD "
- "argument to CTEST_CONFIGURE command or set CTEST_BINARY_DIRECTORY "
- "variable");
- return nullptr;
- }
- cmValue ctestConfigureCommand = mf.GetDefinition("CTEST_CONFIGURE_COMMAND");
- if (cmNonempty(ctestConfigureCommand)) {
- this->CTest->SetCTestConfiguration("ConfigureCommand",
- *ctestConfigureCommand, args.Quiet);
- } else {
- cmValue cmakeGeneratorName = mf.GetDefinition("CTEST_CMAKE_GENERATOR");
- if (cmNonempty(cmakeGeneratorName)) {
- const std::string& source_dir =
- this->CTest->GetCTestConfiguration("SourceDirectory");
- if (source_dir.empty()) {
- status.SetError(
- "Source directory not specified. Either use SOURCE "
- "argument to CTEST_CONFIGURE command or set CTEST_SOURCE_DIRECTORY "
- "variable");
- return nullptr;
- }
- const std::string cmakelists_file = source_dir + "/CMakeLists.txt";
- if (!cmSystemTools::FileExists(cmakelists_file)) {
- std::ostringstream e;
- e << "CMakeLists.txt file does not exist [" << cmakelists_file << "]";
- status.SetError(e.str());
- return nullptr;
- }
- bool multiConfig = false;
- bool cmakeBuildTypeInOptions = false;
- auto gg =
- mf.GetCMakeInstance()->CreateGlobalGenerator(*cmakeGeneratorName);
- if (gg) {
- multiConfig = gg->IsMultiConfig();
- gg.reset();
- }
- std::string cmakeConfigureCommand =
- cmStrCat('"', cmSystemTools::GetCMakeCommand(), '"');
- for (std::string const& option : options) {
- cmakeConfigureCommand += " \"";
- cmakeConfigureCommand += option;
- cmakeConfigureCommand += "\"";
- if ((nullptr != strstr(option.c_str(), "CMAKE_BUILD_TYPE=")) ||
- (nullptr != strstr(option.c_str(), "CMAKE_BUILD_TYPE:STRING="))) {
- cmakeBuildTypeInOptions = true;
- }
- }
- if (!multiConfig && !cmakeBuildTypeInOptions &&
- !this->CTest->GetConfigType().empty()) {
- cmakeConfigureCommand += " \"-DCMAKE_BUILD_TYPE:STRING=";
- cmakeConfigureCommand += this->CTest->GetConfigType();
- cmakeConfigureCommand += "\"";
- }
- if (mf.IsOn("CTEST_USE_LAUNCHERS")) {
- cmakeConfigureCommand += " \"-DCTEST_USE_LAUNCHERS:BOOL=TRUE\"";
- }
- cmakeConfigureCommand += " \"-G";
- cmakeConfigureCommand += *cmakeGeneratorName;
- cmakeConfigureCommand += "\"";
- cmValue cmakeGeneratorPlatform =
- mf.GetDefinition("CTEST_CMAKE_GENERATOR_PLATFORM");
- if (cmNonempty(cmakeGeneratorPlatform)) {
- cmakeConfigureCommand += " \"-A";
- cmakeConfigureCommand += *cmakeGeneratorPlatform;
- cmakeConfigureCommand += "\"";
- }
- cmValue cmakeGeneratorToolset =
- mf.GetDefinition("CTEST_CMAKE_GENERATOR_TOOLSET");
- if (cmNonempty(cmakeGeneratorToolset)) {
- cmakeConfigureCommand += " \"-T";
- cmakeConfigureCommand += *cmakeGeneratorToolset;
- cmakeConfigureCommand += "\"";
- }
- cmakeConfigureCommand += " \"-S";
- cmakeConfigureCommand += source_dir;
- cmakeConfigureCommand += "\"";
- cmakeConfigureCommand += " \"-B";
- cmakeConfigureCommand +=
- this->CTest->GetCTestConfiguration("BuildDirectory");
- cmakeConfigureCommand += "\"";
- this->CTest->SetCTestConfiguration("ConfigureCommand",
- cmakeConfigureCommand, args.Quiet);
- } else {
- status.SetError(
- "Configure command is not specified. If this is a "
- "\"built with CMake\" project, set CTEST_CMAKE_GENERATOR. If not, "
- "set CTEST_CONFIGURE_COMMAND.");
- return nullptr;
- }
- }
- if (cmValue labelsForSubprojects =
- mf.GetDefinition("CTEST_LABELS_FOR_SUBPROJECTS")) {
- this->CTest->SetCTestConfiguration("LabelsForSubprojects",
- *labelsForSubprojects, args.Quiet);
- }
- auto handler = cm::make_unique<cmCTestConfigureHandler>(this->CTest);
- handler->SetQuiet(args.Quiet);
- return std::unique_ptr<cmCTestGenericHandler>(std::move(handler));
- }
- bool cmCTestConfigureCommand::InitialPass(std::vector<std::string> const& args,
- cmExecutionStatus& status)
- {
- using Args = ConfigureArguments;
- static auto const parser =
- cmArgumentParser<Args>{ MakeHandlerParser<Args>() } //
- .Bind("OPTIONS"_s, &ConfigureArguments::Options);
- return this->Invoke(parser, args, status, [&](ConfigureArguments& a) {
- return this->ExecuteHandlerCommand(a, status);
- });
- }
|