summaryrefslogtreecommitdiffstats
path: root/Source/cmLocalUnixMakefileGenerator3.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmLocalUnixMakefileGenerator3.cxx')
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.cxx300
1 files changed, 78 insertions, 222 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx
index 819d21f..11a86bb 100644
--- a/Source/cmLocalUnixMakefileGenerator3.cxx
+++ b/Source/cmLocalUnixMakefileGenerator3.cxx
@@ -60,11 +60,6 @@ void cmLocalUnixMakefileGenerator3::Generate()
// Setup our configuration variables for this directory.
this->ConfigureOutputPaths();
- // write the custom commands, this must happen before writing the targets,
- // but... it may be that it needs to happen after the TraveVSDependencies
- // call
- this->WriteCustomCommands();
-
// Generate the rule files for each target.
cmTargets& targets = m_Makefile->GetTargets();
std::string empty;
@@ -141,89 +136,39 @@ void cmLocalUnixMakefileGenerator3::FormatOutputPath(std::string& path,
}
-void cmLocalUnixMakefileGenerator3::WriteCustomCommands()
+void cmLocalUnixMakefileGenerator3
+::WriteCustomCommands(const cmTarget &target,std::ostream& ruleFileStream,
+ std::vector<std::string>& cleanFiles)
{
- // Generate the rule files for each custom command.
- const std::vector<cmSourceFile*>& sources = m_Makefile->GetSourceFiles();
- for(std::vector<cmSourceFile*>::const_iterator i = sources.begin();
- i != sources.end(); ++i)
- {
- if(const cmCustomCommand* cc = (*i)->GetCustomCommand())
- {
- this->GenerateCustomRuleFile(*cc);
- }
- }
+ std::string tgtDir = m_Makefile->GetStartOutputDirectory();
+ tgtDir += "/";
+ tgtDir += this->GetTargetDirectory(target);
- // generate the includes
- std::string ruleFileName = "CMakeCustomRules.dir/build.make";
+ // add custom commands to the clean rules?
+ const char* clean_no_custom = m_Makefile->GetProperty("CLEAN_NO_CUSTOM");
+ bool clean = cmSystemTools::IsOff(clean_no_custom);
- // Open the rule file. This should be copy-if-different because the
- // rules may depend on this file itself.
- std::string ruleFileNameFull = this->ConvertToFullPath(ruleFileName);
- cmGeneratedFileStream ruleFileStream(ruleFileNameFull.c_str());
- ruleFileStream.SetCopyIfDifferent(true);
- if(!ruleFileStream)
- {
- return;
- }
- this->WriteDisclaimer(ruleFileStream);
-
- std::string relPath = this->GetHomeRelativeOutputPath();
+ // Generate the rule files for each custom command.
+ // get the classes from the source lists then add them to the groups
+ const std::vector<cmSourceFile*> &classes = target.GetSourceFiles();
std::string objTarget;
- for(std::set<cmStdString>::const_iterator i = m_CustomRuleFiles.begin();
- i != m_CustomRuleFiles.end(); ++i)
- {
- objTarget = relPath;
- objTarget += *i;
- ruleFileStream
- << m_IncludeDirective << " "
- << this->ConvertToOutputForExisting(objTarget.c_str()).c_str()
- << "\n";
- }
-
- // now do the clean
- ruleFileName = "CMakeCustomRules.dir/clean.make";
-
- // Open the rule file. This should be copy-if-different because the
- // rules may depend on this file itself.
- ruleFileNameFull = this->ConvertToFullPath(ruleFileName);
- cmGeneratedFileStream ruleFileStream2(ruleFileNameFull.c_str());
- ruleFileStream2.SetCopyIfDifferent(true);
- if(!ruleFileStream2)
- {
- return;
- }
- this->WriteDisclaimer(ruleFileStream2);
-
- std::vector<std::string> cleanFiles;
- for(std::vector<cmSourceFile*>::const_iterator i = sources.begin();
- i != sources.end(); ++i)
+ for(std::vector<cmSourceFile*>::const_iterator i = classes.begin();
+ i != classes.end(); i++)
{
if(const cmCustomCommand* cc = (*i)->GetCustomCommand())
{
- cleanFiles.push_back(cc->GetOutput());
+ objTarget = this->GenerateCustomRuleFile(*cc,tgtDir.c_str());
+ if (clean)
+ {
+ cleanFiles.push_back
+ (this->Convert(cc->GetOutput(),HOME_OUTPUT,SHELL));
+ }
+ ruleFileStream
+ << m_IncludeDirective << " "
+ << this->ConvertToOutputForExisting(objTarget.c_str()).c_str()
+ << "\n";
}
}
- if (cleanFiles.size())
- {
- std::vector<std::string> commands;
- std::vector<std::string> depends;
- this->AppendCleanCommand(commands, cleanFiles);
- std::string dir = m_Makefile->GetStartOutputDirectory();
- dir += "/CMakeCustomRules.dir/clean";
- //dir = cmSystemTools::RelativePath(m_Makefile->GetHomeOutputDirectory(), dir.c_str());
- //dir = cmSystemTools::ConvertToOutputPath(dir.c_str());
- dir = this->Convert(dir.c_str(),HOME_OUTPUT,SHELL,false);
- this->WriteMakeRule(ruleFileStream2,
- "Clean the output of this custom command.",
- dir.c_str(), depends, commands);
- // do the include
- commands.clear();
- depends.push_back(dir);
- this->WriteMakeRule(ruleFileStream2,
- "Clean the output of this custom command.",
- "clean", depends, commands);
- }
}
//----------------------------------------------------------------------------
@@ -382,18 +327,15 @@ cmLocalUnixMakefileGenerator3
this->WriteMakeVariables(ruleFileStream);
- // include the custom commands rules
- if (m_CustomRuleFiles.size())
+ // write the custom commands for this target
+ std::vector<std::string> cleanFiles;
+ // Look for files registered for cleaning in this directory.
+ if(const char* additional_clean_files =
+ m_Makefile->GetProperty("ADDITIONAL_MAKE_CLEAN_FILES"))
{
- // do the include
- std::string dir2 = m_Makefile->GetStartOutputDirectory();
- dir2 += "/CMakeCustomRules.dir/build.make";
- dir2 = this->Convert(dir2.c_str(),HOME_OUTPUT,MAKEFILE);
- ruleFileStream
- << m_IncludeDirective << " "
- << this->ConvertToOutputForExisting(dir2.c_str()).c_str()
- << "\n";
- }
+ cmSystemTools::ExpandListArgument(additional_clean_files, cleanFiles);
+ }
+ this->WriteCustomCommands(target,ruleFileStream,cleanFiles);
// Include the rule file for each object.
std::string relPath = this->GetHomeRelativeOutputPath();
@@ -422,23 +364,33 @@ cmLocalUnixMakefileGenerator3
{
case cmTarget::STATIC_LIBRARY:
this->WriteStaticLibraryRule(ruleFileStream, ruleFileName.c_str(),
- target, objects, external_objects);
+ target, objects, external_objects,
+ cleanFiles);
break;
case cmTarget::SHARED_LIBRARY:
this->WriteSharedLibraryRule(ruleFileStream, ruleFileName.c_str(),
- target, objects, external_objects);
+ target, objects, external_objects,
+ cleanFiles);
break;
case cmTarget::MODULE_LIBRARY:
this->WriteModuleLibraryRule(ruleFileStream, ruleFileName.c_str(),
- target, objects, external_objects);
+ target, objects, external_objects,
+ cleanFiles);
break;
case cmTarget::EXECUTABLE:
this->WriteExecutableRule(ruleFileStream, ruleFileName.c_str(),
- target, objects, external_objects);
+ target, objects, external_objects,
+ cleanFiles);
break;
default:
break;
}
+
+ // Write the requires target.
+ this->WriteTargetRequiresRule(ruleFileStream, target, objects);
+
+ // Write clean target
+ this->WriteTargetCleanRule(ruleFileStream, target, cleanFiles);
}
//----------------------------------------------------------------------------
@@ -745,14 +697,10 @@ cmLocalUnixMakefileGenerator3
}
//----------------------------------------------------------------------------
-void
+std::string
cmLocalUnixMakefileGenerator3
-::GenerateCustomRuleFile(const cmCustomCommand& cc)
+::GenerateCustomRuleFile(const cmCustomCommand& cc, const char *dir)
{
- // Create a directory for custom rule files.
- std::string dir = "CMakeCustomRules.dir";
- cmSystemTools::MakeDirectory(this->ConvertToFullPath(dir).c_str());
-
// Convert the output name to a relative path if possible.
std::string output = this->Convert(cc.GetOutput(),START_OUTPUT);
@@ -768,27 +716,16 @@ cmLocalUnixMakefileGenerator3
ruleFileName += customName;
ruleFileName += ".build.make";
- // If this is a duplicate rule produce an error.
- if(m_CustomRuleFiles.find(ruleFileName) != m_CustomRuleFiles.end())
- {
- cmSystemTools::Error("An output was found with multiple rules on how to build it for output: ",
- cc.GetOutput());
- return;
- }
- m_CustomRuleFiles.insert(ruleFileName);
-
// what is the relative path to the rule file
- std::string relRuleFile = this->GetHomeRelativeOutputPath();
- relRuleFile += ruleFileName;
+ std::string relRuleFile = this->Convert(ruleFileName.c_str(),HOME_OUTPUT);
// Open the rule file. This should be copy-if-different because the
// rules may depend on this file itself.
- std::string ruleFileNameFull = this->ConvertToFullPath(ruleFileName);
- cmGeneratedFileStream ruleFileStream(ruleFileNameFull.c_str());
+ cmGeneratedFileStream ruleFileStream(ruleFileName.c_str());
ruleFileStream.SetCopyIfDifferent(true);
if(!ruleFileStream)
{
- return;
+ return relRuleFile;
}
this->WriteDisclaimer(ruleFileStream);
ruleFileStream
@@ -800,7 +737,7 @@ cmLocalUnixMakefileGenerator3
preEcho += output;
this->AppendEcho(commands, preEcho.c_str());
this->AppendCustomCommand(commands, cc);
-
+
// Collect the dependencies.
std::vector<std::string> depends;
this->AppendCustomDepend(depends, cc);
@@ -817,6 +754,7 @@ cmLocalUnixMakefileGenerator3
this->WriteMakeRule(ruleFileStream, comment,
cc.GetOutput(), depends, commands);
+ return relRuleFile;
}
//----------------------------------------------------------------------------
@@ -846,18 +784,14 @@ cmLocalUnixMakefileGenerator3
ruleFileStream
<< "# Utility rule file for " << target.GetName() << ".\n\n";
- // include the custom commands rules
- if (m_CustomRuleFiles.size())
+ // write the custom commands for this target
+ std::vector<std::string> cleanFiles;
+ if(const char* additional_clean_files =
+ m_Makefile->GetProperty("ADDITIONAL_MAKE_CLEAN_FILES"))
{
- // do the include
- std::string dir2 = m_Makefile->GetStartOutputDirectory();
- dir2 += "/CMakeCustomRules.dir/build.make";
- dir2 = this->Convert(dir2.c_str(),HOME_OUTPUT,MAKEFILE);
- ruleFileStream
- << m_IncludeDirective << " "
- << this->ConvertToOutputForExisting(dir2.c_str()).c_str()
- << "\n";
- }
+ cmSystemTools::ExpandListArgument(additional_clean_files, cleanFiles);
+ }
+ this->WriteCustomCommands(target,ruleFileStream, cleanFiles);
// Collect the commands and dependencies.
std::vector<std::string> commands;
@@ -892,6 +826,9 @@ cmLocalUnixMakefileGenerator3
this->Convert(buildTargetRuleName.c_str(),HOME_OUTPUT,MAKEFILE);
this->WriteConvenienceRule(ruleFileStream, target.GetName(),
buildTargetRuleName.c_str());
+
+ // Write clean target
+ this->WriteTargetCleanRule(ruleFileStream, target, cleanFiles);
}
//----------------------------------------------------------------------------
@@ -1082,21 +1019,6 @@ void cmLocalUnixMakefileGenerator3::WriteMainTargetIncludes(std::ostream& makefi
std::vector<std::string> depends;
std::vector<std::string> no_commands;
- // if this is the clean rules also include the custom commands if there
- // were any
- const char* clean_no_custom = m_Makefile->GetProperty("CLEAN_NO_CUSTOM");
- if (!strcmp(rule,"clean") && cmSystemTools::IsOff(clean_no_custom))
- {
- // do the include
- std::string dir = m_Makefile->GetStartOutputDirectory();
- dir += "/CMakeCustomRules.dir/clean.make";
- dir = this->Convert(dir.c_str(),HOME_OUTPUT,MAKEFILE);
- makefileStream
- << m_IncludeDirective << " "
- << this->ConvertToOutputForExisting(dir.c_str()).c_str()
- << "\n";
- }
-
for (cmTargets::const_iterator l = m_Makefile->GetTargets().begin();
l != m_Makefile->GetTargets().end(); l++)
{
@@ -1188,41 +1110,6 @@ void cmLocalUnixMakefileGenerator3::WriteMainTargetRules(std::ostream& makefileS
//----------------------------------------------------------------------------
void
cmLocalUnixMakefileGenerator3
-::WriteLocalCleanRule(std::ostream& makefileStream)
-{
- // Collect a list of extra files to clean in this directory.
- std::vector<std::string> files;
-
- // Look for files registered for cleaning in this directory.
- if(const char* additional_clean_files =
- m_Makefile->GetProperty("ADDITIONAL_MAKE_CLEAN_FILES"))
- {
- cmSystemTools::ExpandListArgument(additional_clean_files, files);
- }
-
- // Write the local clean rule for this directory.
- if(!files.empty())
- {
- // Have extra files to clean. Write the action to remove them.
- std::string cleanTarget = this->GetHomeRelativeOutputPath();
- cleanTarget += "clean.local";
- std::vector<std::string> no_depends;
- std::vector<std::string> commands;
- this->AppendCleanCommand(commands, files);
- this->WriteMakeRule(makefileStream,
- "Clean extra files in this directory.",
- cleanTarget.c_str(), no_depends, commands);
- commands.clear();
- no_depends.push_back(cleanTarget);
- this->WriteMakeRule(makefileStream, 0,
- "clean", no_depends, commands);
- }
-}
-
-
-//----------------------------------------------------------------------------
-void
-cmLocalUnixMakefileGenerator3
::WriteSpecialTargetsTop(std::ostream& makefileStream)
{
this->WriteDivider(makefileStream);
@@ -1482,7 +1369,8 @@ cmLocalUnixMakefileGenerator3
const char* ruleFileName,
const cmTarget& target,
const std::vector<std::string>& objects,
- const std::vector<std::string>& external_objects)
+ const std::vector<std::string>& external_objects,
+ std::vector<std::string>& cleanFiles)
{
// Write the dependency generation rule.
this->WriteTargetDependRule(ruleFileStream, target, objects);
@@ -1510,8 +1398,6 @@ cmLocalUnixMakefileGenerator3
objTarget += ruleFileName;
this->AppendRuleDepend(depends, objTarget.c_str());
- std::vector<std::string> cleanFiles;
-
// Construct the full path to the executable that will be generated.
std::string targetFullPath = m_ExecutableOutputPath;
if(targetFullPath.length() == 0)
@@ -1646,13 +1532,8 @@ cmLocalUnixMakefileGenerator3
this->WriteConvenienceRule(ruleFileStream, targetFullPath.c_str(),
buildTargetRuleName.c_str());
- // Write clean target
cleanFiles.push_back(cleanObjs);
cleanFiles.push_back(targetOutPath.c_str());
- this->WriteTargetCleanRule(ruleFileName, target, cleanFiles, objects, external_objects);
-
- // Write the driving make target.
- this->WriteTargetRequiresRule(ruleFileStream, target, objects);
}
//----------------------------------------------------------------------------
@@ -1662,7 +1543,8 @@ cmLocalUnixMakefileGenerator3
const char* ruleFileName,
const cmTarget& target,
const std::vector<std::string>& objects,
- const std::vector<std::string>& external_objects)
+ const std::vector<std::string>& external_objects,
+ std::vector<std::string>& cleanFiles)
{
const char* linkLanguage =
target.GetLinkerLanguage(this->GetGlobalGenerator());
@@ -1674,7 +1556,7 @@ cmLocalUnixMakefileGenerator3
this->AppendFlags(extraFlags, target.GetProperty("STATIC_LIBRARY_FLAGS"));
this->WriteLibraryRule(ruleFileStream, ruleFileName, target,
objects, external_objects,
- linkRuleVar.c_str(), extraFlags.c_str());
+ linkRuleVar.c_str(), extraFlags.c_str(),cleanFiles);
}
//----------------------------------------------------------------------------
@@ -1684,7 +1566,8 @@ cmLocalUnixMakefileGenerator3
const char* ruleFileName,
const cmTarget& target,
const std::vector<std::string>& objects,
- const std::vector<std::string>& external_objects)
+ const std::vector<std::string>& external_objects,
+ std::vector<std::string>& cleanFiles)
{
const char* linkLanguage =
target.GetLinkerLanguage(this->GetGlobalGenerator());
@@ -1712,7 +1595,7 @@ cmLocalUnixMakefileGenerator3
}
this->WriteLibraryRule(ruleFileStream, ruleFileName, target,
objects, external_objects,
- linkRuleVar.c_str(), extraFlags.c_str());
+ linkRuleVar.c_str(), extraFlags.c_str(), cleanFiles);
}
//----------------------------------------------------------------------------
@@ -1722,7 +1605,8 @@ cmLocalUnixMakefileGenerator3
const char* ruleFileName,
const cmTarget& target,
const std::vector<std::string>& objects,
- const std::vector<std::string>& external_objects)
+ const std::vector<std::string>& external_objects,
+ std::vector<std::string>& cleanFiles)
{
const char* linkLanguage =
target.GetLinkerLanguage(this->GetGlobalGenerator());
@@ -1736,7 +1620,7 @@ cmLocalUnixMakefileGenerator3
// TODO: .def files should be supported here also.
this->WriteLibraryRule(ruleFileStream, ruleFileName, target,
objects, external_objects,
- linkRuleVar.c_str(), extraFlags.c_str());
+ linkRuleVar.c_str(), extraFlags.c_str(), cleanFiles);
}
//----------------------------------------------------------------------------
@@ -1748,7 +1632,8 @@ cmLocalUnixMakefileGenerator3
const std::vector<std::string>& objects,
const std::vector<std::string>& external_objects,
const char* linkRuleVar,
- const char* extraFlags)
+ const char* extraFlags,
+ std::vector<std::string>& cleanFiles)
{
// Write the dependency generation rule.
this->WriteTargetDependRule(ruleFileStream, target, objects);
@@ -1778,8 +1663,6 @@ cmLocalUnixMakefileGenerator3
objTarget += ruleFileName;
this->AppendRuleDepend(depends, objTarget.c_str());
- std::vector<std::string> cleanFiles;
-
// from here up is the same for exe or lib
for(std::vector<std::string>::const_iterator obj = external_objects.begin();
@@ -1964,13 +1847,8 @@ cmLocalUnixMakefileGenerator3
this->WriteConvenienceRule(ruleFileStream, targetFullPath.c_str(),
buildTargetRuleName.c_str());
- // Write clean target
cleanFiles.push_back(cleanObjs);
cleanFiles.push_back(targetOutPath.c_str());
- this->WriteTargetCleanRule(ruleFileName, target, cleanFiles, objects, external_objects);
-
- // Write the driving make target.
- this->WriteTargetRequiresRule(ruleFileStream, target, objects);
}
//----------------------------------------------------------------------------
@@ -2058,32 +1936,10 @@ cmLocalUnixMakefileGenerator3
//----------------------------------------------------------------------------
void
cmLocalUnixMakefileGenerator3
-::WriteTargetCleanRule(const char *ruleFileName,
+::WriteTargetCleanRule(std::ostream& ruleFileStream,
const cmTarget& target,
- const std::vector<std::string>& files,
- const std::vector<std::string>& objects,
- const std::vector<std::string>& external_objects)
+ const std::vector<std::string>& files)
{
- std::string dir = cmSystemTools::GetFilenamePath(ruleFileName);
- std::string cleanFileName = dir;
- cleanFileName += "/clean.make";
-
- // Open the rule file. This should be copy-if-different because the
- // rules may depend on this file itself.
- std::string ruleFileNameFull = this->ConvertToFullPath(cleanFileName);
- cmGeneratedFileStream ruleFileStream(ruleFileNameFull.c_str());
- ruleFileStream.SetCopyIfDifferent(true);
- if(!ruleFileStream)
- {
- return;
- }
- this->WriteDisclaimer(ruleFileStream);
-
- std::string variableName;
- std::string variableNameExternal;
- this->WriteObjectsVariable(ruleFileStream, target, objects, external_objects,
- variableName, variableNameExternal);
-
std::vector<std::string> no_depends;
std::vector<std::string> commands;