diff options
author | Brad King <brad.king@kitware.com> | 2007-03-09 16:29:15 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2007-03-09 16:29:15 (GMT) |
commit | 31637efbfb958bd5f43bee5c870c501f09e76bdf (patch) | |
tree | 9a09045b4822ffcb871b19f20d34171e7329d90f /Source/cmMakefileTargetGenerator.cxx | |
parent | fb88335cdbbcaca92e228f6bd0b6dbdc83b03806 (diff) | |
download | CMake-31637efbfb958bd5f43bee5c870c501f09e76bdf.zip CMake-31637efbfb958bd5f43bee5c870c501f09e76bdf.tar.gz CMake-31637efbfb958bd5f43bee5c870c501f09e76bdf.tar.bz2 |
ENH: Added cmMakefileTargetGenerator::GenerateExtraOutput to wrap up creation of rules to drive creation of extra outputs generated as side effects of another rule. Reimplemented generation of custom command multiple output rules to use it. Reimplemented soname symlink output dependencies to use it. Now if a symlink is deleted the library will be recreated with the symlink.
Diffstat (limited to 'Source/cmMakefileTargetGenerator.cxx')
-rw-r--r-- | Source/cmMakefileTargetGenerator.cxx | 48 |
1 files changed, 29 insertions, 19 deletions
diff --git a/Source/cmMakefileTargetGenerator.cxx b/Source/cmMakefileTargetGenerator.cxx index 8adcc9b..1f6fe63 100644 --- a/Source/cmMakefileTargetGenerator.cxx +++ b/Source/cmMakefileTargetGenerator.cxx @@ -903,20 +903,8 @@ void cmMakefileTargetGenerator symbolic); } - // If the rule has multiple outputs, add a rule for the extra - // outputs to just depend on the first output with no command. Also - // register the extra outputs as paired with the first output so - // that the check-build-system step will remove the primary output - // if any extra outputs are missing, forcing the rule to regenerate - // all outputs. - depends.clear(); - depends.push_back(*o); - commands.clear(); - std::string emptyCommand = this->GlobalGenerator->GetEmptyCommandHack(); - if(!emptyCommand.empty()) - { - commands.push_back(emptyCommand); - } + // Write rules to drive building any outputs beyond the first. + const char* in = o->c_str(); for(++o; o != outputs.end(); ++o) { bool symbolic = false; @@ -927,12 +915,34 @@ void cmMakefileTargetGenerator symbolic = sf->GetPropertyAsBool("SYMBOLIC"); } } - this->LocalGenerator->WriteMakeRule(*this->BuildFileStream, 0, - o->c_str(), depends, commands, - symbolic); - this->GlobalGenerator->AddMultipleOutputPair(o->c_str(), - depends[0].c_str()); + this->GenerateExtraOutput(o->c_str(), in, symbolic); + } +} + +//---------------------------------------------------------------------------- +void +cmMakefileTargetGenerator +::GenerateExtraOutput(const char* out, const char* in, bool symbolic) +{ + // Add a rule to build the primary output if the extra output needs + // to be created. + std::vector<std::string> commands; + std::vector<std::string> depends; + std::string emptyCommand = this->GlobalGenerator->GetEmptyCommandHack(); + if(!emptyCommand.empty()) + { + commands.push_back(emptyCommand); } + depends.push_back(in); + this->LocalGenerator->WriteMakeRule(*this->BuildFileStream, 0, + out, depends, commands, + symbolic); + + // Register the extra output as paired with the first output so that + // the check-build-system step will remove the primary output if any + // extra outputs are missing. This forces the rule to regenerate + // all outputs. + this->GlobalGenerator->AddMultipleOutputPair(out, in); } //---------------------------------------------------------------------------- |