From: Serge Pavlov Date: Sun, 20 Nov 2016 06:25:07 +0000 (+0000) Subject: Fix file name resolution in nested response files X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=15f79356372985e9409a0c3ee16d76a205e6ea88;p=llvm Fix file name resolution in nested response files If a response file in construct `@file` was specified by relative name, constructs `@file` nested within it were resolved incorrectly if the flag RelativeNames in call to ExpandResponseFile was set to true. This feature is used in configuration files, tests for it are in respective change (see D24933). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@287482 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Support/CommandLine.cpp b/lib/Support/CommandLine.cpp index dccb5d6962f..c9751c093d6 100644 --- a/lib/Support/CommandLine.cpp +++ b/lib/Support/CommandLine.cpp @@ -30,6 +30,7 @@ #include "llvm/Support/ConvertUTF.h" #include "llvm/Support/Debug.h" #include "llvm/Support/ErrorHandling.h" +#include "llvm/Support/FileSystem.h" #include "llvm/Support/Host.h" #include "llvm/Support/ManagedStatic.h" #include "llvm/Support/MemoryBuffer.h" @@ -911,6 +912,11 @@ static bool ExpandResponseFile(StringRef FName, StringSaver &Saver, if (llvm::sys::path::is_relative(FileName)) { SmallString<128> ResponseFile; ResponseFile.append(1, '@'); + if (llvm::sys::path::is_relative(FName)) { + SmallString<128> curr_dir; + llvm::sys::fs::current_path(curr_dir); + ResponseFile.append(curr_dir.str()); + } llvm::sys::path::append( ResponseFile, llvm::sys::path::parent_path(FName), FileName); NewArgv[I] = Saver.save(ResponseFile.c_str()).data();