diff options
| -rw-r--r-- | lld/lib/Core/Reproduce.cpp | 2 | ||||
| -rw-r--r-- | lld/test/ELF/reproduce-backslash.s | 9 |
2 files changed, 11 insertions, 0 deletions
diff --git a/lld/lib/Core/Reproduce.cpp b/lld/lib/Core/Reproduce.cpp index a6f5019702e..5ff668e64fc 100644 --- a/lld/lib/Core/Reproduce.cpp +++ b/lld/lib/Core/Reproduce.cpp @@ -53,7 +53,9 @@ static void writeMember(raw_fd_ostream &OS, StringRef Path, StringRef Data) { // Converts path to use unix path separators so the cpio can be extracted on // both unix and windows. static void convertToUnixPathSeparator(SmallString<128> &Path) { +#ifdef LLVM_ON_WIN32 std::replace(Path.begin(), Path.end(), '\\', '/'); +#endif } void CpioFile::append(StringRef Path, StringRef Data) { diff --git a/lld/test/ELF/reproduce-backslash.s b/lld/test/ELF/reproduce-backslash.s new file mode 100644 index 00000000000..a694bfcfb77 --- /dev/null +++ b/lld/test/ELF/reproduce-backslash.s @@ -0,0 +1,9 @@ +# REQUIRES: x86, cpio, shell + +# Test that we don't erroneously replace \ with / on UNIX, as it's +# legal for a filename to contain backslashes. +# RUN: llvm-mc %s -o foo\\.o -filetype=obj -triple=x86_64-pc-linux +# RUN: ld.lld foo\\.o --reproduce repro +# RUN: cpio -t < repro.cpio | FileCheck %s + +# CHECK: repro/{{.*}}/foo\.o |

