summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
Diffstat (limited to 'Source')
-rw-r--r--Source/cmcldeps.cxx25
1 files changed, 8 insertions, 17 deletions
diff --git a/Source/cmcldeps.cxx b/Source/cmcldeps.cxx
index 39f696f..ce64132 100644
--- a/Source/cmcldeps.cxx
+++ b/Source/cmcldeps.cxx
@@ -178,11 +178,9 @@ static int process( const std::string& srcfilename,
bool quiet = false)
{
std::string output;
- int ret = 0;
// break up command line into a vector
std::vector<std::string> args;
- cmSystemTools::ParseWindowsCommandLine(cmd.c_str(),
- args);
+ cmSystemTools::ParseWindowsCommandLine(cmd.c_str(), args);
// convert to correct vector type for RunSingleCommand
std::vector<cmStdString> command;
for(std::vector<std::string>::iterator i = args.begin();
@@ -191,14 +189,10 @@ static int process( const std::string& srcfilename,
command.push_back(i->c_str());
}
// run the command
- bool success =
- cmSystemTools::RunSingleCommand(command, &output, &ret, dir.c_str(),
- cmSystemTools::OUTPUT_NONE);
- if(ret!= 0)
- {
- return 2;
- }
- int exit_code = ret;
+ int exit_code = 0;
+ bool run = cmSystemTools::RunSingleCommand(command, &output, &exit_code,
+ dir.c_str(), cmSystemTools::OUTPUT_NONE);
+
// process the include directives and output everything else
std::stringstream ss(output);
std::string line;
@@ -221,14 +215,11 @@ static int process( const std::string& srcfilename,
}
}
- if (!success) {
- return exit_code;
- }
-
// don't update .d until/unless we succeed compilation
- outputDepFile(dfile, objfile, includes);
+ if (run && exit_code == 0)
+ outputDepFile(dfile, objfile, includes);
- return 0;
+ return exit_code;
}