summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2001-11-01 23:37:28 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2001-11-01 23:37:28 (GMT)
commitc15ad5c98d7b527622a0f1ddbaaad6ffaf08d94a (patch)
tree544b487f9739b69b4e608866428f58fbf2125df2
parenta13cb203ad1e12850bc0ee2df6fd61b5f813543c (diff)
downloadCMake-c15ad5c98d7b527622a0f1ddbaaad6ffaf08d94a.zip
CMake-c15ad5c98d7b527622a0f1ddbaaad6ffaf08d94a.tar.gz
CMake-c15ad5c98d7b527622a0f1ddbaaad6ffaf08d94a.tar.bz2
ENH: clean up interface and change build in current directory to build the depend file first
-rw-r--r--Source/cmUnixMakefileGenerator.cxx214
-rw-r--r--Source/cmUnixMakefileGenerator.h13
2 files changed, 165 insertions, 62 deletions
diff --git a/Source/cmUnixMakefileGenerator.cxx b/Source/cmUnixMakefileGenerator.cxx
index d87bfdb..1610e0e 100644
--- a/Source/cmUnixMakefileGenerator.cxx
+++ b/Source/cmUnixMakefileGenerator.cxx
@@ -512,6 +512,113 @@ void cmUnixMakefileGenerator::OutputLinkLibraries(std::ostream& fout,
}
+void cmUnixMakefileGenerator::OutputSharedLibraryRule(std::ostream& fout,
+ const char* name,
+ const cmTarget &t)
+{
+ std::string target = m_LibraryOutputPath + "lib" + name + "$(SHLIB_SUFFIX)";
+ std::string depend = "${";
+ depend += name;
+ depend += "_SRC_OBJS} ${" + std::string(name) + "_DEPEND_LIBS}";
+ std::string command = "rm -f lib";
+ command += name;
+ command += "$(SHLIB_SUFFIX)";
+ std::string command2 = "$(CMAKE_CXX_COMPILER) ${CMAKE_SHLIB_LINK_FLAGS} "
+ "${CMAKE_SHLIB_BUILD_FLAGS} ${CMAKE_CXXFLAGS} -o \\\n";
+ command2 += "\t ";
+ command2 += m_LibraryOutputPath + "lib" + std::string(name) + "$(SHLIB_SUFFIX) \\\n";
+ command2 += "\t ${" + std::string(name) + "_SRC_OBJS} ";
+ std::strstream linklibs;
+ this->OutputLinkLibraries(linklibs, name, t);
+ linklibs << std::ends;
+ command2 += linklibs.str();
+ delete [] linklibs.str();
+ this->OutputMakeRule(fout, "rules for a shared library",
+ target.c_str(),
+ depend.c_str(),
+ command.c_str(),
+ command2.c_str());
+}
+
+void cmUnixMakefileGenerator::OutputModuleLibraryRule(std::ostream& fout,
+ const char* name,
+ const cmTarget &t)
+{
+ std::string target = m_LibraryOutputPath + "lib" + std::string(name) + "$(MODULE_SUFFIX)";
+ std::string depend = "${";
+ depend += std::string(name) + "_SRC_OBJS} ${" + std::string(name) + "_DEPEND_LIBS}";
+ std::string command = "rm -f lib" + std::string(name) + "$(MODULE_SUFFIX)";
+ std::string command2 = "$(CMAKE_CXX_COMPILER) ${CMAKE_MODULE_LINK_FLAGS} "
+ "${CMAKE_MODULE_BUILD_FLAGS} ${CMAKE_CXXFLAGS} -o \\\n";
+ command2 += "\t ";
+ command2 += m_LibraryOutputPath + "lib" + std::string(name) + "$(MODULE_SUFFIX) \\\n";
+ command2 += "\t ${" + std::string(name) + "_SRC_OBJS} ";
+ std::strstream linklibs;
+ this->OutputLinkLibraries(linklibs, std::string(name).c_str(), t);
+ linklibs << std::ends;
+ command2 += linklibs.str();
+ delete [] linklibs.str();
+ this->OutputMakeRule(fout, "rules for a shared module library",
+ target.c_str(),
+ depend.c_str(),
+ command.c_str(),
+ command2.c_str());
+}
+
+
+void cmUnixMakefileGenerator::OutputStaticLibraryRule(std::ostream& fout,
+ const char* name,
+ const cmTarget & t)
+{
+ std::string target = m_LibraryOutputPath + "lib" + std::string(name) + ".a";
+ std::string depend = "${";
+ depend += std::string(name) + "_SRC_OBJS}";
+ std::string command = "${CMAKE_AR} ${CMAKE_AR_ARGS} ";
+ command += m_LibraryOutputPath;
+ command += "lib";
+ command += name;
+ command += ".a ${";
+ command += std::string(name) + "_SRC_OBJS}";
+ std::string command2 = "${CMAKE_RANLIB} ";
+ command2 += m_LibraryOutputPath;
+ command2 += "lib";
+ command2 += std::string(name) + ".a";
+ std::string comment = "rule to build static library: ";
+ comment += name;
+ this->OutputMakeRule(fout,
+ comment.c_str(),
+ target.c_str(),
+ depend.c_str(),
+ command.c_str(),
+ command2.c_str());
+}
+
+void cmUnixMakefileGenerator::OutputExecutableRule(std::ostream& fout,
+ const char* name,
+ const cmTarget & t)
+{
+ std::string target = m_ExecutableOutputPath + name;
+ std::string depend = "${";
+ depend += std::string(name) + "_SRC_OBJS} ${" + std::string(name) + "_DEPEND_LIBS}";
+ std::string command =
+ "${CMAKE_CXX_COMPILER} ${CMAKE_SHLIB_LINK_FLAGS} ${CMAKE_CXXFLAGS} ";
+ command += "${" + std::string(name) + "_SRC_OBJS} ";
+ std::strstream linklibs;
+ this->OutputLinkLibraries(linklibs, 0, t);
+ linklibs << std::ends;
+ command += linklibs.str();
+ command += " -o " + m_ExecutableOutputPath + name;
+ std::string comment = "rule to build executable: ";
+ comment += name;
+ this->OutputMakeRule(fout,
+ comment.c_str(),
+ target.c_str(),
+ depend.c_str(),
+ command.c_str());
+}
+
+
+
void cmUnixMakefileGenerator::OutputTargets(std::ostream& fout)
{
// for each target
@@ -519,66 +626,28 @@ void cmUnixMakefileGenerator::OutputTargets(std::ostream& fout)
for(cmTargets::const_iterator l = tgts.begin();
l != tgts.end(); l++)
{
- if (l->second.GetType() == cmTarget::STATIC_LIBRARY)
- {
- fout << "#---------------------------------------------------------\n";
- fout << "# rules for a static library\n";
- fout << "#\n";
- fout << m_LibraryOutputPath << "lib" << l->first << ".a: ${" <<
- l->first << "_SRC_OBJS} \n";
- fout << "\t${CMAKE_AR} ${CMAKE_AR_ARGS} "
- << m_LibraryOutputPath << "lib" << l->first << ".a ${" <<
- l->first << "_SRC_OBJS} \n";
- fout << "\t${CMAKE_RANLIB} "
- << m_LibraryOutputPath << "lib" << l->first << ".a\n";
- fout << "\n\n";
- }
- else if (l->second.GetType() == cmTarget::SHARED_LIBRARY)
+ switch(l->second.GetType())
{
- fout << "#---------------------------------------------------------\n";
- fout << "# rules for a shared library\n";
- fout << "#\n";
- fout << m_LibraryOutputPath << "lib" << l->first << "$(SHLIB_SUFFIX): ${" <<
- l->first << "_SRC_OBJS} ${" << l->first << "_DEPEND_LIBS} \n";
- fout << "\trm -f lib" << l->first << "$(SHLIB_SUFFIX)\n";
- fout << "\t$(CMAKE_CXX_COMPILER) ${CMAKE_SHLIB_LINK_FLAGS} "
- "${CMAKE_SHLIB_BUILD_FLAGS} ${CMAKE_CXXFLAGS} -o \\\n";
- fout << "\t " << m_LibraryOutputPath << "lib" << l->first << "$(SHLIB_SUFFIX) \\\n";
- fout << "\t ${" << l->first <<
- "_SRC_OBJS} ";
- this->OutputLinkLibraries(fout, l->first.c_str(), l->second);
- fout << "\n\n";
- }
- else if (l->second.GetType() == cmTarget::MODULE_LIBRARY)
- {
- fout << "#---------------------------------------------------------\n";
- fout << "# rules for a shared module library\n";
- fout << "#\n";
- fout << m_LibraryOutputPath << "lib" << l->first << "$(MODULE_SUFFIX): ${" <<
- l->first << "_SRC_OBJS} ${" << l->first << "_DEPEND_LIBS} \n";
- fout << "\trm -f lib" << l->first << "$(MODULE_SUFFIX)\n";
- fout << "\t$(CMAKE_CXX_COMPILER) ${CMAKE_MODULE_LINK_FLAGS} "
- "${CMAKE_MODULE_BUILD_FLAGS} ${CMAKE_CXXFLAGS} -o \\\n";
- fout << "\t " << m_LibraryOutputPath << "lib" << l->first << "$(MODULE_SUFFIX) \\\n";
- fout << "\t ${" << l->first <<
- "_SRC_OBJS} ";
- this->OutputLinkLibraries(fout, l->first.c_str(), l->second);
- fout << "\n\n";
- }
- else if ((l->second.GetType() == cmTarget::EXECUTABLE)
- || (l->second.GetType() == cmTarget::WIN32_EXECUTABLE))
- {
- fout << m_ExecutableOutputPath << l->first << ": ${" <<
- l->first << "_SRC_OBJS} ${" << l->first << "_DEPEND_LIBS}\n";
- fout << "\t${CMAKE_CXX_COMPILER} ${CMAKE_SHLIB_LINK_FLAGS} ${CMAKE_CXXFLAGS} "
- << "${" << l->first << "_SRC_OBJS} ";
- this->OutputLinkLibraries(fout, NULL,l->second);
- fout << " -o " << m_ExecutableOutputPath << l->first << "\n\n";
+ case cmTarget::STATIC_LIBRARY:
+ this->OutputStaticLibraryRule(fout, l->first.c_str(), l->second);
+ break;
+ case cmTarget::SHARED_LIBRARY:
+ this->OutputSharedLibraryRule(fout, l->first.c_str(), l->second);
+ break;
+ case cmTarget::MODULE_LIBRARY:
+ this->OutputModuleLibraryRule(fout, l->first.c_str(), l->second);
+ break;
+ case cmTarget::EXECUTABLE:
+ case cmTarget::WIN32_EXECUTABLE:
+ this->OutputExecutableRule(fout, l->first.c_str(), l->second);
+ break;
+
}
}
}
+
// For each target that is an executable or shared library, generate
// the "<name>_DEPEND_LIBS" variable listing its library dependencies.
void cmUnixMakefileGenerator::OutputDependLibs(std::ostream& fout)
@@ -768,9 +837,12 @@ void cmUnixMakefileGenerator::OutputMakeFlags(std::ostream& fout)
}
fout << m_Makefile->GetDefineFlags();
fout << "\n\n";
- fout << "default_target: all\n\n";
- // see if there are files to compile in this makefile
- // These are used for both libraries and executables
+ this->OutputMakeRule(fout,
+ "Default target executed when no arguments are given to make",
+ "default_target",
+ 0,
+ "${MAKE} -${MAKEFLAGS} cmake.depends",
+ "${MAKE} -${MAKEFLAGS} all");
}
@@ -1425,7 +1497,10 @@ void cmUnixMakefileGenerator::OutputMakeRule(std::ostream& fout,
const char* comment,
const char* target,
const char* depends,
- const char* command)
+ const char* command,
+ const char* command2,
+ const char* command3,
+ const char* command4)
{
if(!target)
{
@@ -1438,7 +1513,9 @@ void cmUnixMakefileGenerator::OutputMakeRule(std::ostream& fout,
{
replace = comment;
m_Makefile->ExpandVariablesInString(replace);
+ fout << "#---------------------------------------------------------\n";
fout << "# " << comment;
+ fout << "\n#\n";
}
fout << "\n";
replace = target;
@@ -1455,10 +1532,27 @@ void cmUnixMakefileGenerator::OutputMakeRule(std::ostream& fout,
{
replace = command;
m_Makefile->ExpandVariablesInString(replace);
- fout << "\t" << replace.c_str() << "\n\n";
+ fout << "\t" << replace.c_str() << "\n";
+ }
+ if(command2)
+ {
+ replace = command2;
+ m_Makefile->ExpandVariablesInString(replace);
+ fout << "\t" << replace.c_str() << "\n";
+ }
+ if(command3)
+ {
+ replace = command3;
+ m_Makefile->ExpandVariablesInString(replace);
+ fout << "\t" << replace.c_str() << "\n";
+ }
+ if(command4)
+ {
+ replace = command4;
+ m_Makefile->ExpandVariablesInString(replace);
+ fout << "\t" << replace.c_str() << "\n";
}
fout << "\n";
-
}
diff --git a/Source/cmUnixMakefileGenerator.h b/Source/cmUnixMakefileGenerator.h
index cce773a..db8369b 100644
--- a/Source/cmUnixMakefileGenerator.h
+++ b/Source/cmUnixMakefileGenerator.h
@@ -106,7 +106,13 @@ private:
void OutputMakefile(const char* file);
void OutputMakeFlags(std::ostream&);
void OutputTargetRules(std::ostream& fout);
- void OutputLinkLibraries(std::ostream&, const char*, const cmTarget &);
+ void OutputLinkLibraries(std::ostream&, const char* name, const cmTarget &);
+
+ void OutputSharedLibraryRule(std::ostream&, const char* name, const cmTarget &);
+ void OutputModuleLibraryRule(std::ostream&, const char* name, const cmTarget &);
+ void OutputStaticLibraryRule(std::ostream&, const char* name, const cmTarget &);
+ void OutputExecutableRule(std::ostream&, const char* name, const cmTarget &);
+
void OutputTargets(std::ostream&);
void OutputSubDirectoryRules(std::ostream&);
void OutputDependInformation(std::ostream&);
@@ -127,7 +133,10 @@ private:
const char* comment,
const char* target,
const char* depends,
- const char* command);
+ const char* command,
+ const char* command2 = 0,
+ const char* command3 = 0,
+ const char* command4 = 0);
private:
bool m_CacheOnly;
bool m_Recurse;