[coff] use newlines instead of spaces as separators in msvclto response file

Summary:
Fixes PR32689: /msvclto creates response files with lines
that are too long for msvc's linker (LNK1170).

Reviewers: hans, rnk, ruiu

Subscribers: llvm-commits, mehdi_amini

Differential Revision: https://reviews.llvm.org/D32185

llvm-svn: 300612
This commit is contained in:
Bob Haarman 2017-04-18 22:00:29 +00:00
parent 34e485f922
commit 630d0c0f44
2 changed files with 5 additions and 5 deletions

View File

@ -509,7 +509,7 @@ filterBitcodeFiles(StringRef Path, std::vector<std::string> &TemporaryFiles) {
// Create response file contents and invoke the MSVC linker. // Create response file contents and invoke the MSVC linker.
void LinkerDriver::invokeMSVC(opt::InputArgList &Args) { void LinkerDriver::invokeMSVC(opt::InputArgList &Args) {
std::string Rsp = "/nologo "; std::string Rsp = "/nologo\n";
std::vector<std::string> Temps; std::vector<std::string> Temps;
for (auto *Arg : Args) { for (auto *Arg : Args) {
@ -528,14 +528,14 @@ void LinkerDriver::invokeMSVC(opt::InputArgList &Args) {
case OPT_INPUT: { case OPT_INPUT: {
if (Optional<StringRef> Path = doFindFile(Arg->getValue())) { if (Optional<StringRef> Path = doFindFile(Arg->getValue())) {
if (Optional<std::string> S = filterBitcodeFiles(*Path, Temps)) if (Optional<std::string> S = filterBitcodeFiles(*Path, Temps))
Rsp += quote(*S) + " "; Rsp += quote(*S) + "\n";
continue; continue;
} }
Rsp += quote(Arg->getValue()) + " "; Rsp += quote(Arg->getValue()) + "\n";
break; break;
} }
default: default:
Rsp += toString(Arg) + " "; Rsp += toString(Arg) + "\n";
} }
} }

View File

@ -634,7 +634,7 @@ void runMSVCLinker(std::string Rsp, ArrayRef<StringRef> Objects) {
std::vector<TemporaryFile> Temps; std::vector<TemporaryFile> Temps;
for (StringRef S : Objects) { for (StringRef S : Objects) {
Temps.emplace_back("lto", "obj", S); Temps.emplace_back("lto", "obj", S);
Rsp += quote(Temps.back().Path) + " "; Rsp += quote(Temps.back().Path) + "\n";
} }
log("link.exe " + Rsp); log("link.exe " + Rsp);