summaryrefslogtreecommitdiffstats
path: root/Source/cmLocalUnixMakefileGenerator2.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmLocalUnixMakefileGenerator2.cxx')
-rw-r--r--Source/cmLocalUnixMakefileGenerator2.cxx34
1 files changed, 28 insertions, 6 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator2.cxx b/Source/cmLocalUnixMakefileGenerator2.cxx
index 9168fd2..99acf28 100644
--- a/Source/cmLocalUnixMakefileGenerator2.cxx
+++ b/Source/cmLocalUnixMakefileGenerator2.cxx
@@ -23,6 +23,8 @@
#include <queue>
+#include <assert.h>
+
// Quick-switch for generating old makefiles.
#if 0
# define CMLUMG_MAKEFILE_NAME "Makefile"
@@ -32,8 +34,9 @@
#endif
// TODO: Add "help" target.
-// TODO: Add install targets to m_InstallTargets list.
// TODO: Identify remaining relative path violations.
+// TODO: Add test to drive installation through native build system.
+// TODO: Is there a case where quoted object list fails and unquoted works?
//----------------------------------------------------------------------------
cmLocalUnixMakefileGenerator2::cmLocalUnixMakefileGenerator2()
@@ -147,11 +150,6 @@ void cmLocalUnixMakefileGenerator2::GenerateMakefile()
"Build targets in this directory.",
m_BuildTargets);
- // Write install rules.
- this->WritePassRules(makefileStream, "install",
- "Install files from this directory.",
- m_InstallTargets);
-
// Write clean rules.
this->WritePassRules(makefileStream, "clean",
"Clean targets in this directory.",
@@ -895,6 +893,30 @@ cmLocalUnixMakefileGenerator2
no_commands);
}
+ // Write special "install" target to run cmake_install.cmake script.
+ {
+ std::vector<std::string> no_depends;
+ std::vector<std::string> commands;
+ std::string cmd;
+ if(m_Makefile->GetDefinition("CMake_BINARY_DIR"))
+ {
+ // We are building CMake itself. We cannot use the original
+ // executable to install over itself.
+ cmd = m_ExecutableOutputPath;
+ cmd += "cmake";
+ cmd = this->ConvertToRelativeOutputPath(cmd.c_str());
+ }
+ else
+ {
+ cmd = "$(CMAKE_COMMAND)";
+ }
+ cmd += " -P cmake_install.cmake";
+ commands.push_back(cmd);
+ this->WriteMakeRule(makefileStream,
+ "Special rule to run installation script.", 0,
+ "install", no_depends, commands);
+ }
+
// Write special "rebuild_cache" target to re-run cmake.
{
std::vector<std::string> no_depends;