summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2003-07-14 14:33:09 (GMT)
committerBrad King <brad.king@kitware.com>2003-07-14 14:33:09 (GMT)
commit53510fa6034234ab65b20a15f29f6f8e4625318a (patch)
treea7908e6afa4cbeb4dedf1df82d3dd94c4335af1f /Source
parentaf8c7e76165daf80f757cb72486456a5ae74f1ab (diff)
downloadCMake-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.cxx20
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);