diff options
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmAddTargetCommand.cxx | 13 | ||||
-rw-r--r-- | Source/cmDSPMakefile.cxx | 83 | ||||
-rw-r--r-- | Source/cmDSPMakefile.h | 3 | ||||
-rw-r--r-- | Source/cmDSPWriter.cxx | 83 | ||||
-rw-r--r-- | Source/cmDSPWriter.h | 3 | ||||
-rw-r--r-- | Source/cmDSWMakefile.cxx | 51 | ||||
-rw-r--r-- | Source/cmDSWMakefile.h | 2 | ||||
-rw-r--r-- | Source/cmDSWWriter.cxx | 51 | ||||
-rw-r--r-- | Source/cmDSWWriter.h | 2 | ||||
-rw-r--r-- | Source/cmMakefile.cxx | 16 | ||||
-rw-r--r-- | Source/cmMakefile.h | 11 | ||||
-rw-r--r-- | Source/cmTarget.h | 14 | ||||
-rw-r--r-- | Source/cmUnixMakefileGenerator.cxx | 14 |
13 files changed, 293 insertions, 53 deletions
diff --git a/Source/cmAddTargetCommand.cxx b/Source/cmAddTargetCommand.cxx index bc4fb31..71162c3 100644 --- a/Source/cmAddTargetCommand.cxx +++ b/Source/cmAddTargetCommand.cxx @@ -43,17 +43,14 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // cmAddTargetCommand bool cmAddTargetCommand::Invoke(std::vector<std::string>& args) { - if(args.size() < 1 ) + if(args.size() < 2 ) { this->SetError("called with incorrect number of arguments"); return false; } - return false; - -// for(std::vector<std::string>::iterator i = args.begin(); -// i != args.end(); ++i) -// { -// m_Makefile->Add((*i).c_str()); -// } + std::vector<std::string> dep; + m_Makefile->AddUtilityCommand(args[0].c_str(), + args[1].c_str()); + return true; } diff --git a/Source/cmDSPMakefile.cxx b/Source/cmDSPMakefile.cxx index 6ff4a53..78bcb9e 100644 --- a/Source/cmDSPMakefile.cxx +++ b/Source/cmDSPMakefile.cxx @@ -92,13 +92,17 @@ void cmDSPMakefile::OutputDSPFile() for(cmTargets::iterator l = tgts.begin(); l != tgts.end(); l++) { - if (l->second.IsALibrary()) + switch(l->second.GetType()) { - this->SetBuildType(m_LibraryBuildType, l->first.c_str()); - } - else - { - this->SetBuildType(EXECUTABLE,l->first.c_str()); + case cmTarget::LIBRARY: + this->SetBuildType(m_LibraryBuildType, l->first.c_str()); + break; + case cmTarget::EXECUTABLE: + this->SetBuildType(EXECUTABLE,l->first.c_str()); + break; + case cmTarget::UTILITY: + this->SetBuildType(UTILITY, l->first.c_str()); + break; } this->CreateSingleDSP(l->first.c_str(),l->second); } @@ -121,6 +125,39 @@ void cmDSPMakefile::CreateSingleDSP(const char *lname, cmTarget &target) this->WriteDSPFile(fout,lname,target); } + +void cmDSPMakefile::WriteDSPBuildRule(std::ostream& fout) +{ + std::string dspname = *(m_CreatedProjectNames.end()-1); + dspname += ".dsp"; + std::string makefileIn = "\""; + makefileIn += m_Makefile->GetStartDirectory(); + makefileIn += "/"; + makefileIn += "CMakeLists.txt\""; + std::string dsprule = "\""; + dsprule += m_Makefile->GetHomeDirectory(); + dsprule += "/CMake/Source/CMakeSetupCMD\" "; + dsprule += makefileIn; + dsprule += " -DSP -H\""; + dsprule += m_Makefile->GetHomeDirectory(); + dsprule += "\" -S\""; + dsprule += m_Makefile->GetStartDirectory(); + dsprule += "\" -O\""; + dsprule += m_Makefile->GetStartOutputDirectory(); + dsprule += "\" -B\""; + dsprule += m_Makefile->GetHomeOutputDirectory(); + dsprule += "\""; + + std::set<std::string> depends; + std::set<std::string> outputs; + outputs.insert(outputs.begin(), dspname); + fout << "# Begin Source File\n\n"; + fout << "SOURCE=" << makefileIn.c_str() << "\n\n"; + this->WriteCustomRule(fout, makefileIn.c_str(), dsprule.c_str(), depends, outputs); + fout << "# End Source File\n"; +} + + void cmDSPMakefile::AddDSPBuildRule(cmSourceGroup& sourceGroup) { std::string dspname = *(m_CreatedProjectNames.end()-1); @@ -230,7 +267,7 @@ void cmDSPMakefile::WriteDSPFile(std::ostream& fout, // Tell MS-Dev what the source is. If the compiler knows how to // build it, then it will. - fout << "SOURCE=" << source << "\n\n"; + fout << "SOURCE=" << source.c_str() << "\n\n"; // Loop through every custom command generating code from the // current source. @@ -239,8 +276,21 @@ void cmDSPMakefile::WriteDSPFile(std::ostream& fout, { std::string command = c->first; const cmSourceGroup::CommandFiles& commandFiles = c->second; - this->WriteCustomRule(fout, command.c_str(), commandFiles.m_Depends, + this->WriteCustomRule(fout, source.c_str(), command.c_str(), commandFiles.m_Depends, commandFiles.m_Outputs); + // Create a dummy file with the name of the source if it does + // not exist + if(commandFiles.m_Outputs.size() == 0) + { + std::string dummyFile = m_Makefile->GetStartOutputDirectory(); + dummyFile += "/"; + dummyFile += source; + if(!cmSystemTools::FileExists(dummyFile.c_str())) + { + std::ofstream fout(dummyFile.c_str()); + fout << "Dummy file created by cmake as unused source for utility command.\n"; + } + } } fout << "# End Source File\n"; @@ -259,6 +309,7 @@ void cmDSPMakefile::WriteDSPFile(std::ostream& fout, void cmDSPMakefile::WriteCustomRule(std::ostream& fout, + const char* source, const char* command, const std::set<std::string>& depends, const std::set<std::string>& outputs) @@ -274,7 +325,8 @@ void cmDSPMakefile::WriteCustomRule(std::ostream& fout, { fout << "!ELSEIF \"$(CFG)\" == " << i->c_str() << std::endl; } - + fout << "# Begin Custom Build\n\n"; + // Write out the dependencies (this seems to be the only way to // get VC6 to actually take these dependencies into account. fout << "USERDEP__HACK= "; @@ -286,6 +338,11 @@ void cmDSPMakefile::WriteCustomRule(std::ostream& fout, fout << "\n"; fout << "# Begin Custom Build\n\n"; + if(outputs.size() == 0) + { + fout << source << "_force : \"$(SOURCE)\" \"$(INTDIR)\" \"$(OUTDIR)\""; + fout << "\n " << command << "\n\n"; + } // Write a rule for every output generated by this command. for(std::set<std::string>::const_iterator output = outputs.begin(); @@ -348,6 +405,12 @@ void cmDSPMakefile::SetBuildType(BuildType b, const char *libName) m_DSPFooterTemplate = m_Makefile->GetHomeDirectory(); m_DSPFooterTemplate += "/CMake/Source/EXEFooter.dsptemplate"; break; + case UTILITY: + m_DSPHeaderTemplate = m_Makefile->GetHomeDirectory(); + m_DSPHeaderTemplate += "/CMake/Source/UtilityHeader.dsptemplate"; + m_DSPFooterTemplate = m_Makefile->GetHomeDirectory(); + m_DSPFooterTemplate += "/CMake/Source/UtilityFooter.dsptemplate"; + break; } // once the build type is set, determine what configurations are @@ -400,7 +463,7 @@ void cmDSPMakefile::WriteDSPHeader(std::ostream& fout, const char *libName, { // add libraries to executables and dlls (but never include // a library in a library, bad recursion) - if (!target.IsALibrary() || + if (!target.GetType() == cmTarget::LIBRARY || (m_LibraryBuildType == DLL && libName != j->first)) { if (j->second == cmTarget::GENERAL) diff --git a/Source/cmDSPMakefile.h b/Source/cmDSPMakefile.h index 20f91a5..109feb1 100644 --- a/Source/cmDSPMakefile.h +++ b/Source/cmDSPMakefile.h @@ -57,7 +57,7 @@ public: cmDSPMakefile(cmMakefile*); ~cmDSPMakefile(); void OutputDSPFile(); - enum BuildType {STATIC_LIBRARY, DLL, EXECUTABLE}; + enum BuildType {STATIC_LIBRARY, DLL, EXECUTABLE, UTILITY}; /** * Specify the type of the build: static, dll, or executable. @@ -107,6 +107,7 @@ private: void WriteDSPFooter(std::ostream& fout); void AddDSPBuildRule(cmSourceGroup&); void WriteCustomRule(std::ostream& fout, + const char* source, const char* command, const std::set<std::string>& depends, const std::set<std::string>& outputs); diff --git a/Source/cmDSPWriter.cxx b/Source/cmDSPWriter.cxx index 6ff4a53..78bcb9e 100644 --- a/Source/cmDSPWriter.cxx +++ b/Source/cmDSPWriter.cxx @@ -92,13 +92,17 @@ void cmDSPMakefile::OutputDSPFile() for(cmTargets::iterator l = tgts.begin(); l != tgts.end(); l++) { - if (l->second.IsALibrary()) + switch(l->second.GetType()) { - this->SetBuildType(m_LibraryBuildType, l->first.c_str()); - } - else - { - this->SetBuildType(EXECUTABLE,l->first.c_str()); + case cmTarget::LIBRARY: + this->SetBuildType(m_LibraryBuildType, l->first.c_str()); + break; + case cmTarget::EXECUTABLE: + this->SetBuildType(EXECUTABLE,l->first.c_str()); + break; + case cmTarget::UTILITY: + this->SetBuildType(UTILITY, l->first.c_str()); + break; } this->CreateSingleDSP(l->first.c_str(),l->second); } @@ -121,6 +125,39 @@ void cmDSPMakefile::CreateSingleDSP(const char *lname, cmTarget &target) this->WriteDSPFile(fout,lname,target); } + +void cmDSPMakefile::WriteDSPBuildRule(std::ostream& fout) +{ + std::string dspname = *(m_CreatedProjectNames.end()-1); + dspname += ".dsp"; + std::string makefileIn = "\""; + makefileIn += m_Makefile->GetStartDirectory(); + makefileIn += "/"; + makefileIn += "CMakeLists.txt\""; + std::string dsprule = "\""; + dsprule += m_Makefile->GetHomeDirectory(); + dsprule += "/CMake/Source/CMakeSetupCMD\" "; + dsprule += makefileIn; + dsprule += " -DSP -H\""; + dsprule += m_Makefile->GetHomeDirectory(); + dsprule += "\" -S\""; + dsprule += m_Makefile->GetStartDirectory(); + dsprule += "\" -O\""; + dsprule += m_Makefile->GetStartOutputDirectory(); + dsprule += "\" -B\""; + dsprule += m_Makefile->GetHomeOutputDirectory(); + dsprule += "\""; + + std::set<std::string> depends; + std::set<std::string> outputs; + outputs.insert(outputs.begin(), dspname); + fout << "# Begin Source File\n\n"; + fout << "SOURCE=" << makefileIn.c_str() << "\n\n"; + this->WriteCustomRule(fout, makefileIn.c_str(), dsprule.c_str(), depends, outputs); + fout << "# End Source File\n"; +} + + void cmDSPMakefile::AddDSPBuildRule(cmSourceGroup& sourceGroup) { std::string dspname = *(m_CreatedProjectNames.end()-1); @@ -230,7 +267,7 @@ void cmDSPMakefile::WriteDSPFile(std::ostream& fout, // Tell MS-Dev what the source is. If the compiler knows how to // build it, then it will. - fout << "SOURCE=" << source << "\n\n"; + fout << "SOURCE=" << source.c_str() << "\n\n"; // Loop through every custom command generating code from the // current source. @@ -239,8 +276,21 @@ void cmDSPMakefile::WriteDSPFile(std::ostream& fout, { std::string command = c->first; const cmSourceGroup::CommandFiles& commandFiles = c->second; - this->WriteCustomRule(fout, command.c_str(), commandFiles.m_Depends, + this->WriteCustomRule(fout, source.c_str(), command.c_str(), commandFiles.m_Depends, commandFiles.m_Outputs); + // Create a dummy file with the name of the source if it does + // not exist + if(commandFiles.m_Outputs.size() == 0) + { + std::string dummyFile = m_Makefile->GetStartOutputDirectory(); + dummyFile += "/"; + dummyFile += source; + if(!cmSystemTools::FileExists(dummyFile.c_str())) + { + std::ofstream fout(dummyFile.c_str()); + fout << "Dummy file created by cmake as unused source for utility command.\n"; + } + } } fout << "# End Source File\n"; @@ -259,6 +309,7 @@ void cmDSPMakefile::WriteDSPFile(std::ostream& fout, void cmDSPMakefile::WriteCustomRule(std::ostream& fout, + const char* source, const char* command, const std::set<std::string>& depends, const std::set<std::string>& outputs) @@ -274,7 +325,8 @@ void cmDSPMakefile::WriteCustomRule(std::ostream& fout, { fout << "!ELSEIF \"$(CFG)\" == " << i->c_str() << std::endl; } - + fout << "# Begin Custom Build\n\n"; + // Write out the dependencies (this seems to be the only way to // get VC6 to actually take these dependencies into account. fout << "USERDEP__HACK= "; @@ -286,6 +338,11 @@ void cmDSPMakefile::WriteCustomRule(std::ostream& fout, fout << "\n"; fout << "# Begin Custom Build\n\n"; + if(outputs.size() == 0) + { + fout << source << "_force : \"$(SOURCE)\" \"$(INTDIR)\" \"$(OUTDIR)\""; + fout << "\n " << command << "\n\n"; + } // Write a rule for every output generated by this command. for(std::set<std::string>::const_iterator output = outputs.begin(); @@ -348,6 +405,12 @@ void cmDSPMakefile::SetBuildType(BuildType b, const char *libName) m_DSPFooterTemplate = m_Makefile->GetHomeDirectory(); m_DSPFooterTemplate += "/CMake/Source/EXEFooter.dsptemplate"; break; + case UTILITY: + m_DSPHeaderTemplate = m_Makefile->GetHomeDirectory(); + m_DSPHeaderTemplate += "/CMake/Source/UtilityHeader.dsptemplate"; + m_DSPFooterTemplate = m_Makefile->GetHomeDirectory(); + m_DSPFooterTemplate += "/CMake/Source/UtilityFooter.dsptemplate"; + break; } // once the build type is set, determine what configurations are @@ -400,7 +463,7 @@ void cmDSPMakefile::WriteDSPHeader(std::ostream& fout, const char *libName, { // add libraries to executables and dlls (but never include // a library in a library, bad recursion) - if (!target.IsALibrary() || + if (!target.GetType() == cmTarget::LIBRARY || (m_LibraryBuildType == DLL && libName != j->first)) { if (j->second == cmTarget::GENERAL) diff --git a/Source/cmDSPWriter.h b/Source/cmDSPWriter.h index 20f91a5..109feb1 100644 --- a/Source/cmDSPWriter.h +++ b/Source/cmDSPWriter.h @@ -57,7 +57,7 @@ public: cmDSPMakefile(cmMakefile*); ~cmDSPMakefile(); void OutputDSPFile(); - enum BuildType {STATIC_LIBRARY, DLL, EXECUTABLE}; + enum BuildType {STATIC_LIBRARY, DLL, EXECUTABLE, UTILITY}; /** * Specify the type of the build: static, dll, or executable. @@ -107,6 +107,7 @@ private: void WriteDSPFooter(std::ostream& fout); void AddDSPBuildRule(cmSourceGroup&); void WriteCustomRule(std::ostream& fout, + const char* source, const char* command, const std::set<std::string>& depends, const std::set<std::string>& outputs); diff --git a/Source/cmDSWMakefile.cxx b/Source/cmDSWMakefile.cxx index b03ece6..cd7c292 100644 --- a/Source/cmDSWMakefile.cxx +++ b/Source/cmDSWMakefile.cxx @@ -91,8 +91,13 @@ void cmDSWMakefile::WriteDSWFile(std::ostream& fout) // CMakeLists.txt files that are in sub directories of // this one. std::vector<cmMakefile*> allListFiles; - m_Makefile->FindSubDirectoryCMakeListsFiles(allListFiles); + // add this makefile to the list + allListFiles.push_back(m_Makefile); + // add a special target that depends on ALL projects for easy build + // of Debug only + m_Makefile->AddUtilityCommand("ALL_BUILD", "echo \"Build all projects\""); + m_Makefile->FindSubDirectoryCMakeListsFiles(allListFiles); // For each cmMakefile, create a DSP for it, and // add it to this DSW file for(std::vector<cmMakefile*>::iterator k = allListFiles.begin(); @@ -119,15 +124,52 @@ void cmDSWMakefile::WriteDSWFile(std::ostream& fout) std::vector<std::string> dspnames = pg->GetDSPMakefile()->GetCreatedProjectNames(); const cmTargets &tgts = pg->GetDSPMakefile()->GetMakefile()->GetTargets(); cmTargets::const_iterator l = tgts.begin(); + std::vector<std::string> originalUtilities; + bool addedUtilities = false; for(std::vector<std::string>::iterator si = dspnames.begin(); l != tgts.end(); ++l, ++si) { + // special handling for the current makefile + if(mf == m_Makefile) + { + dir = "."; // no subdirectory for project generated + // if this is the special ALL_BUILD utility, then + // make it depend on every other non UTILITY project. + // This is done by adding the names to the GetUtilities + // vector on the makefile + if(l->first == "ALL_BUILD") + { + addedUtilities = true; + originalUtilities = m_Makefile->GetUtilities(); + for(std::vector<cmMakefile*>::iterator a = allListFiles.begin(); + a != allListFiles.end(); ++a) + { + const cmTargets &atgts = (*a)->GetTargets(); + for(cmTargets::const_iterator al = atgts.begin(); + al != atgts.end(); ++al) + { + if(al->second.GetType() != cmTarget::UTILITY) + { + m_Makefile->GetUtilities().push_back(al->first); + } + } + } + } + } // Write the project into the DSW file this->WriteProject(fout, si->c_str(), dir.c_str(), pg->GetDSPMakefile(),l->second); + if(addedUtilities) + { + m_Makefile->GetUtilities() = originalUtilities; + } + } // delete the cmMakefile which also deletes the cmMSProjectGenerator - delete mf; + if(mf != m_Makefile) + { + delete mf; + } } // Write the footer for the DSW file this->WriteDSWFooter(fout); @@ -141,7 +183,8 @@ void cmDSWMakefile::WriteProject(std::ostream& fout, const char* dspname, const char* dir, cmDSPMakefile* project, - const cmTarget &l) + const cmTarget &l + ) { fout << "#########################################################" "######################\n\n"; @@ -159,7 +202,7 @@ void cmDSWMakefile::WriteProject(std::ostream& fout, { if(j->first != dspname) { - if (!l.IsALibrary() || + if (!(l.GetType() == cmTarget::LIBRARY) || project->GetLibraryBuildType() == cmDSPMakefile::DLL) { // is the library part of this DSW ? If so add dependency diff --git a/Source/cmDSWMakefile.h b/Source/cmDSWMakefile.h index c674b7e..c909d84 100644 --- a/Source/cmDSWMakefile.h +++ b/Source/cmDSWMakefile.h @@ -66,8 +66,6 @@ public: virtual void OutputDSWFile(); private: - void FindAllCMakeListsFiles(const char* subdir, - std::vector<cmMSProjectGenerator*>&); void WriteDSWFile(std::ostream& fout); void WriteDSWHeader(std::ostream& fout); void WriteProject(std::ostream& fout, diff --git a/Source/cmDSWWriter.cxx b/Source/cmDSWWriter.cxx index b03ece6..cd7c292 100644 --- a/Source/cmDSWWriter.cxx +++ b/Source/cmDSWWriter.cxx @@ -91,8 +91,13 @@ void cmDSWMakefile::WriteDSWFile(std::ostream& fout) // CMakeLists.txt files that are in sub directories of // this one. std::vector<cmMakefile*> allListFiles; - m_Makefile->FindSubDirectoryCMakeListsFiles(allListFiles); + // add this makefile to the list + allListFiles.push_back(m_Makefile); + // add a special target that depends on ALL projects for easy build + // of Debug only + m_Makefile->AddUtilityCommand("ALL_BUILD", "echo \"Build all projects\""); + m_Makefile->FindSubDirectoryCMakeListsFiles(allListFiles); // For each cmMakefile, create a DSP for it, and // add it to this DSW file for(std::vector<cmMakefile*>::iterator k = allListFiles.begin(); @@ -119,15 +124,52 @@ void cmDSWMakefile::WriteDSWFile(std::ostream& fout) std::vector<std::string> dspnames = pg->GetDSPMakefile()->GetCreatedProjectNames(); const cmTargets &tgts = pg->GetDSPMakefile()->GetMakefile()->GetTargets(); cmTargets::const_iterator l = tgts.begin(); + std::vector<std::string> originalUtilities; + bool addedUtilities = false; for(std::vector<std::string>::iterator si = dspnames.begin(); l != tgts.end(); ++l, ++si) { + // special handling for the current makefile + if(mf == m_Makefile) + { + dir = "."; // no subdirectory for project generated + // if this is the special ALL_BUILD utility, then + // make it depend on every other non UTILITY project. + // This is done by adding the names to the GetUtilities + // vector on the makefile + if(l->first == "ALL_BUILD") + { + addedUtilities = true; + originalUtilities = m_Makefile->GetUtilities(); + for(std::vector<cmMakefile*>::iterator a = allListFiles.begin(); + a != allListFiles.end(); ++a) + { + const cmTargets &atgts = (*a)->GetTargets(); + for(cmTargets::const_iterator al = atgts.begin(); + al != atgts.end(); ++al) + { + if(al->second.GetType() != cmTarget::UTILITY) + { + m_Makefile->GetUtilities().push_back(al->first); + } + } + } + } + } // Write the project into the DSW file this->WriteProject(fout, si->c_str(), dir.c_str(), pg->GetDSPMakefile(),l->second); + if(addedUtilities) + { + m_Makefile->GetUtilities() = originalUtilities; + } + } // delete the cmMakefile which also deletes the cmMSProjectGenerator - delete mf; + if(mf != m_Makefile) + { + delete mf; + } } // Write the footer for the DSW file this->WriteDSWFooter(fout); @@ -141,7 +183,8 @@ void cmDSWMakefile::WriteProject(std::ostream& fout, const char* dspname, const char* dir, cmDSPMakefile* project, - const cmTarget &l) + const cmTarget &l + ) { fout << "#########################################################" "######################\n\n"; @@ -159,7 +202,7 @@ void cmDSWMakefile::WriteProject(std::ostream& fout, { if(j->first != dspname) { - if (!l.IsALibrary() || + if (!(l.GetType() == cmTarget::LIBRARY) || project->GetLibraryBuildType() == cmDSPMakefile::DLL) { // is the library part of this DSW ? If so add dependency diff --git a/Source/cmDSWWriter.h b/Source/cmDSWWriter.h index c674b7e..c909d84 100644 --- a/Source/cmDSWWriter.h +++ b/Source/cmDSWWriter.h @@ -66,8 +66,6 @@ public: virtual void OutputDSWFile(); private: - void FindAllCMakeListsFiles(const char* subdir, - std::vector<cmMSProjectGenerator*>&); void WriteDSWFile(std::ostream& fout); void WriteDSWHeader(std::ostream& fout); void WriteProject(std::ostream& fout, diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index d706d46..e063ee6 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -486,7 +486,7 @@ void cmMakefile::SetProjectName(const char* p) void cmMakefile::AddLibrary(const char* lname, const std::vector<std::string> &srcs) { cmTarget target; - target.SetIsALibrary(1); + target.SetType(cmTarget::LIBRARY); target.GetSourceLists() = srcs; m_Targets.insert(cmTargets::value_type(lname,target)); } @@ -495,12 +495,24 @@ void cmMakefile::AddExecutable(const char *exeName, const std::vector<std::string> &srcs) { cmTarget target; - target.SetIsALibrary(0); + target.SetType(cmTarget::EXECUTABLE); target.GetSourceLists() = srcs; m_Targets.insert(cmTargets::value_type(exeName,target)); } +void cmMakefile::AddUtilityCommand(const char* utilityName, + const char* command) +{ + cmTarget target; + target.SetType(cmTarget::UTILITY); + std::vector<std::string> empty; + cmCustomCommand cc(utilityName, command, empty, empty); + target.GetCustomCommands().push_back(cc); + m_Targets.insert(cmTargets::value_type(utilityName,target)); +} + + void cmMakefile::AddSourceGroup(const char* name, const char* regex) { // First see if the group exists. If so, replace its regular expression. diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h index 7456544..fbfd650 100644 --- a/Source/cmMakefile.h +++ b/Source/cmMakefile.h @@ -95,6 +95,10 @@ public: * superclass. */ void SetMakefileGenerator(cmMakefileGenerator*); + + ///! Get the current makefile generator. + cmMakefileGenerator* GetMakefileGenerator() + { return m_MakefileGenerator;} /** * Produce the output makefile. @@ -132,6 +136,13 @@ public: void AddExecutable(const char *exename, const std::vector<std::string> &srcs); /** + * Add a utility to the build. A utiltity target is + * a command that is run every time a target is built. + */ + void AddUtilityCommand(const char* utilityName, + const char* command); + + /** * Add a utility on which this project depends. A utility is an executable * name as would be specified to the ADD_EXECUTABLE or UTILITY_SOURCE * commands. It is not a full path nor does it have an extension. diff --git a/Source/cmTarget.h b/Source/cmTarget.h index 6164e28..dd01521 100644 --- a/Source/cmTarget.h +++ b/Source/cmTarget.h @@ -54,12 +54,16 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. class cmTarget { public: + enum TargetType { EXECUTABLE, LIBRARY, UTILITY }; /** - * is this target a library? + * Return the type of target. */ - bool IsALibrary() const { return m_IsALibrary; } - bool GetIsALibrary() const { return m_IsALibrary; } - void SetIsALibrary(bool f) { m_IsALibrary = f; } + TargetType GetType() const + { + return m_TargetType; + } + + void SetType(TargetType f) { m_TargetType = f; } /** * Get the list of the custom commands for this target @@ -103,7 +107,7 @@ public: private: std::vector<cmCustomCommand> m_CustomCommands; std::vector<std::string> m_SourceLists; - bool m_IsALibrary; + TargetType m_TargetType; std::vector<cmSourceFile> m_SourceFiles; LinkLibraries m_LinkLibraries; }; diff --git a/Source/cmUnixMakefileGenerator.cxx b/Source/cmUnixMakefileGenerator.cxx index 4e621f7..5937d44 100644 --- a/Source/cmUnixMakefileGenerator.cxx +++ b/Source/cmUnixMakefileGenerator.cxx @@ -99,7 +99,7 @@ void cmUnixMakefileGenerator::OutputTargetRules(std::ostream& fout) for(cmTargets::const_iterator l = tgts.begin(); l != tgts.end(); l++) { - if (l->second.IsALibrary()) + if (l->second.GetType() == cmTarget::LIBRARY) { fout << " \\\nlib" << l->first.c_str() << "${CMAKE_LIB_EXT}"; } @@ -108,7 +108,7 @@ void cmUnixMakefileGenerator::OutputTargetRules(std::ostream& fout) for(cmTargets::const_iterator l = tgts.begin(); l != tgts.end(); l++) { - if (!l->second.IsALibrary()) + if (!l->second.GetType() == cmTarget::LIBRARY) { fout << "\\\n" << l->first.c_str(); } @@ -195,7 +195,7 @@ void cmUnixMakefileGenerator::OutputTargets(std::ostream& fout) for(cmTargets::const_iterator l = tgts.begin(); l != tgts.end(); l++) { - if (l->second.IsALibrary()) + if (l->second.GetType() == cmTarget::LIBRARY) { fout << "#---------------------------------------------------------\n"; fout << "# rules for a library\n"; @@ -217,7 +217,7 @@ void cmUnixMakefileGenerator::OutputTargets(std::ostream& fout) this->OutputLinkLibraries(fout, l->first.c_str(), l->second); fout << "\n\n"; } - else + else if (l->second.GetType() == cmTarget::EXECUTABLE) { fout << l->first << ": ${" << l->first << "_SRC_OBJS} ${CMAKE_DEPEND_LIBS}\n"; @@ -487,6 +487,12 @@ void cmUnixMakefileGenerator::OutputCustomRules(std::ostream& fout) { std::string command = c->first; const cmSourceGroup::CommandFiles& commandFiles = c->second; + // if the command has no outputs, then it is a utility command + // with no outputs or depends + if(commandFiles.m_Outputs.size() == 0) + { + fout << source.c_str() << ":\n\t" << command.c_str() << "\n\n"; + } // Write a rule for every output generated by this command. for(std::set<std::string>::const_iterator output = commandFiles.m_Outputs.begin(); |