[libcxx] Redo adding support for building and testing with an ABI library not along...
authorEric Fiselier <eric@efcs.ca>
Sun, 19 Oct 2014 00:42:41 +0000 (00:42 +0000)
committerEric Fiselier <eric@efcs.ca>
Sun, 19 Oct 2014 00:42:41 +0000 (00:42 +0000)
commita63c149ceb0e68037df3b7838ed55f6724280b33
tree66459725f6d7ee86c2cf540e9f97e310a54715a5
parent8a99373812cfc7feb30c28ef5fb23c774856eb38
[libcxx] Redo adding support for building and testing with an ABI library not along linker paths

Summary:
This is the second attempt at allowing for the use of libraries that the linker cannot find. The first attempt used `CMAKE_LIBRARY_PATH` and `find_library` to select which ABI library should be used. There were a number of problems with this approach:

- `find_library` didn't work with cmake targets (ie in-tree libcxxabi build)
- It wasn't always possible to determine where `find_library` actually found your library.
- `target_link_libraries` inserted the path of the ABI library into libc++'s RPATH when `find_library` was used.
- Linking libc++ and it's ABI library is a special case. It's a lot easier to keep it simple.

After discussion with @cbergstrum a new approach was decided upon.
This patch achieve the same ends by simply using `LIBCXX_CXX_ABI_LIBRARY_PATH` to specify where to find the library (if the linker won't find it). When this variable is defined it is simply added as a library search path when linking libc++. It is a lot easier to duplicate this behavior in LIT. It also prevents libc++ from being linked with an RPATH.

Reviewers: mclow.lists, cbergstrom, chandlerc, danalbert

Reviewed By: chandlerc, danalbert

Subscribers: chandlerc, cfe-commits

Differential Revision: http://reviews.llvm.org/D5860

llvm-svn: 220157
libcxx/cmake/Modules/HandleLibCXXABI.cmake
libcxx/lib/CMakeLists.txt
libcxx/test/lit.cfg
libcxx/test/lit.site.cfg.in
libcxx/www/index.html