aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp
diff options
context:
space:
mode:
authorJordan Rupprecht <rupprecht@google.com>2019-02-13 23:39:41 +0000
committerJordan Rupprecht <rupprecht@google.com>2019-02-13 23:39:41 +0000
commit451c2ef199e9c5163007ac32e2d426fbfb37e664 (patch)
treecd57778f72c88b3361134816f3b72645907ceaa1 /llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp
parent1113940df2f81d60848d6e955d353b53397c84aa (diff)
downloadllvm-451c2ef199e9c5163007ac32e2d426fbfb37e664.zip
llvm-451c2ef199e9c5163007ac32e2d426fbfb37e664.tar.gz
llvm-451c2ef199e9c5163007ac32e2d426fbfb37e664.tar.bz2
[llvm-ar][libObject] Fix relative paths when nesting thin archives.
Summary: When adding one thin archive to another, we currently chop off the relative path to the flattened members. For instance, when adding `foo/child.a` (which contains `x.txt`) to `parent.a`, when flattening it we should add it as `foo/x.txt` (which exists) instead of `x.txt` (which does not exist). As a note, this also undoes the `IsNew` parameter of handling relative paths in r288280. The unit test there still passes. This was reported as part of testing the kernel build with llvm-ar: https://patchwork.kernel.org/patch/10767545/ (see the second point). Reviewers: mstorsjo, pcc, ruiu, davide, david2050, inglorion Reviewed By: ruiu Subscribers: void, jdoerfert, tpimh, mgorny, hans, nickdesaulniers, hiraditya, llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D57842 llvm-svn: 353995
Diffstat (limited to 'llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp')
-rw-r--r--llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp b/llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp
index 3a5b972..34a8314 100644
--- a/llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp
+++ b/llvm/lib/ToolDrivers/llvm-lib/LibDriver.cpp
@@ -208,6 +208,13 @@ int llvm::libDriverMain(ArrayRef<const char *> ArgsArr) {
// Create an archive file.
std::string OutputPath = getOutputPath(&Args, Members[0]);
+ // llvm-lib uses relative paths for both regular and thin archives, unlike
+ // standard GNU ar, which only uses relative paths for thin archives and
+ // basenames for regular archives.
+ for (NewArchiveMember &Member : Members)
+ Member.MemberName =
+ Saver.save(computeArchiveRelativePath(OutputPath, Member.MemberName));
+
if (Error E =
writeArchive(OutputPath, Members,
/*WriteSymtab=*/true, object::Archive::K_GNU,