ENH: Add second part of SimpleInstall
This commit is contained in:
parent
31c1071ebf
commit
e72bac5870
|
@ -251,6 +251,19 @@ IF(BUILD_TESTING)
|
||||||
--build-options
|
--build-options
|
||||||
"-DCMAKE_INSTALL_PREFIX:PATH=${SimpleInstallInstallDir}"
|
"-DCMAKE_INSTALL_PREFIX:PATH=${SimpleInstallInstallDir}"
|
||||||
--test-command ${SimpleInstallInstallDir}/bin/SimpleInstall)
|
--test-command ${SimpleInstallInstallDir}/bin/SimpleInstall)
|
||||||
|
ADD_TEST(SimpleInstall-Stage2 ${CMAKE_CTEST_COMMAND}
|
||||||
|
--build-and-test
|
||||||
|
"${CMake_SOURCE_DIR}/Tests/SimpleInstall"
|
||||||
|
"${CMake_BINARY_DIR}/Tests/SimpleInstallS2"
|
||||||
|
--build-generator ${CMAKE_GENERATOR}
|
||||||
|
--build-project TestSimpleInstall
|
||||||
|
--build-makeprogram ${MAKEPROGRAM}
|
||||||
|
--build-two-config
|
||||||
|
--build-options
|
||||||
|
"-DCMAKE_INSTALL_PREFIX:PATH=${SimpleInstallInstallDir}"
|
||||||
|
"-DSTAGE2:BOOL=1"
|
||||||
|
--test-command
|
||||||
|
${CMake_BINARY_DIR}/Tests/SimpleInstallS2/ExecPath/SimpleInstallS2)
|
||||||
|
|
||||||
ADD_TEST(X11 ${CMAKE_CTEST_COMMAND}
|
ADD_TEST(X11 ${CMAKE_CTEST_COMMAND}
|
||||||
--build-and-test
|
--build-and-test
|
||||||
|
|
|
@ -5,43 +5,62 @@ SET(EXECUTABLE_OUTPUT_PATH "${TestSimpleInstall_BINARY_DIR}/ExecPath")
|
||||||
SET(LIBRARY_OUTPUT_PATH "${EXECUTABLE_OUTPUT_PATH}")
|
SET(LIBRARY_OUTPUT_PATH "${EXECUTABLE_OUTPUT_PATH}")
|
||||||
|
|
||||||
SET(CMAKE_DEBUG_POSTFIX "_test_debug_postfix")
|
SET(CMAKE_DEBUG_POSTFIX "_test_debug_postfix")
|
||||||
ADD_LIBRARY(test1 STATIC lib1.cxx)
|
|
||||||
ADD_LIBRARY(test2 SHARED lib2.cxx)
|
|
||||||
ADD_LIBRARY(test3 MODULE lib3.cxx)
|
|
||||||
ADD_EXECUTABLE (SimpleInstall inst.cxx foo.c foo.h)
|
|
||||||
TARGET_LINK_LIBRARIES(SimpleInstall test1 test2)
|
|
||||||
|
|
||||||
ADD_DEPENDENCIES(SimpleInstall test3)
|
IF(STAGE2)
|
||||||
|
FIND_LIBRARY(TEST1_LIBRARY
|
||||||
|
NAMES test1 test1${CMAKE_DEBUG_POSTFIX}
|
||||||
|
PATHS "${CMAKE_INSTALL_PREFIX}/lib"
|
||||||
|
DOC "First library")
|
||||||
|
FIND_LIBRARY(TEST2_LIBRARY
|
||||||
|
NAMES test2 test2${CMAKE_DEBUG_POSTFIX}
|
||||||
|
PATHS "${CMAKE_INSTALL_PREFIX}/lib"
|
||||||
|
DOC "First library")
|
||||||
|
ADD_EXECUTABLE (SimpleInstallS2 inst.cxx foo.c foo.h)
|
||||||
|
TARGET_LINK_LIBRARIES(SimpleInstallS2 ${TEST1_LIBRARY} ${TEST2_LIBRARY})
|
||||||
|
|
||||||
INSTALL_TARGETS(/bin SimpleInstall)
|
ELSE(STAGE2)
|
||||||
INSTALL_TARGETS(/lib test1 test2 test3)
|
# this is stage 1, so create libraries and modules and install everything
|
||||||
INSTALL_TARGETS(/include lib1.h lib2.h lib3.h)
|
ADD_LIBRARY(test1 STATIC lib1.cxx)
|
||||||
|
ADD_LIBRARY(test2 SHARED lib2.cxx)
|
||||||
|
ADD_LIBRARY(test3 MODULE lib3.cxx)
|
||||||
|
|
||||||
SET(EXTRA_INSTALL_FLAGS)
|
|
||||||
IF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
|
||||||
MESSAGE("CMake generator: ${CMAKE_GENERATOR}")
|
|
||||||
FOREACH(build_type Debug Release RelWithDebInfo MinSizeRel)
|
|
||||||
IF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
|
||||||
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
|
||||||
ENDIF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
|
||||||
IF(MAKEPROGRAM MATCHES "- ${build_type}")
|
|
||||||
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
|
||||||
ENDIF(MAKEPROGRAM MATCHES "- ${build_type}")
|
|
||||||
ENDFOREACH(build_type)
|
|
||||||
IF(NOT EXTRA_INSTALL_FLAGS)
|
|
||||||
IF(BUILD_TYPE)
|
|
||||||
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${BUILD_TYPE})
|
|
||||||
ENDIF(BUILD_TYPE)
|
|
||||||
ENDIF(NOT EXTRA_INSTALL_FLAGS)
|
|
||||||
ENDIF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
|
||||||
|
|
||||||
MESSAGE("Extra install: ${EXTRA_INSTALL_FLAGS}")
|
|
||||||
|
|
||||||
ADD_CUSTOM_COMMAND(
|
SET(EXTRA_INSTALL_FLAGS)
|
||||||
TARGET SimpleInstall
|
IF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
||||||
POST_BUILD
|
MESSAGE("CMake generator: ${CMAKE_GENERATOR}")
|
||||||
COMMAND ${CMAKE_COMMAND}
|
FOREACH(build_type Debug Release RelWithDebInfo MinSizeRel)
|
||||||
ARGS ${EXTRA_INSTALL_FLAGS}
|
IF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
||||||
|
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
||||||
|
ENDIF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
||||||
|
IF(MAKEPROGRAM MATCHES "- ${build_type}")
|
||||||
|
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
||||||
|
ENDIF(MAKEPROGRAM MATCHES "- ${build_type}")
|
||||||
|
ENDFOREACH(build_type)
|
||||||
|
IF(NOT EXTRA_INSTALL_FLAGS)
|
||||||
|
IF(BUILD_TYPE)
|
||||||
|
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${BUILD_TYPE})
|
||||||
|
ENDIF(BUILD_TYPE)
|
||||||
|
ENDIF(NOT EXTRA_INSTALL_FLAGS)
|
||||||
|
ENDIF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
||||||
|
|
||||||
|
MESSAGE("Extra install: ${EXTRA_INSTALL_FLAGS}")
|
||||||
|
|
||||||
|
ADD_EXECUTABLE (SimpleInstall inst.cxx foo.c foo.h)
|
||||||
|
TARGET_LINK_LIBRARIES(SimpleInstall test1 test2)
|
||||||
|
|
||||||
|
ADD_DEPENDENCIES(SimpleInstall test3)
|
||||||
|
ADD_CUSTOM_COMMAND(
|
||||||
|
TARGET SimpleInstall
|
||||||
|
POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND}
|
||||||
|
ARGS ${EXTRA_INSTALL_FLAGS}
|
||||||
"-P${CMAKE_CURRENT_BINARY_DIR}/cmake_install.cmake"
|
"-P${CMAKE_CURRENT_BINARY_DIR}/cmake_install.cmake"
|
||||||
COMMENT "Install Project"
|
COMMENT "Install Project"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
INSTALL_TARGETS(/bin SimpleInstall)
|
||||||
|
INSTALL_TARGETS(/lib test1 test2 test3)
|
||||||
|
INSTALL_TARGETS(/include lib1.h lib2.h lib3.h)
|
||||||
|
|
||||||
|
ENDIF(STAGE2)
|
||||||
|
|
|
@ -5,43 +5,62 @@ SET(EXECUTABLE_OUTPUT_PATH "${TestSimpleInstall_BINARY_DIR}/ExecPath")
|
||||||
SET(LIBRARY_OUTPUT_PATH "${EXECUTABLE_OUTPUT_PATH}")
|
SET(LIBRARY_OUTPUT_PATH "${EXECUTABLE_OUTPUT_PATH}")
|
||||||
|
|
||||||
SET(CMAKE_DEBUG_POSTFIX "_test_debug_postfix")
|
SET(CMAKE_DEBUG_POSTFIX "_test_debug_postfix")
|
||||||
ADD_LIBRARY(test1 STATIC lib1.cxx)
|
|
||||||
ADD_LIBRARY(test2 SHARED lib2.cxx)
|
|
||||||
ADD_LIBRARY(test3 MODULE lib3.cxx)
|
|
||||||
ADD_EXECUTABLE (SimpleInstall inst.cxx foo.c foo.h)
|
|
||||||
TARGET_LINK_LIBRARIES(SimpleInstall test1 test2)
|
|
||||||
|
|
||||||
ADD_DEPENDENCIES(SimpleInstall test3)
|
IF(STAGE2)
|
||||||
|
FIND_LIBRARY(TEST1_LIBRARY
|
||||||
|
NAMES test1 test1${CMAKE_DEBUG_POSTFIX}
|
||||||
|
PATHS "${CMAKE_INSTALL_PREFIX}/lib"
|
||||||
|
DOC "First library")
|
||||||
|
FIND_LIBRARY(TEST2_LIBRARY
|
||||||
|
NAMES test2 test2${CMAKE_DEBUG_POSTFIX}
|
||||||
|
PATHS "${CMAKE_INSTALL_PREFIX}/lib"
|
||||||
|
DOC "First library")
|
||||||
|
ADD_EXECUTABLE (SimpleInstallS2 inst.cxx foo.c foo.h)
|
||||||
|
TARGET_LINK_LIBRARIES(SimpleInstallS2 ${TEST1_LIBRARY} ${TEST2_LIBRARY})
|
||||||
|
|
||||||
INSTALL_TARGETS(/bin SimpleInstall)
|
ELSE(STAGE2)
|
||||||
INSTALL_TARGETS(/lib test1 test2 test3)
|
# this is stage 1, so create libraries and modules and install everything
|
||||||
INSTALL_TARGETS(/include lib1.h lib2.h lib3.h)
|
ADD_LIBRARY(test1 STATIC lib1.cxx)
|
||||||
|
ADD_LIBRARY(test2 SHARED lib2.cxx)
|
||||||
|
ADD_LIBRARY(test3 MODULE lib3.cxx)
|
||||||
|
|
||||||
SET(EXTRA_INSTALL_FLAGS)
|
|
||||||
IF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
|
||||||
MESSAGE("CMake generator: ${CMAKE_GENERATOR}")
|
|
||||||
FOREACH(build_type Debug Release RelWithDebInfo MinSizeRel)
|
|
||||||
IF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
|
||||||
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
|
||||||
ENDIF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
|
||||||
IF(MAKEPROGRAM MATCHES "- ${build_type}")
|
|
||||||
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
|
||||||
ENDIF(MAKEPROGRAM MATCHES "- ${build_type}")
|
|
||||||
ENDFOREACH(build_type)
|
|
||||||
IF(NOT EXTRA_INSTALL_FLAGS)
|
|
||||||
IF(BUILD_TYPE)
|
|
||||||
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${BUILD_TYPE})
|
|
||||||
ENDIF(BUILD_TYPE)
|
|
||||||
ENDIF(NOT EXTRA_INSTALL_FLAGS)
|
|
||||||
ENDIF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
|
||||||
|
|
||||||
MESSAGE("Extra install: ${EXTRA_INSTALL_FLAGS}")
|
|
||||||
|
|
||||||
ADD_CUSTOM_COMMAND(
|
SET(EXTRA_INSTALL_FLAGS)
|
||||||
TARGET SimpleInstall
|
IF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
||||||
POST_BUILD
|
MESSAGE("CMake generator: ${CMAKE_GENERATOR}")
|
||||||
COMMAND ${CMAKE_COMMAND}
|
FOREACH(build_type Debug Release RelWithDebInfo MinSizeRel)
|
||||||
ARGS ${EXTRA_INSTALL_FLAGS}
|
IF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
||||||
|
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
||||||
|
ENDIF(MAKEPROGRAM MATCHES "/build ${build_type}")
|
||||||
|
IF(MAKEPROGRAM MATCHES "- ${build_type}")
|
||||||
|
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${build_type})
|
||||||
|
ENDIF(MAKEPROGRAM MATCHES "- ${build_type}")
|
||||||
|
ENDFOREACH(build_type)
|
||||||
|
IF(NOT EXTRA_INSTALL_FLAGS)
|
||||||
|
IF(BUILD_TYPE)
|
||||||
|
SET(EXTRA_INSTALL_FLAGS -DBUILD_TYPE=${BUILD_TYPE})
|
||||||
|
ENDIF(BUILD_TYPE)
|
||||||
|
ENDIF(NOT EXTRA_INSTALL_FLAGS)
|
||||||
|
ENDIF(CMAKE_GENERATOR MATCHES "^Visual Studio")
|
||||||
|
|
||||||
|
MESSAGE("Extra install: ${EXTRA_INSTALL_FLAGS}")
|
||||||
|
|
||||||
|
ADD_EXECUTABLE (SimpleInstall inst.cxx foo.c foo.h)
|
||||||
|
TARGET_LINK_LIBRARIES(SimpleInstall test1 test2)
|
||||||
|
|
||||||
|
ADD_DEPENDENCIES(SimpleInstall test3)
|
||||||
|
ADD_CUSTOM_COMMAND(
|
||||||
|
TARGET SimpleInstall
|
||||||
|
POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND}
|
||||||
|
ARGS ${EXTRA_INSTALL_FLAGS}
|
||||||
"-P${CMAKE_CURRENT_BINARY_DIR}/cmake_install.cmake"
|
"-P${CMAKE_CURRENT_BINARY_DIR}/cmake_install.cmake"
|
||||||
COMMENT "Install Project"
|
COMMENT "Install Project"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
INSTALL_TARGETS(/bin SimpleInstall)
|
||||||
|
INSTALL_TARGETS(/lib test1 test2 test3)
|
||||||
|
INSTALL_TARGETS(/include lib1.h lib2.h lib3.h)
|
||||||
|
|
||||||
|
ENDIF(STAGE2)
|
||||||
|
|
Loading…
Reference in New Issue