X-Git-Url: http://biod.pnpi.spb.ru/gitweb/?a=blobdiff_plain;f=CPackInit.cmake;h=c7e7e3cc07064e64c671600f6a804dd0482ec34e;hb=07e8a2a25ab5a62f63af77fe0dd1405cd41ee5ce;hp=122c751638ac86995d8c7a51421d1bf52a02eddf;hpb=69ed86b6b6ee0d3271440a584af3d9c5c827af97;p=alexxy%2Fgromacs.git diff --git a/CPackInit.cmake b/CPackInit.cmake index 122c751638..c7e7e3cc07 100644 --- a/CPackInit.cmake +++ b/CPackInit.cmake @@ -1,7 +1,7 @@ # # This file is part of the GROMACS molecular simulation package. # -# Copyright (c) 2012,2013, by the GROMACS development team, led by +# Copyright (c) 2012,2013,2014, by the GROMACS development team, led by # Mark Abraham, David van der Spoel, Berk Hess, and Erik Lindahl, # and including many others, as listed in the AUTHORS file in the # top-level source directory and at http://www.gromacs.org. @@ -32,15 +32,47 @@ # To help us fund GROMACS development, we humbly ask that you cite # the research papers on the package. Check out http://www.gromacs.org. -#TODO: add check that source doesn't contain any untracked files -if(CPACK_SOURCE_PACKAGE_FILE_NAME) #building source package +set(BUILDING_SOURCE_PACKAGE OFF) +# The essential difference in building a source package is that install() rules +# from the CMake project are not considered when deciding what to package. +# Instead, only the listed directories are packaged (and the listed directories +# contain the source tree). +if (NOT CPACK_INSTALL_CMAKE_PROJECTS) + set(BUILDING_SOURCE_PACKAGE ON) +endif() + +if (BUILDING_SOURCE_PACKAGE) + # TODO: add check that source doesn't contain any untracked files get_filename_component(CMAKE_BINARY_DIR ${CPACK_OUTPUT_CONFIG_FILE} PATH) - if (NOT EXISTS "${CMAKE_BINARY_DIR}/share/man/man1/gmx-view.1" OR - NOT EXISTS "${CMAKE_BINARY_DIR}/share/html/final/online.html") + # TODO: The list could be generated at the same time as the list of + # directories to include to keep the probe file names at the same place. + # And this does not detect if things have been built in the past, but are + # outdated. + if (NOT EXISTS "${CMAKE_BINARY_DIR}/docs/man/man1/gmx-view.1" OR + NOT EXISTS "${CMAKE_BINARY_DIR}/docs/install-guide/final/INSTALL" OR + NOT EXISTS "${CMAKE_BINARY_DIR}/docs/old-html/final/online.html" OR + NOT EXISTS "${CMAKE_BINARY_DIR}/src/programs/completion/gmx-completion.bash" OR + NOT EXISTS "${CMAKE_BINARY_DIR}/docs/old-html/final/programs/gmx-view.html") message(FATAL_ERROR - "To create a complete source package all man and HTML pages need " - "to be generated. " - "You need to run 'make man html' or set GMX_BUILD_HELP=ON to get " - "them automatically built together with the binaries.") + "To create a complete source package, bash completions, " + "man and HTML pages, and INSTALL need to be generated. " + "Run 'make completion man html install-guide' to build " + "these parts. You can also configure with " + "GMX_BUILD_HELP=ON to automatically build the HTML parts.") + endif() +else() + # TODO: If GMX_BUILD_HELP is AUTO, it may happen that the generation fails, + # and things are silently left out. + # Also, it is currently impossible to get these files into the binary + # package for cross-compilation. However, binary packages are not + # currently used much, either... + if (NOT CPACK_GMX_BUILD_HELP) + message(WARNING + "To create a complete binary package, bash completions, and " + "man and HTML pages need to be generated. " + "You need to configure with GMX_BUILD_HELP=ON to include all " + "in the binary package.") + # Building the man, html, ... targets is not sufficient because than the + # install is still not done. endif() endif()