From 61d0a75d11c2ff93c972adeaa28a08f6314d5c07 Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Fri, 29 Apr 2005 11:49:18 -0400 Subject: [PATCH] ENH: Add option to ignore errors. Only works on make --- Source/cmGlobalGenerator.cxx | 19 ++++++++++--------- Source/cmGlobalGenerator.h | 2 +- Source/cmGlobalVisualStudio6Generator.cxx | 7 +++++-- Source/cmGlobalVisualStudio6Generator.h | 3 ++- Source/cmGlobalVisualStudio7Generator.cxx | 6 +++++- Source/cmGlobalVisualStudio7Generator.h | 3 ++- Source/cmGlobalXCodeGenerator.cxx | 3 ++- Source/cmGlobalXCodeGenerator.h | 3 ++- 8 files changed, 29 insertions(+), 17 deletions(-) diff --git a/Source/cmGlobalGenerator.cxx b/Source/cmGlobalGenerator.cxx index 17bfc0150..c473def81 100644 --- a/Source/cmGlobalGenerator.cxx +++ b/Source/cmGlobalGenerator.cxx @@ -651,7 +651,8 @@ int cmGlobalGenerator::TryCompile(const char *srcdir, const char *bindir, } std::string cmGlobalGenerator::GenerateBuildCommand(const char* makeProgram, - const char *projectName, const char *targetName, const char* config) + const char *projectName, const char *targetName, const char* config, + bool ignoreErrors) { // Project name and config are not used yet. (void)projectName; @@ -659,21 +660,21 @@ std::string cmGlobalGenerator::GenerateBuildCommand(const char* makeProgram, std::string makeCommand = makeProgram; makeCommand = cmSystemTools::ConvertToOutputPath(makeCommand.c_str()); - makeCommand += " "; // Since we have full control over the invocation of nmake, let us // make it quiet. if ( strcmp(this->GetName(), "NMake Makefiles") == 0 ) { - makeCommand += "/NOLOGO "; + makeCommand += " /NOLOGO "; + } + if ( ignoreErrors ) + { + makeCommand += " -i"; } if ( targetName ) { + makeCommand += " "; makeCommand += targetName; } - else - { - makeCommand += "all"; - } return makeCommand; } @@ -701,7 +702,7 @@ int cmGlobalGenerator::Build( // should we do a clean first? if (clean) { - std::string cleanCommand = this->GenerateBuildCommand(makeCommandCSTR, projectName, "clean", config); + std::string cleanCommand = this->GenerateBuildCommand(makeCommandCSTR, projectName, "clean", config, false); if (!cmSystemTools::RunSingleCommand(cleanCommand.c_str(), output, &retVal, 0, false, timeout)) { @@ -719,7 +720,7 @@ int cmGlobalGenerator::Build( } // now build - std::string makeCommand = this->GenerateBuildCommand(makeCommandCSTR, projectName, target, config); + std::string makeCommand = this->GenerateBuildCommand(makeCommandCSTR, projectName, target, config, false); if (!cmSystemTools::RunSingleCommand(makeCommand.c_str(), output, &retVal, 0, false, timeout)) diff --git a/Source/cmGlobalGenerator.h b/Source/cmGlobalGenerator.h index a4bd0baba..a250ab043 100644 --- a/Source/cmGlobalGenerator.h +++ b/Source/cmGlobalGenerator.h @@ -99,7 +99,7 @@ public: const char *makeProgram, const char *config, bool clean); virtual std::string GenerateBuildCommand(const char* makeProgram, const char *projectName, const char *targetName, - const char* config); + const char* config, bool ignoreErrors); ///! Set the CMake instance void SetCMakeInstance(cmake *cm) { diff --git a/Source/cmGlobalVisualStudio6Generator.cxx b/Source/cmGlobalVisualStudio6Generator.cxx index 6704c7312..79fd4fd77 100644 --- a/Source/cmGlobalVisualStudio6Generator.cxx +++ b/Source/cmGlobalVisualStudio6Generator.cxx @@ -67,9 +67,12 @@ void cmGlobalVisualStudio6Generator::GenerateConfigurations(cmMakefile* mf) } } -std::string cmGlobalVisualStudio6Generator::GenerateBuildCommand(const char* makeProgram, const char *projectName, const char *targetName, - const char* config) +std::string cmGlobalVisualStudio6Generator::GenerateBuildCommand(const char* makeProgram, + const char *projectName, const char *targetName, const char* config, bool ignoreErrors) { + // Ingoring errors is not implemented in visual studio 6 + (void) ignoreErrors; + // now build the test std::vector mp; mp.push_back("[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\VisualStudio\\6.0\\Setup;VsCommonDir]/MSDev98/Bin"); diff --git a/Source/cmGlobalVisualStudio6Generator.h b/Source/cmGlobalVisualStudio6Generator.h index 3f0841f14..0234ac74b 100644 --- a/Source/cmGlobalVisualStudio6Generator.h +++ b/Source/cmGlobalVisualStudio6Generator.h @@ -55,7 +55,8 @@ public: * loaded commands, not as part of the usual build process. */ virtual std::string GenerateBuildCommand(const char* makeProgram, - const char *projectName, const char *targetName, const char* config); + const char *projectName, const char *targetName, const char* config, + bool ignoreErrors); /** * Generate the all required files for building this project/tree. This diff --git a/Source/cmGlobalVisualStudio7Generator.cxx b/Source/cmGlobalVisualStudio7Generator.cxx index 7eb127272..336218809 100644 --- a/Source/cmGlobalVisualStudio7Generator.cxx +++ b/Source/cmGlobalVisualStudio7Generator.cxx @@ -43,8 +43,12 @@ void cmGlobalVisualStudio7Generator::EnableLanguage(std::vectorcons this->cmGlobalGenerator::EnableLanguage(lang, mf); } -std::string cmGlobalVisualStudio7Generator::GenerateBuildCommand(const char* makeProgram, const char *projectName, const char *targetName, const char* config) +std::string cmGlobalVisualStudio7Generator::GenerateBuildCommand(const char* makeProgram, + const char *projectName, const char *targetName, const char* config, bool ignoreErrors) { + // Ingoring errors is not implemented in visual studio 6 + (void) ignoreErrors; + // now build the test std::string makeCommand = cmSystemTools::ConvertToOutputPath(makeProgram); diff --git a/Source/cmGlobalVisualStudio7Generator.h b/Source/cmGlobalVisualStudio7Generator.h index f735dc749..63969715f 100644 --- a/Source/cmGlobalVisualStudio7Generator.h +++ b/Source/cmGlobalVisualStudio7Generator.h @@ -54,7 +54,8 @@ public: * loaded commands, not as part of the usual build process. */ virtual std::string GenerateBuildCommand(const char* makeProgram, - const char *projectName, const char *targetName, const char* config); + const char *projectName, const char *targetName, const char* config, + bool ignoreErrors); /** * Generate the all required files for building this project/tree. This diff --git a/Source/cmGlobalXCodeGenerator.cxx b/Source/cmGlobalXCodeGenerator.cxx index 1f17992cd..95df61120 100644 --- a/Source/cmGlobalXCodeGenerator.cxx +++ b/Source/cmGlobalXCodeGenerator.cxx @@ -52,7 +52,8 @@ void cmGlobalXCodeGenerator::EnableLanguage(std::vectorconst& //---------------------------------------------------------------------------- std::string cmGlobalXCodeGenerator::GenerateBuildCommand(const char* makeProgram, - const char *projectName, const char *targetName, const char* config) + const char *projectName, const char *targetName, const char* config, + bool ignoreErrors) { // Config is not used yet (void) config; diff --git a/Source/cmGlobalXCodeGenerator.h b/Source/cmGlobalXCodeGenerator.h index 85cbea0d5..c308a54b5 100644 --- a/Source/cmGlobalXCodeGenerator.h +++ b/Source/cmGlobalXCodeGenerator.h @@ -58,7 +58,8 @@ public: * loaded commands, not as part of the usual build process. */ virtual std::string GenerateBuildCommand(const char* makeProgram, - const char *projectName, const char *targetName, const char* config); + const char *projectName, const char *targetName, const char* config, + bool ignoreErrors); /** * Generate the all required files for building this project/tree. This