summaryrefslogtreecommitdiffstats
path: root/Source/cmTarget.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-07-30 14:59:37 (GMT)
committerBrad King <brad.king@kitware.com>2009-07-30 14:59:37 (GMT)
commitfcab87c9f802965318bee033c2fa3ff27cfbfec7 (patch)
tree75000cee15b4ecd1c233c7c7c259fa15bffb6994 /Source/cmTarget.cxx
parentfd633b33cff397b110cc69f82fd522cdf905952a (diff)
downloadCMake-fcab87c9f802965318bee033c2fa3ff27cfbfec7.zip
CMake-fcab87c9f802965318bee033c2fa3ff27cfbfec7.tar.gz
CMake-fcab87c9f802965318bee033c2fa3ff27cfbfec7.tar.bz2
Do not always propagate linker language preference
The commit "Consider link dependencies for link language" taught CMake to propagate linker language preference from languages compiled into libraries linked by a target. It turns out this should only be done for some languages, such as C++, because normally the language of the program entry point (main) should be used. We introduce variable CMAKE_<LANG>_LINKER_PREFERENCE_PROPAGATES to tell CMake whether a language should propagate its linker preference across targets. Currently it is true only for C++.
Diffstat (limited to 'Source/cmTarget.cxx')
-rw-r--r--Source/cmTarget.cxx33
1 files changed, 22 insertions, 11 deletions
diff --git a/Source/cmTarget.cxx b/Source/cmTarget.cxx
index 52dbb56..8fdb16a 100644
--- a/Source/cmTarget.cxx
+++ b/Source/cmTarget.cxx
@@ -441,18 +441,15 @@ void cmTarget::DefineProperties(cmake *cm)
cm->DefineProperty
("LINKER_LANGUAGE", cmProperty::TARGET,
- "Specifies language whose link tool should be used (obselete).",
+ "Specifies language whose compiler will invoke the linker.",
"For executables, shared libraries, and modules, this sets the "
- "language whose link tool is used to link the target "
+ "language whose compiler is used to link the target "
"(such as \"C\" or \"CXX\"). "
- "CMake 2.6 and below select a linker language automatically "
- "based on the languages compiled into the target. "
- "This property overrides the default in case one of the "
- "linked libraries uses another language. "
- "A typical example is a C executable linking to a static archive "
- "containing C++ object files. "
- "CMake 2.8 and above account for languages in linked targets "
- "automatically, making this property unnecessary.");
+ "A typical value for an executable is the language of the source "
+ "file providing the program entry point (main). "
+ "If not set, the language with the highest linker preference "
+ "value is the default. "
+ "See documentation of CMAKE_<LANG>_LINKER_PREFERENCE variables.");
cm->DefineProperty
("LOCATION", cmProperty::TARGET,
@@ -2506,11 +2503,25 @@ void cmTarget::ComputeLinkClosure(const char* config, LinkClosure& lc)
{
// Find the language with the highest preference value.
cmTargetSelectLinker tsl(this);
+
+ // First select from the languages compiled directly in this target.
+ for(std::vector<std::string>::const_iterator li = impl->Languages.begin();
+ li != impl->Languages.end(); ++li)
+ {
+ tsl.Consider(li->c_str());
+ }
+
+ // Now consider languages that propagate from linked targets.
for(std::set<cmStdString>::const_iterator sit = languages.begin();
sit != languages.end(); ++sit)
{
- tsl.Consider(sit->c_str());
+ std::string propagates = "CMAKE_"+*sit+"_LINKER_PREFERENCE_PROPAGATES";
+ if(this->Makefile->IsOn(propagates.c_str()))
+ {
+ tsl.Consider(sit->c_str());
+ }
}
+
lc.LinkerLanguage = tsl.Choose();
}
}