[libc++][CMake] Link against libSystem on Apple platforms
Instead of manually linking against libm/librt/libpthread, we should be
linking against libSystem on Apple platforms, and only that. libm and
libpthread are symlinks to libSystem anyway.
llvm-svn: 359808
GitOrigin-RevId: 223ed705d0d3c3b07f00202a04447df836c05df8
diff --git a/cmake/config-ix.cmake b/cmake/config-ix.cmake
index 730ee7e..23ae710 100644
--- a/cmake/config-ix.cmake
+++ b/cmake/config-ix.cmake
@@ -80,8 +80,15 @@
set(LIBCXX_HAS_PTHREAD_LIB NO)
set(LIBCXX_HAS_M_LIB NO)
set(LIBCXX_HAS_RT_LIB NO)
+ set(LIBCXX_HAS_SYSTEM_LIB NO)
+elseif(APPLE)
+ check_library_exists(System write "" LIBCXX_HAS_SYSTEM_LIB)
+ set(LIBCXX_HAS_PTHREAD_LIB NO)
+ set(LIBCXX_HAS_M_LIB NO)
+ set(LIBCXX_HAS_RT_LIB NO)
else()
check_library_exists(pthread pthread_create "" LIBCXX_HAS_PTHREAD_LIB)
check_library_exists(m ccos "" LIBCXX_HAS_M_LIB)
check_library_exists(rt clock_gettime "" LIBCXX_HAS_RT_LIB)
+ set(LIBCXX_HAS_SYSTEM_LIB NO)
endif()
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 3c31548..5d9cc01 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -140,6 +140,10 @@
target_add_compile_flags_if_supported(${target} PRIVATE "/Zl")
target_add_link_flags_if_supported(${target} PRIVATE "/nodefaultlib")
+ if (LIBCXX_HAS_SYSTEM_LIB)
+ target_link_libraries(${target} PUBLIC System)
+ endif()
+
if (LIBCXX_HAS_PTHREAD_LIB)
target_link_libraries(${target} PUBLIC pthread)
endif()