mirror of
https://github.com/reactos/CMake.git
synced 2025-03-04 09:57:12 +00:00

This patch is generated by a python script that uses regular expressions to search for string concatenation patterns of the kind ``` std::string str = <ARG0>; str += <ARG1>; str += <ARG2>; ... ``` and replaces them with a single `cmStrCat` call ``` std::string str = cmStrCat(<ARG0>, <ARG1>, <ARG2>, ...); ``` If any `<ARGX>` is itself a concatenated string of the kind ``` a + b + c + ...; ``` then `<ARGX>` is split into multiple arguments for the `cmStrCat` call. If there's a sequence of literals in the `<ARGX>`, then all literals in the sequence are concatenated and merged into a single literal argument for the `cmStrCat` call. Single character strings are converted to single char arguments for the `cmStrCat` call. `std::to_string(...)` wrappings are removed from `cmStrCat` arguments, because it supports numeric types as well as string types. `arg.substr(x)` arguments to `cmStrCat` are replaced with `cm::string_view(arg).substr(x)`
83 lines
2.3 KiB
C++
83 lines
2.3 KiB
C++
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
|
#include "cmSetTargetPropertiesCommand.h"
|
|
|
|
#include <iterator>
|
|
|
|
#include "cmAlgorithms.h"
|
|
#include "cmMakefile.h"
|
|
#include "cmStringAlgorithms.h"
|
|
#include "cmTarget.h"
|
|
|
|
class cmExecutionStatus;
|
|
|
|
// cmSetTargetPropertiesCommand
|
|
bool cmSetTargetPropertiesCommand::InitialPass(
|
|
std::vector<std::string> const& args, cmExecutionStatus&)
|
|
{
|
|
if (args.size() < 2) {
|
|
this->SetError("called with incorrect number of arguments");
|
|
return false;
|
|
}
|
|
|
|
// first collect up the list of files
|
|
std::vector<std::string> propertyPairs;
|
|
int numFiles = 0;
|
|
std::vector<std::string>::const_iterator j;
|
|
for (j = args.begin(); j != args.end(); ++j) {
|
|
if (*j == "PROPERTIES") {
|
|
// now loop through the rest of the arguments, new style
|
|
++j;
|
|
if (std::distance(j, args.end()) % 2 != 0) {
|
|
this->SetError("called with incorrect number of arguments.");
|
|
return false;
|
|
}
|
|
cmAppend(propertyPairs, j, args.end());
|
|
break;
|
|
}
|
|
numFiles++;
|
|
}
|
|
if (propertyPairs.empty()) {
|
|
this->SetError("called with illegal arguments, maybe missing "
|
|
"a PROPERTIES specifier?");
|
|
return false;
|
|
}
|
|
|
|
// now loop over all the targets
|
|
int i;
|
|
for (i = 0; i < numFiles; ++i) {
|
|
if (this->Makefile->IsAlias(args[i])) {
|
|
this->SetError("can not be used on an ALIAS target.");
|
|
return false;
|
|
}
|
|
bool ret = cmSetTargetPropertiesCommand::SetOneTarget(
|
|
args[i], propertyPairs, this->Makefile);
|
|
if (!ret) {
|
|
std::string message =
|
|
cmStrCat("Can not find target to add properties to: ", args[i]);
|
|
this->SetError(message);
|
|
return false;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
bool cmSetTargetPropertiesCommand::SetOneTarget(
|
|
const std::string& tname, std::vector<std::string>& propertyPairs,
|
|
cmMakefile* mf)
|
|
{
|
|
if (cmTarget* target = mf->FindTargetToUse(tname)) {
|
|
// now loop through all the props and set them
|
|
unsigned int k;
|
|
for (k = 0; k < propertyPairs.size(); k = k + 2) {
|
|
target->SetProperty(propertyPairs[k], propertyPairs[k + 1].c_str());
|
|
target->CheckProperty(propertyPairs[k], mf);
|
|
}
|
|
}
|
|
// if file is not already in the makefile, then add it
|
|
else {
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|