diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2001-11-01 23:37:28 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2001-11-01 23:37:28 (GMT) |
commit | c15ad5c98d7b527622a0f1ddbaaad6ffaf08d94a (patch) | |
tree | 544b487f9739b69b4e608866428f58fbf2125df2 | |
parent | a13cb203ad1e12850bc0ee2df6fd61b5f813543c (diff) | |
download | CMake-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.cxx | 214 | ||||
-rw-r--r-- | Source/cmUnixMakefileGenerator.h | 13 |
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; |