diff options
author | Brad King <brad.king@kitware.com> | 2004-10-27 12:47:49 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2004-10-27 12:47:49 (GMT) |
commit | 0d622ae9e82e286a23ab4fceb1c5f76d6f76b503 (patch) | |
tree | e7c09268aa18ec1724da85c0a6c8d4cbb61d85b9 /Source | |
parent | 414a2fd645867058ca50cc6a8eed260d13ad1749 (diff) | |
download | CMake-0d622ae9e82e286a23ab4fceb1c5f76d6f76b503.zip CMake-0d622ae9e82e286a23ab4fceb1c5f76d6f76b503.tar.gz CMake-0d622ae9e82e286a23ab4fceb1c5f76d6f76b503.tar.bz2 |
ENH: Added generation of rules for shared libraries and modules.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmLocalUnixMakefileGenerator2.cxx | 78 | ||||
-rw-r--r-- | Source/cmLocalUnixMakefileGenerator2.h | 10 |
2 files changed, 80 insertions, 8 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator2.cxx b/Source/cmLocalUnixMakefileGenerator2.cxx index 46cbf8f..04d98b1 100644 --- a/Source/cmLocalUnixMakefileGenerator2.cxx +++ b/Source/cmLocalUnixMakefileGenerator2.cxx @@ -367,6 +367,14 @@ cmLocalUnixMakefileGenerator2 this->WriteStaticLibraryRule(ruleFileStream, ruleFileName.c_str(), target, objects); break; + case cmTarget::SHARED_LIBRARY: + this->WriteSharedLibraryRule(ruleFileStream, ruleFileName.c_str(), + target, objects); + break; + case cmTarget::MODULE_LIBRARY: + this->WriteModuleLibraryRule(ruleFileStream, ruleFileName.c_str(), + target, objects); + break; case cmTarget::EXECUTABLE: this->WriteExecutableRule(ruleFileStream, ruleFileName.c_str(), target, objects); @@ -719,8 +727,68 @@ cmLocalUnixMakefileGenerator2 std::string linkRuleVar = "CMAKE_"; linkRuleVar += linkLanguage; linkRuleVar += "_CREATE_STATIC_LIBRARY"; + + std::string extraFlags; + this->AppendFlags(extraFlags, target.GetProperty("STATIC_LIBRARY_FLAGS")); this->WriteLibraryRule(ruleFileStream, ruleFileName, target, objects, - linkRuleVar.c_str(), "STATIC_LIBRARY_FLAGS"); + linkRuleVar.c_str(), extraFlags.c_str()); +} + +//---------------------------------------------------------------------------- +void +cmLocalUnixMakefileGenerator2 +::WriteSharedLibraryRule(std::ostream& ruleFileStream, + const char* ruleFileName, + const cmTarget& target, + std::vector<std::string>& objects) +{ + const char* linkLanguage = + target.GetLinkerLanguage(this->GetGlobalGenerator()); + std::string linkRuleVar = "CMAKE_"; + linkRuleVar += linkLanguage; + linkRuleVar += "_CREATE_SHARED_LIBRARY"; + + std::string extraFlags; + this->AppendFlags(extraFlags, target.GetProperty("LINK_FLAGS")); + this->AddConfigVariableFlags(extraFlags, "CMAKE_SHARED_LINKER_FLAGS"); + if(m_Makefile->IsOn("WIN32") && !(m_Makefile->IsOn("CYGWIN") || m_Makefile->IsOn("MINGW"))) + { + const std::vector<cmSourceFile*>& sources = target.GetSourceFiles(); + for(std::vector<cmSourceFile*>::const_iterator i = sources.begin(); + i != sources.end(); ++i) + { + if((*i)->GetSourceExtension() == "def") + { + extraFlags += " "; + extraFlags += m_Makefile->GetSafeDefinition("CMAKE_LINK_DEF_FILE_FLAG"); + extraFlags += this->ConvertToRelativeOutputPath((*i)->GetFullPath().c_str()); + } + } + } + this->WriteLibraryRule(ruleFileStream, ruleFileName, target, objects, + linkRuleVar.c_str(), extraFlags.c_str()); +} + +//---------------------------------------------------------------------------- +void +cmLocalUnixMakefileGenerator2 +::WriteModuleLibraryRule(std::ostream& ruleFileStream, + const char* ruleFileName, + const cmTarget& target, + std::vector<std::string>& objects) +{ + const char* linkLanguage = + target.GetLinkerLanguage(this->GetGlobalGenerator()); + std::string linkRuleVar = "CMAKE_"; + linkRuleVar += linkLanguage; + linkRuleVar += "_CREATE_SHARED_MODULE"; + + std::string extraFlags; + this->AppendFlags(extraFlags, target.GetProperty("LINK_FLAGS")); + this->AddConfigVariableFlags(extraFlags, "CMAKE_MODULE_LINKER_FLAGS"); + // TODO: Should .def files be supported here also? + this->WriteLibraryRule(ruleFileStream, ruleFileName, target, objects, + linkRuleVar.c_str(), extraFlags.c_str()); } //---------------------------------------------------------------------------- @@ -731,7 +799,7 @@ cmLocalUnixMakefileGenerator2 const cmTarget& target, std::vector<std::string>& objects, const char* linkRuleVar, - const char* flagsPropertyName) + const char* extraFlags) { std::vector<std::string> commands; @@ -747,11 +815,7 @@ cmLocalUnixMakefileGenerator2 const char* linkLanguage = target.GetLinkerLanguage(this->GetGlobalGenerator()); std::string linkFlags; - if(const char* targetLinkFlags = target.GetProperty(flagsPropertyName)) - { - linkFlags += " "; - linkFlags += targetLinkFlags; - } + this->AppendFlags(linkFlags, extraFlags); std::string targetName; std::string targetNameSO; std::string targetNameReal; diff --git a/Source/cmLocalUnixMakefileGenerator2.h b/Source/cmLocalUnixMakefileGenerator2.h index 5f3c89b..e269fe2 100644 --- a/Source/cmLocalUnixMakefileGenerator2.h +++ b/Source/cmLocalUnixMakefileGenerator2.h @@ -66,12 +66,20 @@ protected: const char* ruleFileName, const cmTarget& target, std::vector<std::string>& objects); + void WriteSharedLibraryRule(std::ostream& ruleFileStream, + const char* ruleFileName, + const cmTarget& target, + std::vector<std::string>& objects); + void WriteModuleLibraryRule(std::ostream& ruleFileStream, + const char* ruleFileName, + const cmTarget& target, + std::vector<std::string>& objects); void WriteLibraryRule(std::ostream& ruleFileStream, const char* ruleFileName, const cmTarget& target, std::vector<std::string>& objects, const char* linkRuleVar, - const char* flagsPropertyName); + const char* extraLinkFlags); std::string GetTargetDirectory(const cmTarget& target); std::string GetObjectFileName(const cmTarget& target, |