mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-01-16 12:12:44 +08:00
fix cmake build on windows
This commit is contained in:
parent
6ca8b3fd89
commit
2b911b0b10
@ -121,14 +121,28 @@ add_library(mimalloc SHARED ${mi_sources})
|
|||||||
set_target_properties(mimalloc PROPERTIES VERSION ${mi_version} NO_SONAME "YES" OUTPUT_NAME ${mi_basename} )
|
set_target_properties(mimalloc PROPERTIES VERSION ${mi_version} NO_SONAME "YES" OUTPUT_NAME ${mi_basename} )
|
||||||
target_compile_definitions(mimalloc PRIVATE ${mi_defines} MI_SHARED_LIB MI_SHARED_LIB_EXPORT)
|
target_compile_definitions(mimalloc PRIVATE ${mi_defines} MI_SHARED_LIB MI_SHARED_LIB_EXPORT)
|
||||||
target_compile_options(mimalloc PRIVATE ${mi_cflags})
|
target_compile_options(mimalloc PRIVATE ${mi_cflags})
|
||||||
|
target_link_libraries(mimalloc PUBLIC ${mi_libraries})
|
||||||
target_include_directories(mimalloc PUBLIC
|
target_include_directories(mimalloc PUBLIC
|
||||||
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
||||||
$<INSTALL_INTERFACE:${mi_install_dir}/include>
|
$<INSTALL_INTERFACE:${mi_install_dir}/include>
|
||||||
)
|
)
|
||||||
target_link_libraries(mimalloc PUBLIC ${mi_libraries})
|
if(WIN32)
|
||||||
|
# On windows copy the mimalloc redirection dll too.
|
||||||
|
target_link_libraries(mimalloc PRIVATE ../../bin/mimalloc-redirect)
|
||||||
|
add_custom_command(TARGET mimalloc POST_BUILD
|
||||||
|
COMMAND "${CMAKE_COMMAND}" -E copy "../../bin/mimalloc-redirect.dll" $<TARGET_FILE_DIR:mimalloc>
|
||||||
|
COMMENT "Copy mimalloc-redirect.dll to output directory")
|
||||||
|
endif()
|
||||||
|
|
||||||
# static library
|
# static library
|
||||||
add_library(mimalloc-static STATIC ${mi_sources})
|
add_library(mimalloc-static STATIC ${mi_sources})
|
||||||
|
target_compile_definitions(mimalloc-static PRIVATE ${mi_defines} MI_STATIC_LIB)
|
||||||
|
target_compile_options(mimalloc-static PRIVATE ${mi_cflags})
|
||||||
|
target_link_libraries(mimalloc-static PUBLIC ${mi_libraries})
|
||||||
|
target_include_directories(mimalloc-static PUBLIC
|
||||||
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
||||||
|
$<INSTALL_INTERFACE:${mi_install_dir}/include>
|
||||||
|
)
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
# When building both static and shared libraries on Windows, a static library should use a
|
# When building both static and shared libraries on Windows, a static library should use a
|
||||||
# different output name to avoid the conflict with the import library of a shared one.
|
# different output name to avoid the conflict with the import library of a shared one.
|
||||||
@ -137,14 +151,6 @@ if(WIN32)
|
|||||||
else()
|
else()
|
||||||
set_target_properties(mimalloc-static PROPERTIES OUTPUT_NAME ${mi_basename})
|
set_target_properties(mimalloc-static PROPERTIES OUTPUT_NAME ${mi_basename})
|
||||||
endif()
|
endif()
|
||||||
target_compile_definitions(mimalloc-static PRIVATE ${mi_defines} MI_STATIC_LIB)
|
|
||||||
target_compile_options(mimalloc-static PRIVATE ${mi_cflags})
|
|
||||||
|
|
||||||
target_include_directories(mimalloc-static PUBLIC
|
|
||||||
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
|
||||||
$<INSTALL_INTERFACE:${mi_install_dir}/include>
|
|
||||||
)
|
|
||||||
target_link_libraries(mimalloc-static PUBLIC ${mi_libraries})
|
|
||||||
|
|
||||||
# install static and shared library, and the include files
|
# install static and shared library, and the include files
|
||||||
install(TARGETS mimalloc EXPORT mimalloc DESTINATION ${mi_install_dir} LIBRARY NAMELINK_SKIP)
|
install(TARGETS mimalloc EXPORT mimalloc DESTINATION ${mi_install_dir} LIBRARY NAMELINK_SKIP)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user