2017-04-01 05:10:53 +08:00
|
|
|
MSVC's lib.exe produces archives with absolute paths to the members. It's useful
|
|
|
|
for llvm-ar to extract them to their basename in the CWD, since usually the
|
|
|
|
directories in the path in the archive won't exist during archive extraction.
|
|
|
|
|
|
|
|
Get a temp clean cwd to extract into.
|
|
|
|
RUN: rm -rf %t && mkdir %t && cd %t
|
|
|
|
|
|
|
|
RUN: llvm-ar t %S/Inputs/absolute-paths.lib | FileCheck %s --check-prefix=CHECK-LIST
|
|
|
|
CHECK-LIST: C:/src/llvm-project/build/dne/b.o
|
|
|
|
CHECK-LIST: C:/src/llvm-project/build/dne/a.o
|
|
|
|
|
|
|
|
Check that a.o comes out and defines foo.
|
[llvm-ar] Implement the P modifier.
Summary:
GNU ar has a `P` modifier that changes filename comparisons to use full paths instead of the basename. As noted in the GNU docs, regular archives are not created with full path names, so P is used to deal with archives created by other archive programs (e.g. see the updated `absolute-paths.test` test case).
Since thin archives use full path names -- paths are relative to the archive -- it seems very error prone to not imply P when dealing with thin archives, so P is implied in those cases. (I think this is a deviation from GNU ar that makes sense).
This fixes PR37436 via https://github.com/ClangBuiltLinux/linux/issues/33.
Reviewers: mstorsjo, pcc, ruiu, davide, david2050, rnk
Subscribers: tpimh, llvm-commits, nickdesaulniers
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D57927
llvm-svn: 354044
2019-02-15 02:35:13 +08:00
|
|
|
RUN: llvm-ar xP %S/Inputs/absolute-paths.lib 'C:/src/llvm-project/build/dne/a.o'
|
2017-04-01 05:10:53 +08:00
|
|
|
RUN: llvm-nm a.o | FileCheck %s --check-prefix=CHECK-A
|
|
|
|
CHECK-A: T foo
|
|
|
|
|
|
|
|
Check that b.o comes out and defines bar.
|
[llvm-ar] Implement the P modifier.
Summary:
GNU ar has a `P` modifier that changes filename comparisons to use full paths instead of the basename. As noted in the GNU docs, regular archives are not created with full path names, so P is used to deal with archives created by other archive programs (e.g. see the updated `absolute-paths.test` test case).
Since thin archives use full path names -- paths are relative to the archive -- it seems very error prone to not imply P when dealing with thin archives, so P is implied in those cases. (I think this is a deviation from GNU ar that makes sense).
This fixes PR37436 via https://github.com/ClangBuiltLinux/linux/issues/33.
Reviewers: mstorsjo, pcc, ruiu, davide, david2050, rnk
Subscribers: tpimh, llvm-commits, nickdesaulniers
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D57927
llvm-svn: 354044
2019-02-15 02:35:13 +08:00
|
|
|
RUN: llvm-ar xP %S/Inputs/absolute-paths.lib C:/src/llvm-project/build/dne/b.o
|
2017-04-01 05:10:53 +08:00
|
|
|
RUN: llvm-nm b.o | FileCheck %s --check-prefix=CHECK-B
|
|
|
|
CHECK-B: T bar
|
[llvm-ar] Implement the P modifier.
Summary:
GNU ar has a `P` modifier that changes filename comparisons to use full paths instead of the basename. As noted in the GNU docs, regular archives are not created with full path names, so P is used to deal with archives created by other archive programs (e.g. see the updated `absolute-paths.test` test case).
Since thin archives use full path names -- paths are relative to the archive -- it seems very error prone to not imply P when dealing with thin archives, so P is implied in those cases. (I think this is a deviation from GNU ar that makes sense).
This fixes PR37436 via https://github.com/ClangBuiltLinux/linux/issues/33.
Reviewers: mstorsjo, pcc, ruiu, davide, david2050, rnk
Subscribers: tpimh, llvm-commits, nickdesaulniers
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D57927
llvm-svn: 354044
2019-02-15 02:35:13 +08:00
|
|
|
|
|
|
|
xP above is only required because we were explicitly extracting items from an
|
|
|
|
archive with absolute paths. Extracting all objects doesn't need P because we
|
|
|
|
aren't explicitly requesting any individual object.
|
|
|
|
RUN: rm -f a.o b.o
|
|
|
|
RUN: llvm-ar x %S/Inputs/absolute-paths.lib
|
|
|
|
RUN: llvm-nm a.o | FileCheck %s --check-prefix=CHECK-A
|
|
|
|
RUN: llvm-nm b.o | FileCheck %s --check-prefix=CHECK-B
|