summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2005-01-17 20:09:32 (GMT)
committerBrad King <brad.king@kitware.com>2005-01-17 20:09:32 (GMT)
commit64f4880cb56887935c7490c0a225dc7182b832c5 (patch)
treede1f0de554d4e4b212fa57678345ba06d19084c0
parent97a3d514acb8ce01839ebec0316277b9155518c2 (diff)
downloadCMake-64f4880cb56887935c7490c0a225dc7182b832c5.zip
CMake-64f4880cb56887935c7490c0a225dc7182b832c5.tar.gz
CMake-64f4880cb56887935c7490c0a225dc7182b832c5.tar.bz2
ENH: Adding partial implementation of provides-requires mode.
-rw-r--r--Source/cmLocalUnixMakefileGenerator2.cxx73
-rw-r--r--Source/cmLocalUnixMakefileGenerator2.h3
2 files changed, 69 insertions, 7 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator2.cxx b/Source/cmLocalUnixMakefileGenerator2.cxx
index c55831c..a0e18f2 100644
--- a/Source/cmLocalUnixMakefileGenerator2.cxx
+++ b/Source/cmLocalUnixMakefileGenerator2.cxx
@@ -33,11 +33,19 @@
# define CMLUMG_MAKEFILE_NAME "Makefile2"
#endif
+#if 0
+# define CMLUMG_PROVIDES_REQUIRES
+#endif
+
// TODO: Add "help" target.
// 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?
+// TODO: Fortran support:
+// - This needs a "provides-requires" mode for the .o files in a target.
+// - Driving target must be TGT.requires: account for this in jump-and-build.
+
//----------------------------------------------------------------------------
cmLocalUnixMakefileGenerator2::cmLocalUnixMakefileGenerator2()
{
@@ -261,10 +269,7 @@ cmLocalUnixMakefileGenerator2
!m_GlobalGenerator->IgnoreFile((*source)->GetSourceExtension().c_str()))
{
// Generate this object file's rule file.
- this->GenerateObjectRuleFile(target, *(*source));
-
- // Save the object file name.
- objects.push_back(this->GetObjectFileName(target, *(*source)));
+ this->GenerateObjectRuleFile(target, *(*source), objects);
}
}
@@ -349,7 +354,8 @@ cmLocalUnixMakefileGenerator2
//----------------------------------------------------------------------------
void
cmLocalUnixMakefileGenerator2
-::GenerateObjectRuleFile(const cmTarget& target, const cmSourceFile& source)
+::GenerateObjectRuleFile(const cmTarget& target, const cmSourceFile& source,
+ std::vector<std::string>& objects)
{
// Identify the language of the source file.
const char* lang = this->GetSourceFileLanguage(source);
@@ -364,6 +370,9 @@ cmLocalUnixMakefileGenerator2
// Get the full path name of the object file.
std::string obj = this->GetObjectFileName(target, source);
+ // Save this in the target's list of object files.
+ objects.push_back(obj);
+
// The object file should be checked for dependency integrity.
m_CheckDependFiles.insert(obj);
@@ -519,6 +528,27 @@ cmLocalUnixMakefileGenerator2
this->WriteMakeRule(ruleFileStream, 0, buildEcho.c_str(),
obj.c_str(), depends, commands);
}
+
+#ifdef CMLUMG_PROVIDES_REQUIRES
+ std::string objectRequires = obj;
+ std::string objectProvides = obj;
+ objectRequires += ".requires";
+ objectProvides += ".provides";
+ {
+ std::vector<std::string> no_commands;
+ std::vector<std::string> depends;
+ depends.push_back(obj);
+ this->WriteMakeRule(ruleFileStream, 0, 0,
+ objectProvides.c_str(), depends, no_commands);
+ }
+ {
+ std::vector<std::string> no_depends;
+ std::vector<std::string> commands;
+ commands.push_back(this->GetRecursiveMakeCall(objectProvides.c_str()));
+ this->WriteMakeRule(ruleFileStream, 0, 0,
+ objectRequires.c_str(), no_depends, commands);
+ }
+#endif
}
//----------------------------------------------------------------------------
@@ -1487,10 +1517,41 @@ cmLocalUnixMakefileGenerator2
cleanFiles.push_back(objs);
this->WriteTargetCleanRule(ruleFileStream, target, cleanFiles);
+ // Construct name of driving target listed in build.local rule.
+ // TODO: See top of file description of Fortran support.
+ std::string targetDriveName = target.GetName();
+
+#ifdef CMLUMG_PROVIDES_REQUIRES
+ targetDriveName += ".requires";
+ std::string targetProvides = target.GetName();
+ targetProvides += ".provides";
+ {
+ std::vector<std::string> no_commands;
+ std::vector<std::string> depends;
+ depends.push_back(target.GetName());
+ this->WriteMakeRule(ruleFileStream, 0, 0,
+ targetProvides.c_str(), depends, no_commands);
+ }
+ {
+ // Build list of require-level dependencies.
+ std::vector<std::string> depends;
+ for(std::vector<std::string>::const_iterator obj = objects.begin();
+ obj != objects.end(); ++obj)
+ {
+ depends.push_back(*obj + ".requires");
+ }
+
+ std::vector<std::string> commands;
+ commands.push_back(this->GetRecursiveMakeCall(targetProvides.c_str()));
+ this->WriteMakeRule(ruleFileStream, 0, 0,
+ targetDriveName.c_str(), depends, commands);
+ }
+#endif
+
// Add this to the list of build rules in this directory.
if(target.IsInAll())
{
- m_BuildTargets.push_back(target.GetName());
+ m_BuildTargets.push_back(targetDriveName);
}
}
diff --git a/Source/cmLocalUnixMakefileGenerator2.h b/Source/cmLocalUnixMakefileGenerator2.h
index 5f831a0..b867339 100644
--- a/Source/cmLocalUnixMakefileGenerator2.h
+++ b/Source/cmLocalUnixMakefileGenerator2.h
@@ -65,7 +65,8 @@ protected:
void GenerateCMakefile();
void GenerateTargetRuleFile(const cmTarget& target);
void GenerateObjectRuleFile(const cmTarget& target,
- const cmSourceFile& source);
+ const cmSourceFile& source,
+ std::vector<std::string>& objects);
void GenerateCustomRuleFile(const cmCustomCommand& cc);
void GenerateUtilityRuleFile(const cmTarget& target);
std::string GenerateDependsMakeFile(const char* file);