diff options
| author | Nico Weber <thakis@chromium.org> | 2021-06-07 11:00:34 -0400 | 
|---|---|---|
| committer | Nico Weber <thakis@chromium.org> | 2021-06-07 17:04:03 -0400 | 
| commit | 17c43c404535fe427d2cddb665154ae601d505bd (patch) | |
| tree | 6b80b47b50c9300d14b44a6dcd220883ceb776b0 /libcxx/include/__algorithm/equal.h | |
| parent | 8ec73e96b72d04787ed606cfbb62a7a2a05b3711 (diff) | |
| download | llvm-17c43c404535fe427d2cddb665154ae601d505bd.zip llvm-17c43c404535fe427d2cddb665154ae601d505bd.tar.gz llvm-17c43c404535fe427d2cddb665154ae601d505bd.tar.bz2 | |
[lld/mac] Add reexports after reexporter to inputFiles
When a library "host"'s reexports change their installName with
`$ld$os10.11$install_name$host`, we used to write a load command for "host" but
write the version numbers of the reexport instead of "host". This fixes that.
I first thought that the rule is to take the version numbers from the library
that originally had that install name (implemented in D103819), but that's not
what ld64 seems to be doing: It takes the version number from the first dylib
with that install name it loads, and it loads the reexporting library before
the reexports. We already did most of that, we just added reexports before the
reexporter. After this change, we add the reexporter before the reexports.
Addresses https://bugs.llvm.org/show_bug.cgi?id=49800#c11 part 1.
(ld64 seems to add reexports after processing _all_ files on the command line,
while we add them right after the reexporter. For the common case of reexport +
$ld$ symbol changing back to the exporter name, this doesn't make a difference,
but you can construct a case where it does. I expect this to not make a
difference in practice though.)
Differential Revision: https://reviews.llvm.org/D103821
Diffstat (limited to 'libcxx/include/__algorithm/equal.h')
0 files changed, 0 insertions, 0 deletions
