diff options
author | Brad King <brad.king@kitware.com> | 2009-01-05 16:05:57 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-01-05 16:05:57 (GMT) |
commit | 86aeefc7c97cd65d952513963400d28e6eb32808 (patch) | |
tree | 32cc77d8cf8e250921da67144d5ba5d12b1adf91 /Source/cmFileCommand.cxx | |
parent | e2fa035c700504e0fb6e6b170a0b38feb575c273 (diff) | |
download | CMake-86aeefc7c97cd65d952513963400d28e6eb32808.zip CMake-86aeefc7c97cd65d952513963400d28e6eb32808.tar.gz CMake-86aeefc7c97cd65d952513963400d28e6eb32808.tar.bz2 |
COMP: Fix installation of cmake-gui by CMake 2.4
When CMake 2.4 generates the build tree for CMake itself it asks the
built CMake to install itself using the rules that 2.4 generated. Since
the install rules use undocumented commands that are not compatible from
2.4 to 2.6 we need a special case to avoid failure. This sets a special
indicator variable in the install rules that enables a compatibility
hack to support the old install rule format.
Diffstat (limited to 'Source/cmFileCommand.cxx')
-rw-r--r-- | Source/cmFileCommand.cxx | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/Source/cmFileCommand.cxx b/Source/cmFileCommand.cxx index 9a452fa..a101435 100644 --- a/Source/cmFileCommand.cxx +++ b/Source/cmFileCommand.cxx @@ -1690,7 +1690,7 @@ bool cmFileCommand::ParseInstallArgs(std::vector<std::string> const& args, std::string stype = "FILES"; enum Doing { DoingNone, DoingFiles, DoingProperties, DoingPermissionsFile, DoingPermissionsDir, - DoingPermissionsMatch }; + DoingPermissionsMatch, DoingSelf24 }; Doing doing = DoingNone; bool use_given_permissions_file = false; bool use_given_permissions_dir = false; @@ -1844,6 +1844,14 @@ bool cmFileCommand::ParseInstallArgs(std::vector<std::string> const& args, } else if ( *cstr == "COMPONENTS" ) { + if(this->Makefile->IsOn("CMAKE_INSTALL_SELF_2_4")) + { + // When CMake 2.4 builds this CMake version we need to support + // the install scripts it generates since it asks this CMake + // to install itself using the rules it generated. + doing = DoingSelf24; + continue; + } cmOStringStream e; e << "INSTALL called with old-style COMPONENTS argument. " << "This script was generated with an older version of CMake. " @@ -1903,6 +1911,13 @@ bool cmFileCommand::ParseInstallArgs(std::vector<std::string> const& args, return false; } } + else if(doing == DoingSelf24) + { + // Ignore these arguments for compatibility. This should be + // reached only when CMake 2.4 is installing the current + // CMake. It can be removed when CMake 2.6 or higher is + // required to build CMake. + } else { this->SetError("called with inappropriate arguments"); |