94 lines
3.0 KiB
CMake
94 lines
3.0 KiB
CMake
set(LLVM_LINK_COMPONENTS
|
|
Core
|
|
ExecutionEngine
|
|
MC
|
|
MCJIT
|
|
Object
|
|
OrcJit
|
|
Option
|
|
RuntimeDyld
|
|
Support
|
|
native
|
|
)
|
|
|
|
add_clang_executable(clang-interpreter
|
|
main.cpp
|
|
)
|
|
|
|
add_dependencies(clang-interpreter
|
|
clang-resource-headers
|
|
)
|
|
|
|
clang_target_link_libraries(clang-interpreter
|
|
PRIVATE
|
|
clangBasic
|
|
clangCodeGen
|
|
clangDriver
|
|
clangFrontend
|
|
clangSerialization
|
|
)
|
|
|
|
export_executable_symbols(clang-interpreter)
|
|
|
|
if (MSVC)
|
|
# Is this a CMake bug that even with export_executable_symbols, Windows
|
|
# needs to explictly export the type_info vtable
|
|
set_property(TARGET clang-interpreter
|
|
APPEND_STRING PROPERTY LINK_FLAGS " /EXPORT:??_7type_info@@6B@")
|
|
endif()
|
|
|
|
function(clang_enable_exceptions TARGET)
|
|
# Really have to jump through hoops to enable exception handling independent
|
|
# of how LLVM is being built.
|
|
if (NOT LLVM_REQUIRES_EH AND NOT LLVM_REQUIRES_RTTI)
|
|
if (MSVC)
|
|
# /EHs to allow throwing from extern "C"
|
|
set(excptnExceptions_ON "/D _HAS_EXCEPTIONS=1 /EHs /wd4714")
|
|
set(excptnExceptions_OFF "/D _HAS_EXCEPTIONS=0 /EHs-c-")
|
|
set(excptnRTTI_ON "/GR")
|
|
set(excptnRTTI_OFF "/GR-")
|
|
set(excptnEHRTTIRegEx "(/EHs(-c-?)|_HAS_EXCEPTIONS=(0|1))")
|
|
else()
|
|
set(excptnExceptions_ON "-fexceptions")
|
|
set(excptnExceptions_OFF "-fno-exceptions")
|
|
set(excptnRTTI_ON "-frtti")
|
|
set(excptnRTTI_OFF "-fno-rtti")
|
|
set(excptnEHRTTIRegEx "-f(exceptions|no-exceptions)")
|
|
endif()
|
|
if (LLVM_REQUIRES_EH)
|
|
set(excptnExceptions_DFLT ${excptnExceptions_ON})
|
|
else()
|
|
set(excptnExceptions_DFLT ${excptnExceptions_OFF})
|
|
endif()
|
|
if (LLVM_REQUIRES_RTTI)
|
|
set(excptnRTTI_DFLT ${excptnRTTI_ON})
|
|
else()
|
|
set(excptnRTTI_DFLT ${excptnRTTI_OFF})
|
|
endif()
|
|
|
|
# Strip the exception & rtti flags from the target
|
|
get_property(addedFlags TARGET ${TARGET} PROPERTY COMPILE_FLAGS)
|
|
string(REGEX REPLACE ${excptnEHRTTIRegEx} "" editedFlags "${addedFlags}")
|
|
string(REPLACE ${excptnRTTI_OFF} "" editedFlags "${editedFlags}")
|
|
set_property(TARGET ${TARGET} PROPERTY COMPILE_FLAGS "${editedFlags}")
|
|
|
|
get_property(addedFlags TARGET ${TARGET} PROPERTY COMPILE_DEFINITIONS)
|
|
string(REGEX REPLACE ${excptnEHRTTIRegEx} "" editedFlags "${addedFlags}")
|
|
string(REPLACE ${excptnRTTI_OFF} "" editedFlags "${editedFlags}")
|
|
set_property(TARGET ${TARGET} PROPERTY COMPILE_DEFINITIONS "${editedFlags}")
|
|
|
|
# Re-add the exception & rtti flags from LLVM
|
|
set_property(SOURCE main.cpp APPEND_STRING PROPERTY COMPILE_FLAGS
|
|
" ${excptnExceptions_DFLT} ${excptnRTTI_DFLT} ")
|
|
set_property(SOURCE Manager.cpp APPEND_STRING PROPERTY COMPILE_FLAGS
|
|
" ${excptnExceptions_DFLT} ${excptnRTTI_DFLT} ")
|
|
|
|
# Invoke with exceptions & rtti
|
|
set_property(SOURCE Invoke.cpp APPEND_STRING PROPERTY COMPILE_FLAGS
|
|
" ${excptnExceptions_ON} ${excptnRTTI_ON} ")
|
|
|
|
endif()
|
|
endfunction(clang_enable_exceptions)
|
|
|
|
clang_enable_exceptions(clang-interpreter)
|