X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fcmake%2FBBTKCreatePackageIncludeScript.cmake;h=9d144af80da6ae9c0508b705057f5993bc7e44d4;hb=ed9d32f344e2ffa223081390b63f064cf1e42de0;hp=65f1dcd8a973d98beb21269bab2b149f4ca88fa0;hpb=ea9a967fd537db57f8f135b2a5afc065e3a0a2db;p=bbtk.git diff --git a/kernel/cmake/BBTKCreatePackageIncludeScript.cmake b/kernel/cmake/BBTKCreatePackageIncludeScript.cmake index 65f1dcd..9d144af 100644 --- a/kernel/cmake/BBTKCreatePackageIncludeScript.cmake +++ b/kernel/cmake/BBTKCreatePackageIncludeScript.cmake @@ -2,12 +2,8 @@ MACRO(BBTK_CREATE_PACKAGE_INCLUDE_SCRIPT BBTK_PACKAGE_NAME BBTK_PACKAGE_BBS_BOXES BBTK_PACKAGE_BBS_APPLI ) - SET(OUTPUT_PATH ${BBTK_BBS_INSTALL_PATH}/${BBTK_PACKAGE_NAME}) - SET(OUTPUT_FILE ${PROJECT_BINARY_DIR}/${OUTPUT_PATH}/${BBTK_PACKAGE_NAME}.bbs) - - # MESSAGE(ERROR "${BBTK_PACKAGE_BBS_BOXES} - ${BBTK_PACKAGE_BBS_APPLI}") - - # Creates the file ${BBTK_PACKAGE_NAME}.bbs + # Creates the file ${BBTK_PACKAGE_NAME}.bbp + SET(OUTPUT_FILE ${BBTK_BBS_BUILD_PATH}/${BBTK_PACKAGE_NAME}.bbp) FILE(WRITE "${OUTPUT_FILE}" "#-----------------------------------------\n" @@ -20,22 +16,106 @@ MACRO(BBTK_CREATE_PACKAGE_INCLUDE_SCRIPT BBTK_PACKAGE_NAME BBTK_PACKAGE_BB "#-----------------------------------------\n" "package ${BBTK_PACKAGE_NAME}\n" ) + + #FILE(APPEND + # "${OUTPUT_FILE}" + # "#-----------------------------------------\n" + # "include ${BBTK_PACKAGE_NAME}/boxes/*\n" + # ) + FOREACH(bbs ${BBTK_PACKAGE_BBS_BOXES}) FILE(APPEND "${OUTPUT_FILE}" "#-----------------------------------------\n" - "include ${bbs}\n" + "include ${BBTK_PACKAGE_NAME}/${bbs}\n" + ) + CONFIGURE_FILE( + ${CMAKE_CURRENT_SOURCE_DIR}/${bbs} + ${BBTK_BBS_BUILD_PATH}/${BBTK_PACKAGE_NAME}/${bbs} + COPYONLY ) + GET_FILENAME_COMPONENT(bbs_path ${bbs} PATH) + + + IF(WIN32) + INSTALL( + FILES ${CMAKE_CURRENT_SOURCE_DIR}/${bbs} +# DESTINATION ${BBTK_BBS_INSTALL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} + DESTINATION ${BBTK_BBS_REL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} + ) +ELSE(WIN32) +INSTALL( + FILES ${CMAKE_CURRENT_SOURCE_DIR}/${bbs} + DESTINATION ${BBTK_BBS_INSTALL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} +# DESTINATION ${BBTK_BBS_REL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} + ) +ENDIF(WIN32) ENDFOREACH(bbs) - FOREACH(bbs ${BBTK_PACKAGE_BBS_APPLI}) + FILE(APPEND + "${OUTPUT_FILE}" + "#-----------------------------------------\n" + "endpackage\n" + "#-- EOF ----------------------------------\n" + ) + IF(WIN32) + INSTALL( + FILES ${OUTPUT_FILE} +# DESTINATION ${BBTK_BBS_INSTALL_PATH} + DESTINATION ${BBTK_BBS_REL_PATH} + ) +ELSE(WIN32) + INSTALL( + FILES ${OUTPUT_FILE} + DESTINATION ${BBTK_BBS_INSTALL_PATH} +# DESTINATION ${BBTK_BBS_REL_PATH} + ) +ENDIF(WIN32) + # Creates the file ${BBTK_PACKAGE_NAME}-appli.bbp + SET(OUTPUT_FILE ${BBTK_BBS_BUILD_PATH}/${BBTK_PACKAGE_NAME}-appli.bbp) + FILE(WRITE + "${OUTPUT_FILE}" + "#-----------------------------------------\n" + "# Applications include script for bbtk package '${BBTK_PACKAGE_NAME}'\n" + "# Automatically generated by cmake (macro BBTK_CREATE_PACKAGE_INCLUDE_SCRIPT)\n") + FILE(APPEND + "${OUTPUT_FILE}" + "#-----------------------------------------\n" + "load ${BBTK_PACKAGE_NAME}\n" + "#-----------------------------------------\n" + "package ${BBTK_PACKAGE_NAME}\n" + ) + FOREACH(bbs ${BBTK_PACKAGE_BBS_APPLI}) + GET_FILENAME_COMPONENT(filename "${bbs}" NAME_WE) FILE(APPEND "${OUTPUT_FILE}" "#-----------------------------------------\n" "define ${filename}\n" - "include ${bbs}\n" + "include ${BBTK_PACKAGE_NAME}/${bbs} source\n" "endefine\n" ) + + CONFIGURE_FILE( + ${CMAKE_CURRENT_SOURCE_DIR}/${bbs} + ${BBTK_BBS_BUILD_PATH}/${BBTK_PACKAGE_NAME}/${bbs} + COPYONLY + ) + GET_FILENAME_COMPONENT(bbs_path ${bbs} PATH) + + + IF(WIN32) + INSTALL( + FILES ${CMAKE_CURRENT_SOURCE_DIR}/${bbs} + # DESTINATION ${BBTK_BBS_INSTALL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} + DESTINATION ${BBTK_BBS_REL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} + ) +ELSE(WIN32) + INSTALL( + FILES ${CMAKE_CURRENT_SOURCE_DIR}/${bbs} + DESTINATION ${BBTK_BBS_INSTALL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} + # DESTINATION ${BBTK_BBS_REL_PATH}/${BBTK_PACKAGE_NAME}/${bbs_path} + ) +ENDIF(WIN32) ENDFOREACH(bbs) FILE(APPEND "${OUTPUT_FILE}" @@ -43,14 +123,22 @@ MACRO(BBTK_CREATE_PACKAGE_INCLUDE_SCRIPT BBTK_PACKAGE_NAME BBTK_PACKAGE_BB "endpackage\n" "#-- EOF ----------------------------------\n" ) - -# ADD_CUSTOM_TARGET(${BBTK_PACKAGE_NAME}.bbs ALL -# DEPENDS ${OUTPUT_FILE} -# ) - +IF(WIN32) + INSTALL( + FILES ${OUTPUT_FILE} + # DESTINATION ${BBTK_BBS_INSTALL_PATH} + DESTINATION ${BBTK_BBS_REL_PATH} + ) +ELSE(WIN32) INSTALL( FILES ${OUTPUT_FILE} - DESTINATION ${OUTPUT_PATH} + DESTINATION ${BBTK_BBS_INSTALL_PATH} + # DESTINATION ${BBTK_BBS_REL_PATH} ) +ENDIF(WIN32) +# ADD_CUSTOM_TARGET(${BBTK_PACKAGE_NAME}.bbp ALL +# DEPENDS ${OUTPUT_FILE} +# ) + ENDMACRO(BBTK_CREATE_PACKAGE_INCLUDE_SCRIPT)