From 9f7e27fc3a2d2b1863147f235a2980de019ee7c9 Mon Sep 17 00:00:00 2001 From: Brad King Date: Wed, 30 Jul 2014 11:14:17 -0400 Subject: De-duplicate shared library targets in generated link lines The linker will bring in shared libraries as a whole and use them even for symbols that are needed by entries later in the link line. Therefore we do not need to repeat them. De-duplicate link entries that we know are shared libraries because we have a cmTarget associated with them. Tested-by: Jean-Christophe Fillion-Robin --- Source/cmComputeLinkDepends.cxx | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/Source/cmComputeLinkDepends.cxx b/Source/cmComputeLinkDepends.cxx index c13da50..b13a125 100644 --- a/Source/cmComputeLinkDepends.cxx +++ b/Source/cmComputeLinkDepends.cxx @@ -166,7 +166,8 @@ guaranteed to be acyclic. The final list of items produced by this procedure consists of the original user link line followed by minimal additional items needed to -satisfy dependencies. +satisfy dependencies. The final list is then filtered to de-duplicate +items that we know the linker will re-use automatically (shared libs). */ @@ -262,10 +263,20 @@ cmComputeLinkDepends::Compute() this->OrderLinkEntires(); // Compute the final set of link entries. + std::set emmitted; for(std::vector::const_iterator li = this->FinalLinkOrder.begin(); li != this->FinalLinkOrder.end(); ++li) { - this->FinalLinkEntries.push_back(this->EntryList[*li]); + int i = *li; + LinkEntry const& e = this->EntryList[i]; + cmTarget const* t = e.Target; + // Entries that we know the linker will re-use for symbols + // needed by later entries do not need to be repeated. + bool uniquify = t && t->GetType() == cmTarget::SHARED_LIBRARY; + if(!uniquify || emmitted.insert(i).second) + { + this->FinalLinkEntries.push_back(e); + } } // Display the final set. -- cgit v0.12 From ccec6df85f604429a905d664d8a6e8c9e0d835e1 Mon Sep 17 00:00:00 2001 From: Brad King Date: Wed, 30 Jul 2014 11:41:05 -0400 Subject: Help: Add notes for topic 'link-line-dedup' --- Help/release/dev/link-line-dedup.rst | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 Help/release/dev/link-line-dedup.rst diff --git a/Help/release/dev/link-line-dedup.rst b/Help/release/dev/link-line-dedup.rst new file mode 100644 index 0000000..6ce31e3 --- /dev/null +++ b/Help/release/dev/link-line-dedup.rst @@ -0,0 +1,5 @@ +link-line-dedup +--------------- + +* When generating linker command-lines, CMake now avoids repeating + items corresponding to SHARED library targets. -- cgit v0.12