diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2007-10-31 16:55:04 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2007-10-31 16:55:04 (GMT) |
commit | e65c40f94a15f5e70695bd5c08444fc42262940c (patch) | |
tree | f3ef20ff363eec1b200c7373ddd21c9a70cffcb3 | |
parent | fb621feefcfddffa27ec429bab85ff5a711e075d (diff) | |
download | CMake-e65c40f94a15f5e70695bd5c08444fc42262940c.zip CMake-e65c40f94a15f5e70695bd5c08444fc42262940c.tar.gz CMake-e65c40f94a15f5e70695bd5c08444fc42262940c.tar.bz2 |
ENH: add CPACK_PROJECT_CONFIG_FILE option to CPack
-rw-r--r-- | CMakeCPack.cmake | 3 | ||||
-rw-r--r-- | CMakeCPackOptions.cmake.in (renamed from CPackConfig.cmake.in) | 9 | ||||
-rw-r--r-- | CPackSourceConfig.cmake.in | 8 | ||||
-rw-r--r-- | Source/CPack/cmCPackGenericGenerator.cxx | 10 |
4 files changed, 18 insertions, 12 deletions
diff --git a/CMakeCPack.cmake b/CMakeCPack.cmake index b988d17..f511895 100644 --- a/CMakeCPack.cmake +++ b/CMakeCPack.cmake @@ -4,6 +4,9 @@ IF(EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake") SET(CMAKE_INSTALL_MFC_LIBRARIES 1) INCLUDE(InstallRequiredSystemLibraries) ENDIF(EXISTS "${CMAKE_ROOT}/Modules/InstallRequiredSystemLibraries.cmake") + CONFIGURE_FILE("${CMake_SOURCE_DIR}/CMakeCPackOptions.cmake.in" + "${CMake_BINARY_DIR}/CMakeCPackOptions.cmake" @ONLY) + SET(CPACK_PROJECT_CONFIG_FILE "${CMake_BINARY_DIR}/CMakeCPackOptions.cmake") SET(CPACK_PACKAGE_DESCRIPTION_SUMMARY "CMake is a build tool") SET(CPACK_PACKAGE_VENDOR "Kitware") SET(CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_SOURCE_DIR}/Copyright.txt") diff --git a/CPackConfig.cmake.in b/CMakeCPackOptions.cmake.in index 6c92d0c..f1be2e8 100644 --- a/CPackConfig.cmake.in +++ b/CMakeCPackOptions.cmake.in @@ -1,6 +1,3 @@ -# all CPACK_ variables from the cmake project -@_CPACK_OTHER_VARIABLES_@ - if(CPACK_GENERATOR MATCHES "NSIS") # set the install/unistall icon used for the installer itself # There is a bug in NSI that does not handle full unix paths properly. @@ -31,3 +28,9 @@ if(CPACK_GENERATOR MATCHES "NSIS") SET(CPACK_NSIS_CONTACT @CPACK_PACKAGE_CONTACT@) SET(CPACK_NSIS_MODIFY_PATH ON) endif(CPACK_GENERATOR MATCHES "NSIS") + +if(CPACK_GENERATOR MATCHES "CygwinSource") + # when packaging source make sure the .build directory is not included + SET(CPACK_SOURCE_IGNORE_FILES + "/CVS/" "/\\.build/" "/\\.svn/" "\\.swp$" "\\.#" "/#" "~$") +endif(CPACK_GENERATOR MATCHES "CygwinSource") diff --git a/CPackSourceConfig.cmake.in b/CPackSourceConfig.cmake.in deleted file mode 100644 index 46b8eee..0000000 --- a/CPackSourceConfig.cmake.in +++ /dev/null @@ -1,8 +0,0 @@ -# All CPACK_ variables from the cmake project -@_CPACK_OTHER_VARIABLES_@ - -if(CPACK_GENERATOR MATCHES "CygwinSource") - # when packaging source make sure the .build directory is not included - SET(CPACK_SOURCE_IGNORE_FILES - "/CVS/" "/\\.build/" "/\\.svn/" "\\.swp$" "\\.#" "/#" "~$") -endif(CPACK_GENERATOR MATCHES "CygwinSource") diff --git a/Source/CPack/cmCPackGenericGenerator.cxx b/Source/CPack/cmCPackGenericGenerator.cxx index e961357..51d1018 100644 --- a/Source/CPack/cmCPackGenericGenerator.cxx +++ b/Source/CPack/cmCPackGenericGenerator.cxx @@ -60,7 +60,6 @@ void cmCPackGenericGenerator::DisplayVerboseOutput(const char* msg, //---------------------------------------------------------------------- int cmCPackGenericGenerator::PrepareNames() { - this->SetOption("CPACK_GENERATOR", this->Name.c_str()); std::string tempDirectory = this->GetOption("CPACK_PACKAGE_DIRECTORY"); tempDirectory += "/_CPack_Packages/"; @@ -754,6 +753,15 @@ int cmCPackGenericGenerator::Initialize(const char* name, cmMakefile* mf, "Cannot initialize the generator" << std::endl); return 0; } + // set the running generator name + this->SetOption("CPACK_GENERATOR", this->Name.c_str()); + // Load the project specific config file + const char* config = + this->GetOption("CPACK_PROJECT_CONFIG_FILE"); + if(config) + { + mf->ReadListFile(config); + } int result = this->InitializeInternal(); if (cmSystemTools::GetErrorOccuredFlag()) { |