[PATCH] D53066: [RFC] [Driver] Use forward slashes in most linker arguments
Martin Storsjö via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Sat Oct 13 14:12:17 PDT 2018
mstorsjo updated this revision to Diff 169579.
mstorsjo retitled this revision from "[RFC] [MinGW] Print paths with forward slashes in commands printed with -v" to "[RFC] [Driver] Use forward slashes in most linker arguments".
mstorsjo edited the summary of this revision.
mstorsjo added a comment.
Tested the earlier discussed solution, and it seems to work fine for my particular case with libtool.
https://reviews.llvm.org/D53066
Files:
lib/Driver/ToolChain.cpp
Index: lib/Driver/ToolChain.cpp
===================================================================
--- lib/Driver/ToolChain.cpp
+++ lib/Driver/ToolChain.cpp
@@ -378,15 +378,15 @@
SmallString<128> P(LibPath);
llvm::sys::path::append(P, Prefix + Twine("clang_rt.") + Component + Suffix);
if (getVFS().exists(P))
- return P.str();
+ return llvm::sys::path::convert_to_slash(P);
}
StringRef Arch = getArchNameForCompilerRTLib(*this, Args);
const char *Env = TT.isAndroid() ? "-android" : "";
SmallString<128> Path(getCompilerRTPath());
llvm::sys::path::append(Path, Prefix + Twine("clang_rt.") + Component + "-" +
Arch + Env + Suffix);
- return Path.str();
+ return llvm::sys::path::convert_to_slash(Path);
}
const char *ToolChain::getCompilerRTArgString(const llvm::opt::ArgList &Args,
@@ -425,7 +425,7 @@
}
std::string ToolChain::GetFilePath(const char *Name) const {
- return D.GetFilePath(Name, *this);
+ return llvm::sys::path::convert_to_slash(D.GetFilePath(Name, *this));
}
std::string ToolChain::GetProgramPath(const char *Name) const {
@@ -774,12 +774,14 @@
void ToolChain::AddFilePathLibArgs(const ArgList &Args,
ArgStringList &CmdArgs) const {
for (const auto &LibPath : getLibraryPaths())
- if(LibPath.length() > 0)
- CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
+ if (LibPath.length() > 0)
+ CmdArgs.push_back(Args.MakeArgString(
+ StringRef("-L") + llvm::sys::path::convert_to_slash(LibPath)));
for (const auto &LibPath : getFilePaths())
- if(LibPath.length() > 0)
- CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
+ if (LibPath.length() > 0)
+ CmdArgs.push_back(Args.MakeArgString(
+ StringRef("-L") + llvm::sys::path::convert_to_slash(LibPath)));
}
void ToolChain::AddCCKextLibArgs(const ArgList &Args,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D53066.169579.patch
Type: text/x-patch
Size: 1949 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20181013/07bb0e2e/attachment.bin>
More information about the cfe-commits
mailing list