diff options
author | Andy Cedilnik <andy.cedilnik@kitware.com> | 2004-02-08 17:04:10 (GMT) |
---|---|---|
committer | Andy Cedilnik <andy.cedilnik@kitware.com> | 2004-02-08 17:04:10 (GMT) |
commit | e72bac587054b16fdc44ed597b7f03b06656d95a (patch) | |
tree | 921a8c0fd5c7fba24882be9b4013a62ffe9de55e /Tests/SimpleInstall | |
parent | 31c1071ebfb559ba4d0cd113e54f85d9e2228d77 (diff) | |
download | CMake-e72bac587054b16fdc44ed597b7f03b06656d95a.zip CMake-e72bac587054b16fdc44ed597b7f03b06656d95a.tar.gz CMake-e72bac587054b16fdc44ed597b7f03b06656d95a.tar.bz2 |
ENH: Add second part of SimpleInstall
Diffstat (limited to 'Tests/SimpleInstall')
-rw-r--r-- | Tests/SimpleInstall/CMakeLists.txt | 97 |
1 files changed, 58 insertions, 39 deletions
diff --git a/Tests/SimpleInstall/CMakeLists.txt b/Tests/SimpleInstall/CMakeLists.txt index 59790f0..c70a0f8 100644 --- a/Tests/SimpleInstall/CMakeLists.txt +++ b/Tests/SimpleInstall/CMakeLists.txt @@ -5,43 +5,62 @@ SET(EXECUTABLE_OUTPUT_PATH "${TestSimpleInstall_BINARY_DIR}/ExecPath") SET(LIBRARY_OUTPUT_PATH "${EXECUTABLE_OUTPUT_PATH}") 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) - -INSTALL_TARGETS(/bin SimpleInstall) -INSTALL_TARGETS(/lib test1 test2 test3) -INSTALL_TARGETS(/include lib1.h lib2.h lib3.h) - -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( - TARGET SimpleInstall - POST_BUILD - COMMAND ${CMAKE_COMMAND} - ARGS ${EXTRA_INSTALL_FLAGS} + +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}) + +ELSE(STAGE2) + # this is stage 1, so create libraries and modules and install everything + 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_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" - 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) |