@@ -148,6 +148,8 @@ if(UMF_DEVELOPER_MODE)
148148 UMF_DEVELOPER_MODE=1)
149149endif ()
150150
151+ message (STATUS "CMAKE_PREFIX_PATH=${CMAKE_PREFIX_PATH} " )
152+
151153if (NOT UMF_BUILD_LIBUMF_POOL_JEMALLOC)
152154 set (UMF_POOL_JEMALLOC_ENABLED FALSE )
153155 set (JEMALLOC_FOUND FALSE )
@@ -429,24 +431,86 @@ elseif(UMF_BUILD_CUDA_PROVIDER)
429431endif ()
430432
431433if (WINDOWS AND UMF_USE_DEBUG_POSTFIX )
432- # Build debug umf library with the d suffix that is compiled with /MDd so
433- # users can link against it in debug builds.
434- set (CMAKE_DEBUG_POSTFIX d)
435-
434+ # Build the umfd target in a separate directory with Debug configuration
435+ string (JOIN "\; " UMFD_CMAKE_PREFIX_PATH ${CMAKE_PREFIX_PATH} )
436436 add_custom_target (
437- umfd ALL
438- COMMAND ${CMAKE_COMMAND} --build ${CMAKE_BINARY_DIR} --target umf
439- --config Debug
440- COMMENT "Building debug umf library with the d suffix" )
437+ build_umfd ALL
438+ COMMAND
439+ ${CMAKE_COMMAND} -G "${CMAKE_GENERATOR} " -S ${UMF_CMAKE_SOURCE_DIR}
440+ -B ${CMAKE_BINARY_DIR} /umfd_build -DCMAKE_BUILD_TYPE=Debug
441+ -DCMAKE_DEBUG_POSTFIX =d
442+ -DCMAKE_PREFIX_PATH="${UMFD_CMAKE_PREFIX_PATH} "
443+ -DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
444+ -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
445+ -DUMF_USE_DEBUG_POSTFIX =OFF
446+ -DUMF_BUILD_SHARED_LIBRARY=${UMF_BUILD_SHARED_LIBRARY}
447+ -DUMF_BUILD_LEVEL_ZERO_PROVIDER=${UMF_BUILD_LEVEL_ZERO_PROVIDER}
448+ -DUMF_BUILD_CUDA_PROVIDER=${UMF_BUILD_CUDA_PROVIDER}
449+ -DUMF_BUILD_LIBUMF_POOL_JEMALLOC=${UMF_BUILD_LIBUMF_POOL_JEMALLOC}
450+ -DUMF_BUILD_TESTS=OFF -DUMF_BUILD_GPU_TESTS=OFF
451+ -DUMF_BUILD_BENCHMARKS=OFF -DUMF_BUILD_BENCHMARKS_MT=OFF
452+ -DUMF_BUILD_EXAMPLES=OFF -DUMF_BUILD_GPU_EXAMPLES=OFF
453+ -DUMF_BUILD_FUZZTESTS=OFF -DUMF_DISABLE_HWLOC=${UMF_DISABLE_HWLOC}
454+ -DUMF_LINK_HWLOC_STATICALLY=${UMF_LINK_HWLOC_STATICALLY}
455+ -DUMF_HWLOC_NAME=${UMF_HWLOC_NAME}
456+ -DUMF_INSTALL_RPATH=${UMF_INSTALL_RPATH} -DUMF_DEVELOPER_MODE=OFF
457+ -DUMF_FORMAT_CODE_STYLE=OFF -DUMF_TESTS_FAIL_ON_SKIP=OFF
458+ -DUMF_USE_ASAN=OFF -DUMF_USE_UBSAN=OFF -DUMF_USE_TSAN=OFF
459+ -DUMF_USE_MSAN=OFF -DUMF_USE_VALGRIND=OFF -DUMF_USE_COVERAGE=OFF
460+ -DUMF_PROXY_LIB_BASED_ON_POOL=${UMF_PROXY_LIB_BASED_ON_POOL}
461+ COMMAND ${CMAKE_COMMAND} --build ${CMAKE_BINARY_DIR} /umfd_build --target
462+ umf --config Debug
463+ COMMENT
464+ "Configuring and building umfd.dll in a separate directory with Debug configuration"
465+ )
441466
442- # Copy built UMF libraries to the Release build subdirectory
443- add_custom_command (
444- TARGET umfd
445- COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_BINARY_DIR} /bin/Debug/umfd.dll
446- ${CMAKE_BINARY_DIR} /bin/Release/umfd.dll
447- COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_BINARY_DIR} /lib/Debug/umfd.lib
448- ${CMAKE_BINARY_DIR} /lib/Release/umfd.lib
449- COMMENT "Copying debug libraries to the Release build directory" )
467+ # Copy built UMF libraries to the main binary directory and remove
468+ # umfd_build
469+ if (CMAKE_CONFIGURATION_TYPES )
470+ # Multi-config generator (e.g., Visual Studio)
471+ if (UMF_BUILD_SHARED_LIBRARY)
472+ add_custom_command (
473+ TARGET build_umfd
474+ COMMAND
475+ ${CMAKE_COMMAND} -E copy_if_different
476+ ${CMAKE_BINARY_DIR} /umfd_build/bin/Debug/umfd.dll
477+ ${CMAKE_BINARY_DIR} /bin/$<CONFIG>/umfd.dll
478+ COMMENT "Copying umfd.dll to the main binary directory" )
479+ endif ()
480+ add_custom_command (
481+ TARGET build_umfd
482+ COMMAND
483+ ${CMAKE_COMMAND} -E copy_if_different
484+ ${CMAKE_BINARY_DIR} /umfd_build/lib/Debug/umfd.lib
485+ ${CMAKE_BINARY_DIR} /lib/$<CONFIG>/umfd.lib
486+ COMMAND
487+ ${CMAKE_COMMAND} -E remove_directory
488+ ${CMAKE_BINARY_DIR} /umfd_build DEPENDS
489+ ${CMAKE_BINARY_DIR} /bin/$<CONFIG>/umfd.dll
490+ COMMENT "Copying umfd.lib to the main library directory" )
491+ else ()
492+ # Single-config generator (e.g., Ninja)
493+ if (UMF_BUILD_SHARED_LIBRARY)
494+ add_custom_command (
495+ TARGET build_umfd
496+ COMMAND
497+ ${CMAKE_COMMAND} -E copy_if_different
498+ ${CMAKE_BINARY_DIR} /umfd_build/bin/umfd.dll
499+ ${CMAKE_BINARY_DIR} /bin/umfd.dll
500+ COMMENT "Copying umfd.dll file to the main binary directory" )
501+ endif ()
502+ add_custom_command (
503+ TARGET build_umfd
504+ COMMAND
505+ ${CMAKE_COMMAND} -E copy_if_different
506+ ${CMAKE_BINARY_DIR} /umfd_build/lib/umfd.lib
507+ ${CMAKE_BINARY_DIR} /lib/umfd.lib
508+ COMMAND
509+ ${CMAKE_COMMAND} -E remove_directory
510+ ${CMAKE_BINARY_DIR} /umfd_build DEPENDS
511+ ${CMAKE_BINARY_DIR} /bin/umfd.dll
512+ COMMENT "Copying umfd.lib file to the main library directory" )
513+ endif ()
450514endif ()
451515
452516# This build type check is not possible on Windows when CMAKE_BUILD_TYPE is not
@@ -841,12 +905,24 @@ endif()
841905# --------------------------------------------------------------------------- #
842906# Configure make install/uninstall and packages
843907# --------------------------------------------------------------------------- #
844- # Install umfd target
908+ # Install the umfd library files as part of the umfd component
845909if (WINDOWS AND UMF_USE_DEBUG_POSTFIX )
846- install (FILES ${CMAKE_BINARY_DIR} /bin/Debug/umfd.dll
847- DESTINATION ${CMAKE_INSTALL_BINDIR} )
848- install (FILES ${CMAKE_BINARY_DIR} /lib/Debug/umfd.lib
849- DESTINATION ${CMAKE_INSTALL_LIBDIR} )
910+ if (CMAKE_CONFIGURATION_TYPES )
911+ set (UMFD_DLL "${CMAKE_BINARY_DIR} /bin/$<CONFIG>/umfd.dll" )
912+ set (UMFD_LIB "${CMAKE_BINARY_DIR} /lib/$<CONFIG>/umfd.lib" )
913+ else ()
914+ set (UMFD_DLL "${CMAKE_BINARY_DIR} /bin/umfd.dll" )
915+ set (UMFD_LIB "${CMAKE_BINARY_DIR} /lib/umfd.lib" )
916+ endif ()
917+
918+ install (
919+ FILES ${UMFD_DLL}
920+ DESTINATION ${CMAKE_INSTALL_BINDIR}
921+ COMPONENT umfd)
922+ install (
923+ FILES ${UMFD_LIB}
924+ DESTINATION ${CMAKE_INSTALL_LIBDIR}
925+ COMPONENT umfd)
850926endif ()
851927
852928install (FILES ${PROJECT_SOURCE_DIR} /LICENSE.TXT
0 commit comments