mirror of
https://github.com/Kitware/CMake.git
synced 2025-10-16 14:08:35 +08:00

This changes `cmMakefile::AddDefinition` to take a `cm::string_view` as value argument instead of a `const char *`. Benefits are: - `std::string` can be passed to `cmMakefile::AddDefinition` directly without the `c_str()` plus string length recomputation fallback. - Lengths of literals passed to `cmMakefile::AddDefinition` can be computed at compile time. In various sources uses of `cmMakefile::AddDefinition` are adapted to avoid `std::string::c_str` calls and the `std::string` is passed directly. Uses of `cmMakefile::AddDefinition`, where a `nullptr` `const char*` might be passed to `cmMakefile::AddDefinition` are extended with `nullptr` checks.
51 lines
1.2 KiB
C++
51 lines
1.2 KiB
C++
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
|
#include "cmCTestRunScriptCommand.h"
|
|
|
|
#include "cmCTestScriptHandler.h"
|
|
#include "cmMakefile.h"
|
|
|
|
#include <sstream>
|
|
|
|
class cmExecutionStatus;
|
|
|
|
bool cmCTestRunScriptCommand::InitialPass(std::vector<std::string> const& args,
|
|
cmExecutionStatus& /*unused*/)
|
|
{
|
|
if (args.empty()) {
|
|
this->CTestScriptHandler->RunCurrentScript();
|
|
return true;
|
|
}
|
|
|
|
bool np = false;
|
|
unsigned int i = 0;
|
|
if (args[i] == "NEW_PROCESS") {
|
|
np = true;
|
|
i++;
|
|
}
|
|
int start = i;
|
|
// run each script
|
|
std::string returnVariable;
|
|
for (i = start; i < args.size(); ++i) {
|
|
if (args[i] == "RETURN_VALUE") {
|
|
++i;
|
|
if (i < args.size()) {
|
|
returnVariable = args[i];
|
|
}
|
|
}
|
|
}
|
|
for (i = start; i < args.size(); ++i) {
|
|
if (args[i] == "RETURN_VALUE") {
|
|
++i;
|
|
} else {
|
|
int ret;
|
|
cmCTestScriptHandler::RunScript(this->CTest, this->Makefile,
|
|
args[i].c_str(), !np, &ret);
|
|
std::ostringstream str;
|
|
str << ret;
|
|
this->Makefile->AddDefinition(returnVariable, str.str());
|
|
}
|
|
}
|
|
return true;
|
|
}
|