diff options
author | Brad King <brad.king@kitware.com> | 2003-07-14 14:33:09 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2003-07-14 14:33:09 (GMT) |
commit | 53510fa6034234ab65b20a15f29f6f8e4625318a (patch) | |
tree | a7908e6afa4cbeb4dedf1df82d3dd94c4335af1f /Source | |
parent | af8c7e76165daf80f757cb72486456a5ae74f1ab (diff) | |
download | CMake-53510fa6034234ab65b20a15f29f6f8e4625318a.zip CMake-53510fa6034234ab65b20a15f29f6f8e4625318a.tar.gz CMake-53510fa6034234ab65b20a15f29f6f8e4625318a.tar.bz2 |
BUG: Custom commands should have variables expanded before comparing with previously added custom commands.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmMakefile.cxx | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index e963f9f..0e9534a 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -520,7 +520,7 @@ void cmMakefile::AddCustomCommand(const char* source, void cmMakefile:: AddCustomCommandToOutput(const char* output, - const char* command, + const char* inCommand, const std::vector<std::string>& commandArgs, const char *main_dependency, const std::vector<std::string>& depends, @@ -529,6 +529,12 @@ AddCustomCommandToOutput(const char* output, { std::string expandC; std::string combinedArgs; + std::string command = inCommand; + + // process the command's string + this->ExpandVariablesInString(command); + command = cmSystemTools::EscapeSpaces(command.c_str()); + unsigned int i; for (i = 0; i < commandArgs.size(); ++i) { @@ -563,7 +569,7 @@ AddCustomCommandToOutput(const char* output, // if the command and args are the same // as the command already there, then silently skip // this add command - if(cc->IsEquivalent(command, combinedArgs.c_str())) + if(cc->IsEquivalent(command.c_str(), combinedArgs.c_str())) { return; } @@ -585,7 +591,7 @@ AddCustomCommandToOutput(const char* output, // if the command and args are the same // as the command already there, then silently skip // this add command - if(cc->IsEquivalent(command, combinedArgs.c_str())) + if(cc->IsEquivalent(command.c_str(), combinedArgs.c_str())) { return; } @@ -605,19 +611,13 @@ AddCustomCommandToOutput(const char* output, cmSourceFile *out = this->GetOrCreateSource(output, true); out->SetProperty("GENERATED","1"); - // process the command - expandC = command; - this->ExpandVariablesInString(expandC); - std::string c = cmSystemTools::EscapeSpaces(expandC.c_str()); - - std::vector<std::string> depends2(depends); if (main_dependency && main_dependency[0] != '\0') { depends2.push_back(mainDepend.c_str()); } cmCustomCommand *cc = - new cmCustomCommand(c.c_str(),combinedArgs.c_str(),depends2, output); + new cmCustomCommand(command.c_str(),combinedArgs.c_str(),depends2, output); if ( comment && comment[0] ) { cc->SetComment(comment); |