From d6f98c2a82c693f9f96bd7c515fa4946a375f3ca Mon Sep 17 00:00:00 2001 From: Brad King Date: Wed, 11 Dec 2002 11:49:08 -0500 Subject: ENH: Added cmSystemTools::EnableMSVCDebugHook() to prevent error dialogs when CMake is invoked by Dart. --- Source/cmDumpDocumentation.cxx | 1 + Source/cmSystemTools.cxx | 23 +++++++++++++++++++++++ Source/cmSystemTools.h | 6 ++++++ Source/cmakemain.cxx | 1 + Source/cmaketest.cxx | 1 + Source/cmw9xcom.cxx | 1 + Source/ctest.cxx | 1 + 7 files changed, 34 insertions(+) diff --git a/Source/cmDumpDocumentation.cxx b/Source/cmDumpDocumentation.cxx index e920f96..18473b8 100644 --- a/Source/cmDumpDocumentation.cxx +++ b/Source/cmDumpDocumentation.cxx @@ -21,6 +21,7 @@ int main(int ac, char** av) { + cmSystemTools::EnableMSVCDebugHook(); cmake cmi; const char* outname = "cmake.html"; if(ac > 1) diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx index 40fafe2..7750349 100644 --- a/Source/cmSystemTools.cxx +++ b/Source/cmSystemTools.cxx @@ -2427,3 +2427,26 @@ void cmSystemTools::SplitProgramFromArgs(const char* path, program = ""; args = ""; } + +#if defined(_MSC_VER) && defined(_DEBUG) +# include +# include +# include +static int cmSystemToolsDebugReport(int, char* message, int*) +{ + if(getenv("DART_TEST_FROM_DART")) + { + fprintf(stderr, message); + exit(1); + } + return 0; +} +void cmSystemTools::EnableMSVCDebugHook() +{ + _CrtSetReportHook(cmSystemToolsDebugReport); +} +#else +void cmSystemTools::EnableMSVCDebugHook() +{ +} +#endif diff --git a/Source/cmSystemTools.h b/Source/cmSystemTools.h index 190ebdb..0e41691 100644 --- a/Source/cmSystemTools.h +++ b/Source/cmSystemTools.h @@ -356,6 +356,12 @@ public: */ static void SetRunCommandHideConsole(bool v){s_RunCommandHideConsole = v;} static bool GetRunCommandHideConsole(){ return s_RunCommandHideConsole;} + + /** When building DEBUG with MSVC, this enables a hook that prevents + * error dialogs from popping up if the program is being run from + * DART. + */ + static void EnableMSVCDebugHook(); protected: // these two functions can be called from ConvertToOutputPath /** diff --git a/Source/cmakemain.cxx b/Source/cmakemain.cxx index 2781f0b..96112bc 100644 --- a/Source/cmakemain.cxx +++ b/Source/cmakemain.cxx @@ -25,6 +25,7 @@ void updateProgress(const char *msg, float prog, void *cd); int main(int ac, char** av) { + cmSystemTools::EnableMSVCDebugHook(); int ret = do_cmake(ac, av); #ifdef CMAKE_BUILD_WITH_CMAKE cmDynamicLoader::FlushCache(); diff --git a/Source/cmaketest.cxx b/Source/cmaketest.cxx index e3c4039..efb312e 100644 --- a/Source/cmaketest.cxx +++ b/Source/cmaketest.cxx @@ -29,6 +29,7 @@ int do_cmaketest(int ac, char** av); int main(int ac, char** av) { + cmSystemTools::EnableMSVCDebugHook(); int ret = do_cmaketest(ac, av); #ifdef CMAKE_BUILD_WITH_CMAKE cmDynamicLoader::FlushCache(); diff --git a/Source/cmw9xcom.cxx b/Source/cmw9xcom.cxx index 33f474b..cb41719 100644 --- a/Source/cmw9xcom.cxx +++ b/Source/cmw9xcom.cxx @@ -20,6 +20,7 @@ // this is a test driver program for cmake. int main (int argc, char *argv[]) { + cmSystemTools::EnableMSVCDebugHook(); if ( argc <= 1 ) { std::cerr << "Usage: " << argv[0] << " executable" << std::endl; diff --git a/Source/ctest.cxx b/Source/ctest.cxx index 3dd6fd8..4fba9b1 100644 --- a/Source/ctest.cxx +++ b/Source/ctest.cxx @@ -1422,6 +1422,7 @@ int ctest::ProcessTests() // this is a test driver program for cmake. int main (int argc, char *argv[]) { + cmSystemTools::EnableMSVCDebugHook(); ctest inst; // look at the args -- cgit v0.12