Link LLVM-based tools dynamically to LLVM (take 2) (#441)

This is a revival of #397 but only applies the logic to non-Windows
platforms. Windows builds still seem to not work so Windows is not
improved as a result of this change.
pull/443/head
Alex Crichton 7 months ago committed by GitHub
parent 2e7bb65533
commit 778a02bb08
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -55,6 +55,19 @@ set(tools
c++filt c++filt
llvm-config) llvm-config)
# By default link LLVM dynamically to all the various tools. This greatly
# reduces the binary size of all the tools through a shared library rather than
# statically linking LLVM to each individual tool. This requires a few other
# install targets as well to ensure the appropriate libraries are all installed.
#
# Also note that the `-wasi-sdk` version suffix is intended to help prevent
# these dynamic libraries from clashing with other system libraries in case the
# `lib` dir gets put on `LD_LIBRARY_PATH` or similar.
if(NOT WIN32)
list(APPEND default_cmake_args -DLLVM_LINK_LLVM_DYLIB=ON -DLLVM_VERSION_SUFFIX=-wasi-sdk)
list(APPEND tools LLVM clang-cpp)
endif()
list(TRANSFORM tools PREPEND --target= OUTPUT_VARIABLE build_targets) list(TRANSFORM tools PREPEND --target= OUTPUT_VARIABLE build_targets)
list(TRANSFORM tools PREPEND --target=install- OUTPUT_VARIABLE install_targets) list(TRANSFORM tools PREPEND --target=install- OUTPUT_VARIABLE install_targets)

Loading…
Cancel
Save