summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2007-10-31 16:55:04 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2007-10-31 16:55:04 (GMT)
commite65c40f94a15f5e70695bd5c08444fc42262940c (patch)
treef3ef20ff363eec1b200c7373ddd21c9a70cffcb3
parentfb621feefcfddffa27ec429bab85ff5a711e075d (diff)
downloadCMake-e65c40f94a15f5e70695bd5c08444fc42262940c.zip
CMake-e65c40f94a15f5e70695bd5c08444fc42262940c.tar.gz
CMake-e65c40f94a15f5e70695bd5c08444fc42262940c.tar.bz2
ENH: add CPACK_PROJECT_CONFIG_FILE option to CPack
-rw-r--r--CMakeCPack.cmake3
-rw-r--r--CMakeCPackOptions.cmake.in (renamed from CPackConfig.cmake.in)9
-rw-r--r--CPackSourceConfig.cmake.in8
-rw-r--r--Source/CPack/cmCPackGenericGenerator.cxx10
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())
{