summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndy Cedilnik <andy.cedilnik@kitware.com>2006-02-23 22:30:12 (GMT)
committerAndy Cedilnik <andy.cedilnik@kitware.com>2006-02-23 22:30:12 (GMT)
commit66ea097554b4abe398d5046a8ad45e935053d7fc (patch)
tree0b728ec678fa7c11882b9ec601c8dfa2ed8d07fc
parent542b034a66da45b82afd05eacfcafa22ee41f7ac (diff)
downloadCMake-66ea097554b4abe398d5046a8ad45e935053d7fc.zip
CMake-66ea097554b4abe398d5046a8ad45e935053d7fc.tar.gz
CMake-66ea097554b4abe398d5046a8ad45e935053d7fc.tar.bz2
ENH: Properly handle target dependencies
-rw-r--r--Source/cmGlobalGenerator.cxx18
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.cxx8
2 files changed, 18 insertions, 8 deletions
diff --git a/Source/cmGlobalGenerator.cxx b/Source/cmGlobalGenerator.cxx
index ade6421..52f3480 100644
--- a/Source/cmGlobalGenerator.cxx
+++ b/Source/cmGlobalGenerator.cxx
@@ -1237,8 +1237,8 @@ void cmGlobalGenerator::CreateDefaultGlobalTargets(cmTargets* targets)
singleLine.push_back(this->GetCMakeInstance()->GetCTestCommand());
singleLine.push_back("--force-new-ctest-process");
cpackCommandLines.push_back(singleLine);
- (*targets)[this->GetPackageTargetName()]
- = this->CreateGlobalTarget(this->GetPackageTargetName(),
+ (*targets)[this->GetTestTargetName()]
+ = this->CreateGlobalTarget(this->GetTestTargetName(),
"Running tests...", &cpackCommandLines, depends);
//Edit Cache
@@ -1306,6 +1306,7 @@ void cmGlobalGenerator::CreateDefaultGlobalTargets(cmTargets* targets)
singleLine.push_back("-P");
singleLine.push_back("cmake_install.cmake");
cpackCommandLines.push_back(singleLine);
+ /*
const char* noall =
mf->GetDefinition("CMAKE_SKIP_INSTALL_ALL_DEPENDENCY");
bool dependsOnAll = false;
@@ -1313,10 +1314,11 @@ void cmGlobalGenerator::CreateDefaultGlobalTargets(cmTargets* targets)
{
dependsOnAll = true;
}
+ */
(*targets)[this->GetInstallTargetName()] =
this->CreateGlobalTarget(
this->GetInstallTargetName(), "Install the project...",
- &cpackCommandLines, depends, dependsOnAll);
+ &cpackCommandLines, depends);
}
cmTarget cmGlobalGenerator::CreateGlobalTarget(
@@ -1330,13 +1332,19 @@ cmTarget cmGlobalGenerator::CreateGlobalTarget(
target.SetType(cmTarget::GLOBAL_TARGET, name);
target.SetInAll(false);
+ std::vector<std::string> fileDepends;
// Store the custom command in the target.
- cmCustomCommand cc(0, depends, *commandLines, 0, 0);
+ cmCustomCommand cc(0, fileDepends, *commandLines, 0, 0);
target.GetPostBuildCommands().push_back(cc);
target.SetProperty("EchoString", message);
if ( depends_on_all )
{
- target.SetProperty("DependsOnAll", "ON");
+ target.AddUtility("all");
+ }
+ std::vector<std::string>::iterator dit;
+ for ( dit = depends.begin(); dit != depends.end(); ++ dit )
+ {
+ target.AddUtility(dit->c_str());
}
return target;
}
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx
index 13cd316..6ac963a 100644
--- a/Source/cmLocalUnixMakefileGenerator3.cxx
+++ b/Source/cmLocalUnixMakefileGenerator3.cxx
@@ -1266,10 +1266,12 @@ void cmLocalUnixMakefileGenerator3
{
text = "Running external command ...";
}
- const char* dependsOnAll = glIt->second.GetProperty("DependsOnAll");
- if ( dependsOnAll || cmSystemTools::IsOn(dependsOnAll) )
+ std::set<cmStdString>::iterator dit;
+ for ( dit = glIt->second.GetUtilities().begin();
+ dit != glIt->second.GetUtilities().end();
+ ++ dit )
{
- depends.push_back("all");
+ depends.push_back(dit->c_str());
}
this->AppendEcho(commands, text);