diff options
author | Brad King <brad.king@kitware.com> | 2005-11-17 18:49:10 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2005-11-17 18:49:10 (GMT) |
commit | 70b4e1051e04be892c86aa3ff729d63ccf1f7771 (patch) | |
tree | 780b663a4c900e576b798b4be894372420d12f99 /Source/cmLocalUnixMakefileGenerator3.cxx | |
parent | 6ce463dab36091ce77f5b2cb614478d5ab049fe5 (diff) | |
download | CMake-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.cxx | 19 |
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()); |