summaryrefslogtreecommitdiffstats
path: root/Source/cmLocalUnixMakefileGenerator3.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2005-11-17 18:49:10 (GMT)
committerBrad King <brad.king@kitware.com>2005-11-17 18:49:10 (GMT)
commit70b4e1051e04be892c86aa3ff729d63ccf1f7771 (patch)
tree780b663a4c900e576b798b4be894372420d12f99 /Source/cmLocalUnixMakefileGenerator3.cxx
parent6ce463dab36091ce77f5b2cb614478d5ab049fe5 (diff)
downloadCMake-70b4e1051e04be892c86aa3ff729d63ccf1f7771.zip
CMake-70b4e1051e04be892c86aa3ff729d63ccf1f7771.tar.gz
CMake-70b4e1051e04be892c86aa3ff729d63ccf1f7771.tar.bz2
BUG: Fixed support for external object files built by custom commands. Also added a test to keep it working.
Diffstat (limited to 'Source/cmLocalUnixMakefileGenerator3.cxx')
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.cxx19
1 files changed, 17 insertions, 2 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx
index 54f063b..c89c587 100644
--- a/Source/cmLocalUnixMakefileGenerator3.cxx
+++ b/Source/cmLocalUnixMakefileGenerator3.cxx
@@ -398,6 +398,13 @@ cmLocalUnixMakefileGenerator3
// This is an external object file. Just add it.
external_objects.push_back((*source)->GetFullPath());
}
+ else
+ {
+ // We only get here if a source file is not an external object
+ // and has an extension that is listed as an ignored file type
+ // for this language. No message or diagnosis should be
+ // given.
+ }
}
}
@@ -1283,6 +1290,14 @@ cmLocalUnixMakefileGenerator3
// Add a dependency on the rule file itself.
this->AppendRuleDepend(depends, ruleFileName);
+ for(std::vector<std::string>::const_iterator obj = external_objects.begin();
+ obj != external_objects.end(); ++obj)
+ {
+ depends.push_back(*obj);
+ }
+
+ // from here up is the same for exe or lib
+
// Get the name of the executable to generate.
std::string targetName;
std::string targetNameReal;
@@ -1602,14 +1617,14 @@ cmLocalUnixMakefileGenerator3
// Add a dependency on the rule file itself.
this->AppendRuleDepend(depends, ruleFileName);
- // from here up is the same for exe or lib
-
for(std::vector<std::string>::const_iterator obj = external_objects.begin();
obj != external_objects.end(); ++obj)
{
depends.push_back(*obj);
}
+ // from here up is the same for exe or lib
+
// Get the language to use for linking this library.
const char* linkLanguage =
target.GetLinkerLanguage(this->GetGlobalGenerator());