summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2008-08-27 14:21:50 (GMT)
committerBrad King <brad.king@kitware.com>2008-08-27 14:21:50 (GMT)
commit012e4c4f68dc75002468cc043065c358bc12a7b5 (patch)
tree4dc5915f84f0373ff2e8f1709936dc5af2360bc3
parent32fe1d5b0d79ba4298c95e14f2815e61a05a0e38 (diff)
downloadCMake-012e4c4f68dc75002468cc043065c358bc12a7b5.zip
CMake-012e4c4f68dc75002468cc043065c358bc12a7b5.tar.gz
CMake-012e4c4f68dc75002468cc043065c358bc12a7b5.tar.bz2
BUG: Do not infer dependencies of link flags
In cmComputeLinkDepends link items that look like flags (starting in '-') should not be included in dependency inferral. They are not libraries and therefore have no dependencies. They should just be passed through to the final link line unchanged. See issue #7546.
-rw-r--r--Source/cmComputeLinkDepends.cxx13
-rw-r--r--Source/cmComputeLinkDepends.h6
2 files changed, 14 insertions, 5 deletions
diff --git a/Source/cmComputeLinkDepends.cxx b/Source/cmComputeLinkDepends.cxx
index e3ef604..d687d64 100644
--- a/Source/cmComputeLinkDepends.cxx
+++ b/Source/cmComputeLinkDepends.cxx
@@ -50,7 +50,9 @@ those without known dependencies. We will call the two types "known
items" and "unknown items", respecitvely. Known items are those whose
names correspond to targets (built or imported) and those for which an
old-style <item>_LIB_DEPENDS variable is defined. All other items are
-unknown and we must infer dependencies for them.
+unknown and we must infer dependencies for them. For items that look
+like flags (beginning with '-') we trivially infer no dependencies,
+and do not include them in the dependencies of other items.
Known items have dependency lists ordered based on how the user
specified them. We can use this order to infer potential dependencies
@@ -293,6 +295,7 @@ int cmComputeLinkDepends::AddLinkEntry(std::string const& item)
LinkEntry& entry = this->EntryList[index];
entry.Item = item;
entry.Target = this->FindTargetToLink(entry.Item.c_str());
+ entry.IsFlag = !entry.Target && item[0] == '-';
// If the item has dependencies queue it to follow them.
if(entry.Target)
@@ -312,7 +315,7 @@ int cmComputeLinkDepends::AddLinkEntry(std::string const& item)
BFSEntry qe = {index, val};
this->BFSQueue.push(qe);
}
- else
+ else if(!entry.IsFlag)
{
// The item dependencies are not known. We need to infer them.
this->InferredDependSets[index] = new DependSetList;
@@ -555,7 +558,10 @@ cmComputeLinkDepends::AddLinkEntries(int depender_index,
// The depender must come before the dependee.
if(depender_index >= 0)
{
- this->EntryConstraintGraph[dependee_index].push_back(depender_index);
+ if(!this->EntryList[dependee_index].IsFlag)
+ {
+ this->EntryConstraintGraph[dependee_index].push_back(depender_index);
+ }
}
else
{
@@ -572,6 +578,7 @@ cmComputeLinkDepends::AddLinkEntries(int depender_index,
// items are outside libraries that should not be depending on
// targets.
if(!this->EntryList[dependee_index].Target &&
+ !this->EntryList[dependee_index].IsFlag &&
dependee_index != dsi->first)
{
dsi->second.insert(dependee_index);
diff --git a/Source/cmComputeLinkDepends.h b/Source/cmComputeLinkDepends.h
index 5777110..b41da9e 100644
--- a/Source/cmComputeLinkDepends.h
+++ b/Source/cmComputeLinkDepends.h
@@ -46,9 +46,11 @@ public:
std::string Item;
cmTarget* Target;
bool IsSharedDep;
- LinkEntry(): Item(), Target(0), IsSharedDep(false) {}
+ bool IsFlag;
+ LinkEntry(): Item(), Target(0), IsSharedDep(false), IsFlag(false) {}
LinkEntry(LinkEntry const& r):
- Item(r.Item), Target(r.Target), IsSharedDep(r.IsSharedDep) {}
+ Item(r.Item), Target(r.Target), IsSharedDep(r.IsSharedDep),
+ IsFlag(r.IsFlag) {}
};
typedef std::vector<LinkEntry> EntryVector;