mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-07 22:30:13 -06:00
Ninja,Makefile: Fix <LANG>_COMPILER_LAUNCHER shell command syntax
The first entry in the compiler launcher command argument list is the command itself and should be converted to the shell's native command syntax (e.g. backslashes on Windows). Without this, the `RunCMake.CompilerLauncher` test fails on Windows when there are *no* spaces in the path to `cmake.exe`.
This commit is contained in:
@@ -788,8 +788,12 @@ void cmMakefileTargetGenerator::WriteObjectBuildFile(
|
||||
if (!compileCommands.empty() && !compilerLauncher.empty()) {
|
||||
std::vector<std::string> args;
|
||||
cmSystemTools::ExpandListArgument(compilerLauncher, args, true);
|
||||
for (std::string& i : args) {
|
||||
i = this->LocalGenerator->EscapeForShell(i);
|
||||
if (!args.empty()) {
|
||||
args[0] = this->LocalGenerator->ConvertToOutputFormat(
|
||||
args[0], cmOutputConverter::SHELL);
|
||||
for (std::string& i : cmMakeRange(args.begin() + 1, args.end())) {
|
||||
i = this->LocalGenerator->EscapeForShell(i);
|
||||
}
|
||||
}
|
||||
compileCommands.front().insert(0, cmJoin(args, " ") + " ");
|
||||
}
|
||||
|
||||
@@ -25,6 +25,7 @@
|
||||
#include "cmNinjaNormalTargetGenerator.h"
|
||||
#include "cmNinjaUtilityTargetGenerator.h"
|
||||
#include "cmOutputConverter.h"
|
||||
#include "cmRange.h"
|
||||
#include "cmRulePlaceholderExpander.h"
|
||||
#include "cmSourceFile.h"
|
||||
#include "cmState.h"
|
||||
@@ -763,8 +764,12 @@ void cmNinjaTargetGenerator::WriteCompileRule(const std::string& lang)
|
||||
if (!compileCmds.empty() && !compilerLauncher.empty()) {
|
||||
std::vector<std::string> args;
|
||||
cmSystemTools::ExpandListArgument(compilerLauncher, args, true);
|
||||
for (std::string& i : args) {
|
||||
i = this->LocalGenerator->EscapeForShell(i);
|
||||
if (!args.empty()) {
|
||||
args[0] = this->LocalGenerator->ConvertToOutputFormat(
|
||||
args[0], cmOutputConverter::SHELL);
|
||||
for (std::string& i : cmMakeRange(args.begin() + 1, args.end())) {
|
||||
i = this->LocalGenerator->EscapeForShell(i);
|
||||
}
|
||||
}
|
||||
compileCmds.front().insert(0, cmJoin(args, " ") + " ");
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user