2019-07-12 05:42:55 +08:00
|
|
|
# Building libclang-cpp.so fails if LLVM_ENABLE_PIC=Off
|
2019-05-17 12:20:01 +08:00
|
|
|
if (NOT LLVM_ENABLE_PIC)
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
get_property(clang_libs GLOBAL PROPERTY CLANG_STATIC_LIBS)
|
|
|
|
|
|
|
|
foreach (lib ${clang_libs})
|
2019-10-05 02:17:58 +08:00
|
|
|
if(XCODE)
|
|
|
|
# Xcode doesn't support object libraries, so we have to trick it into
|
|
|
|
# linking the static libraries instead.
|
|
|
|
list(APPEND _DEPS "-force_load" ${lib})
|
|
|
|
else()
|
|
|
|
list(APPEND _OBJECTS $<TARGET_OBJECTS:obj.${lib}>)
|
|
|
|
endif()
|
2019-07-13 01:23:35 +08:00
|
|
|
list(APPEND _DEPS $<TARGET_PROPERTY:${lib},INTERFACE_LINK_LIBRARIES>)
|
2020-02-05 05:06:54 +08:00
|
|
|
|
|
|
|
# clang libraries are redundant since we are linking all the individual
|
|
|
|
# object files into libclang-cpp.so, so filter them out from _DEPS.
|
|
|
|
# This avoids problems with LLVM global data when building with
|
|
|
|
# BUILD_SHARED_LIBS=ON
|
|
|
|
# FIXME: We could use list(FILTER) with cmake >= 3.6
|
|
|
|
# FIXME: With cmake >= 3.15 we could use the generator expression
|
|
|
|
# $<FILTER:list,INCLUDE|EXCLUDE,regex>
|
|
|
|
get_target_property(interface ${lib} LINK_LIBRARIES)
|
|
|
|
if (interface)
|
|
|
|
foreach(lib ${interface})
|
|
|
|
if (NOT ${lib} MATCHES "^clang")
|
|
|
|
list(APPEND _DEPS ${lib})
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endif()
|
2019-05-17 12:20:01 +08:00
|
|
|
endforeach ()
|
|
|
|
|
2019-07-12 23:11:28 +08:00
|
|
|
if (CLANG_LINK_CLANG_DYLIB)
|
|
|
|
set(INSTALL_WITH_TOOLCHAIN INSTALL_WITH_TOOLCHAIN)
|
|
|
|
endif()
|
|
|
|
|
2019-07-12 05:42:55 +08:00
|
|
|
add_clang_library(clang-cpp
|
2019-05-17 12:20:01 +08:00
|
|
|
SHARED
|
2019-07-12 23:11:28 +08:00
|
|
|
${INSTALL_WITH_TOOLCHAIN}
|
2019-05-17 12:20:01 +08:00
|
|
|
clang-shlib.cpp
|
|
|
|
${_OBJECTS}
|
|
|
|
LINK_LIBS
|
|
|
|
${_DEPS})
|