#----------------------------------------------------------------------------- # Macro CREATE_FIND_PACKAGE # Creates and install the cmake files which allow # to find a library by the cmake command FIND_PACKAGE. # # Inputs : # -------- # LIBRARY_NAME : name of the library to find # # The following variables **MUST** have been set previously : # # * ${LIBRARY_NAME}_BUILD_TREE_RELATIVE_INCLUDE_PATHS # The list of include paths # when someone uses a *BUILD TREE* version of ${LIBRARY_NAME}. # NB : # THE PATHS *MUST BE RELATIVE* TO THE ROOT DIR OF THE PROJECT **SOURCES** ! # Assume your project architecture is : # install/ : directory in which CREATE_FIND_PACKAGE is invoked # src/part1/include/ : first include dir # src/part2/include/ : second include dir # Then you should set the var with : # SET(${LIBRARY_NAME}_BUILD_TREE_RELATIVE_INCLUDE_PATHS # src/part1/include # src/part2/include ) # Which will result in actual include paths : # ${PROJECT_SOURCE_DIR}/src/part1/include; # ${PROJECT_SOURCE_DIR}/src/part2/include # * ${LIBRARY_NAME}_BUILD_TREE_RELATIVE_LIBRARY_PATHS # Like the previous var but for the library paths. # NB : # THE PATHS *MUST BE RELATIVE* TO THE ROOT DIR OF THE **BUILD TREE** # THAT IS POINT TO THE FOLDERS WHERE THE LIBS WILL BE BUILD # Assume that your project architecture is : # src/part1/src/ : first source dir, in which the lib 'part1' is built # src/part2/src/ : first source dir, in which the lib 'part2' is built # Then you should set the var with # SET(${LIBRARY_NAME}_BUILD_TREE_RELATIVE_LIBRARY_PATHS # src/part1/src # src/part2/src # ) # Which will result in actual library paths : # ${PROJECT_BINARY_DIR}/src/part1/src # ${PROJECT_BINARY_DIR}/src/part2/src # * ${LIBRARY_NAME}_INSTALL_TREE_RELATIVE_INCLUDE_PATHS # The list of include paths # when someone uses an *INSTALLED* version of ${LIBRARY_NAME} # The paths *MUST BE RELATIVE* to INSTALL_PREFIX # # A typical example is "include/${LIBRARY_NAME}" # * ${LIBRARY_NAME}_INSTALL_TREE_RELATIVE_LIBRARY_PATHS # Like the previous var but for library paths. # A typical example is ".." # * ${LIBRARY_NAME}_LIBRARIES # The list of libraries to link against when using ${LIBRARY_NAME} # # The following variables can be set optionally : # # * ${LIBRARY_NAME}_REQUIRED_C_FLAGS # * ${LIBRARY_NAME}_REQUIRED_CXX_FLAGS # * ${LIBRARY_NAME}_REQUIRED_LINK_FLAGS # * ${LIBRARY_NAME}_MAJOR_VERSION # * ${LIBRARY_NAME}_MINOR_VERSION # * ${LIBRARY_NAME}_BUILD_VERSION # * ${LIBRARY_NAME}_INSTALL_FOLDER : if set then install the stuff # in INSTALL_PREFIX/lib/${LIBRARY_NAME}_INSTALL_FOLDER # instead of INSTALL_PREFIX/lib/${LIBRARY_NAME} # # # To provide a user defined # couple of Config/Use file (in addition to the standard one) use : # SET( ${LIBRARY_NAME}_HAS_ADDITIONAL_CONFIG_FILE TRUE ) # and store the *ABSOLUTE* paths to the additional files in the vars : # ${LIBRARY_NAME}_ADDITIONAL_CONFIG_FILE # ${LIBRARY_NAME}_ADDITIONAL_USE_FILE # (e.g. ${CMAKE_CURRENT_SOURCE_DIR}/MyConfig.cmake) # # Outputs : # -------- # At cmake run-time, the macro creates the following files # in the current dir of the build tree (where the macro is invoked) : # Use${LIBRARY_NAME}.cmake # ${LIBRARY_NAME}Config.cmake # ${LIBRARY_NAME}BuildSettings.cmake # And if the vars ${LIBRARY_NAME}_ADDITIONAL_CONFIG_FILE and # ${LIBRARY_NAME}_ADDITIONAL_USE_FILE are set, it also creates : # Additional${LIBRARY_NAME}Config.cmake # AdditionalUse${LIBRARY_NAME}.cmake # # At install-time, the same files are installed # in INSTALL_PREFIX/lib/${LIBRARY_NAME} # and the file : # Find${LIBRARY_NAME}.cmake # is installed in ${CMAKE_ROOT}/Modules/ # # #----------------------------------------------------------------------------- MACRO(CMAKE_CREATE_FIND_PACKAGE LIBRARY_NAME) #--------------------------------------------------------------------------- # Sets the common values to build tree and install tree configs SET(CFP_LIB_REQUIRED_C_FLAGS ${${LIBRARY_NAME}_REQUIRED_C_FLAGS}) SET(CFP_LIB_REQUIRED_CXX_FLAGS ${${LIBRARY_NAME}_REQUIRED_CXX_FLAGS}) SET(CFP_LIB_REQUIRED_LINK_FLAGS ${${LIBRARY_NAME}_REQUIRED_LINK_FLAGS}) SET(CFP_LIB_MAJOR_VERSION ${${LIBRARY_NAME}_MAJOR_VERSION}) SET(CFP_LIB_MINOR_VERSION ${${LIBRARY_NAME}_MINOR_VERSION}) SET(CFP_LIB_BUILD_VERSION ${${LIBRARY_NAME}_BUILD_VERSION}) SET(CFP_LIB_VERSION ${CFP_LIB_MAJOR_VERSION}.${CFP_LIB_MINOR_VERSION}.${CFP_LIB_BUILD_VERSION}) SET(CFP_LIB_LIBRARIES ${${LIBRARY_NAME}_LIBRARIES}) IF (${LIBRARY_NAME}_HAS_ADDITIONAL_CONFIG_FILE) SET(CFP_LIB_HAS_ADDITIONAL_CONFIG_FILE TRUE) ELSE (${LIBRARY_NAME}_HAS_ADDITIONAL_CONFIG_FILE) SET(CFP_LIB_HAS_ADDITIONAL_CONFIG_FILE FALSE) ENDIF (${LIBRARY_NAME}_HAS_ADDITIONAL_CONFIG_FILE) #--------------------------------------------------------------------------- #--------------------------------------------------------------------------- #-- BUILD TREE configuration SET(CFP_BUILD_TREE_CONFIGURATION TRUE) # UseLIBRARY_NAME.cmake CONFIGURE_FILE( ${CMakeCreateFindPackage_DIR}/CMakeCreateFindPackage_UseLibrary.cmake.in ${PROJECT_BINARY_DIR}/Use${LIBRARY_NAME}.cmake @ONLY IMMEDIATE ) # LIBRARY_NAMEConfig.cmake SET(CFP_LIB_RELATIVE_INCLUDE_PATHS ${${LIBRARY_NAME}_BUILD_TREE_RELATIVE_INCLUDE_PATHS}) SET(CFP_LIB_RELATIVE_LIBRARY_PATHS ${${LIBRARY_NAME}_BUILD_TREE_RELATIVE_LIBRARY_PATHS}) CONFIGURE_FILE( ${CMakeCreateFindPackage_DIR}/CMakeCreateFindPackage_LibraryConfig.cmake.in ${PROJECT_BINARY_DIR}/${LIBRARY_NAME}Config.cmake @ONLY IMMEDIATE ) # LIBRARY_NAMEBuildSettings.cmake : # Save the compiler settings so another project can import them. INCLUDE(${CMAKE_ROOT}/Modules/CMakeExportBuildSettings.cmake) CMAKE_EXPORT_BUILD_SETTINGS(${PROJECT_BINARY_DIR}/${LIBRARY_NAME}BuildSettings.cmake) # Additional Config and Use files IF(CFP_LIB_HAS_ADDITIONAL_CONFIG_FILE) CONFIGURE_FILE( ${${LIBRARY_NAME}_ADDITIONAL_CONFIG_FILE} ${PROJECT_BINARY_DIR}/Additional${LIBRARY_NAME}Config.cmake @ONLY IMMEDIATE ) CONFIGURE_FILE( ${${LIBRARY_NAME}_ADDITIONAL_USE_FILE} ${PROJECT_BINARY_DIR}/AdditionalUse${LIBRARY_NAME}.cmake @ONLY IMMEDIATE ) ENDIF(CFP_LIB_HAS_ADDITIONAL_CONFIG_FILE) #--------------------------------------------------------------------------- #--------------------------------------------------------------------------- #-- INSTALL TREE configuration SET(CFP_BUILD_TREE_CONFIGURATION FALSE) # Create work directory to put the configured files because # if the user invoked the macro at the root of the build tree the files # would overwrite those configured for the build tree SET(CFP_WORK_DIR ${CMAKE_CURRENT_BINARY_DIR}/CMakeCreateFindPackage_stuff) IF(NOT IS_DIRECTORY ${CFP_WORK_DIR}) FILE(MAKE_DIRECTORY ${CFP_WORK_DIR}) ENDIF(NOT IS_DIRECTORY ${CFP_WORK_DIR}) #---------------------------------------------------------------------------- #INSTALLATION PATH IF(WIN32) SET(INSTALL_PATH .) ELSE(WIN32) IF(${LIBRARY_NAME}_INSTALL_FOLDER) SET(INSTALL_PATH lib/${${LIBRARY_NAME}_INSTALL_FOLDER}) ELSE(${LIBRARY_NAME}_INSTALL_FOLDER) SET(INSTALL_PATH lib/${LIBRARY_NAME}) ENDIF(${LIBRARY_NAME}_INSTALL_FOLDER) ENDIF(WIN32) # UseLIBRARY_NAME.cmake CONFIGURE_FILE( ${CMakeCreateFindPackage_DIR}/CMakeCreateFindPackage_UseLibrary.cmake.in ${CFP_WORK_DIR}/Use${LIBRARY_NAME}.cmake @ONLY IMMEDIATE ) INSTALL( FILES ${CFP_WORK_DIR}/Use${LIBRARY_NAME}.cmake DESTINATION ${INSTALL_PATH} ) # LIBRARY_NAMEConfig.cmake SET(CFP_LIB_RELATIVE_INCLUDE_PATHS ${${LIBRARY_NAME}_INSTALL_TREE_RELATIVE_INCLUDE_PATHS}) SET(CFP_LIB_RELATIVE_LIBRARY_PATHS ${${LIBRARY_NAME}_INSTALL_TREE_RELATIVE_LIBRARY_PATHS}) CONFIGURE_FILE( ${CMakeCreateFindPackage_DIR}/CMakeCreateFindPackage_LibraryConfig.cmake.in ${CFP_WORK_DIR}/${LIBRARY_NAME}Config.cmake @ONLY IMMEDIATE ) INSTALL( FILES ${CFP_WORK_DIR}/${LIBRARY_NAME}Config.cmake DESTINATION ${INSTALL_PATH} ) # LIBRARY_NAMEBuildSettings.cmake : CMAKE_EXPORT_BUILD_SETTINGS(${CFP_WORK_DIR}/${LIBRARY_NAME}BuildSettings.cmake) INSTALL( FILES ${CFP_WORK_DIR}/${LIBRARY_NAME}BuildSettings.cmake DESTINATION ${INSTALL_PATH} ) # Additional Config and Use files IF(CFP_LIB_HAS_ADDITIONAL_CONFIG_FILE) CONFIGURE_FILE( ${${LIBRARY_NAME}_ADDITIONAL_CONFIG_FILE} ${CFP_WORK_DIR}/Additional${LIBRARY_NAME}Config.cmake @ONLY IMMEDIATE ) INSTALL( FILES ${CFP_WORK_DIR}/Additional${LIBRARY_NAME}Config.cmake DESTINATION ${INSTALL_PATH} ) CONFIGURE_FILE( ${${LIBRARY_NAME}_ADDITIONAL_USE_FILE} ${CFP_WORK_DIR}/AdditionalUse${LIBRARY_NAME}.cmake @ONLY IMMEDIATE ) INSTALL( FILES ${CFP_WORK_DIR}/AdditionalUse${LIBRARY_NAME}.cmake DESTINATION ${INSTALL_PATH} ) ENDIF(CFP_LIB_HAS_ADDITIONAL_CONFIG_FILE) # Specific to install tree # FindLIBRARY_NAME.cmake in CMake/Modules dir CONFIGURE_FILE( ${CMakeCreateFindPackage_DIR}/CMakeCreateFindPackage_FindLibrary.cmake.in ${CFP_WORK_DIR}/Find${LIBRARY_NAME}.cmake @ONLY IMMEDIATE ) INSTALL( FILES ${CFP_WORK_DIR}/Find${LIBRARY_NAME}.cmake DESTINATION ${CMAKE_ROOT}/Modules ) #--------------------------------------------------------------------------- ENDMACRO(CMAKE_CREATE_FIND_PACKAGE) #-----------------------------------------------------------------------------