summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2002-12-11 19:15:35 (GMT)
committerBrad King <brad.king@kitware.com>2002-12-11 19:15:35 (GMT)
commit3bcbca96ab7424852e1cc4e15ef19174e40db224 (patch)
treed928862a6adb8a861348895c5ca73c8e94d28aec
parent682e2c7b8b614b595dcff32ffe24d67a5e26ff54 (diff)
downloadCMake-3bcbca96ab7424852e1cc4e15ef19174e40db224.zip
CMake-3bcbca96ab7424852e1cc4e15ef19174e40db224.tar.gz
CMake-3bcbca96ab7424852e1cc4e15ef19174e40db224.tar.bz2
ENH: Improved implementation of MSVC debug hook to only add the hook if DART_TEST_FROM_DART is set in the environment. This is better than always adding the hook and testing the environment from the callback.
-rw-r--r--Source/cmCreateTestSourceList.cxx17
-rw-r--r--Source/cmSystemTools.cxx12
2 files changed, 15 insertions, 14 deletions
diff --git a/Source/cmCreateTestSourceList.cxx b/Source/cmCreateTestSourceList.cxx
index 62286bc..5ed0f44 100644
--- a/Source/cmCreateTestSourceList.cxx
+++ b/Source/cmCreateTestSourceList.cxx
@@ -96,7 +96,8 @@ bool cmCreateTestSourceList::InitialPass(std::vector<std::string> const& argsIn)
"#include <ctype.h>\n"
"#include <stdio.h>\n"
"#include <string.h>\n"
- "#include <stdlib.h>\n";
+ "#include <stdlib.h>\n"
+ "\n";
fout <<
"#if defined(_MSC_VER) && defined(_DEBUG)\n"
"/* MSVC debug hook to prevent dialogs when running from DART. */\n"
@@ -104,11 +105,8 @@ bool cmCreateTestSourceList::InitialPass(std::vector<std::string> const& argsIn)
"static int TestDriverDebugReport(int type, char* message, int* retVal)\n"
"{\n"
" (void)type; (void)retVal;\n"
- " if(getenv(\"DART_TEST_FROM_DART\"))\n"
- " {\n"
- " fprintf(stderr, message);\n"
- " exit(1);\n"
- " }\n"
+ " fprintf(stderr, message);\n"
+ " exit(1);\n"
" return 0;\n"
"}\n"
"#endif\n";
@@ -221,8 +219,11 @@ bool cmCreateTestSourceList::InitialPass(std::vector<std::string> const& argsIn)
" char *arg, *test_name;\n"
" \n"
"#if defined(_MSC_VER) && defined(_DEBUG)\n"
- " /* Put in hook for debug library. */\n"
- " _CrtSetReportHook(TestDriverDebugReport);\n"
+ " /* If running from DART, put in debug hook. */\n"
+ " if(getenv(\"DART_TEST_FROM_DART\"))\n"
+ " {\n"
+ " _CrtSetReportHook(TestDriverDebugReport);\n"
+ " }\n"
"#endif\n"
" \n"
" NumTests = " << numTests << ";\n"
diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx
index 7750349..ff27805 100644
--- a/Source/cmSystemTools.cxx
+++ b/Source/cmSystemTools.cxx
@@ -2434,16 +2434,16 @@ void cmSystemTools::SplitProgramFromArgs(const char* path,
# include <stdlib.h>
static int cmSystemToolsDebugReport(int, char* message, int*)
{
- if(getenv("DART_TEST_FROM_DART"))
- {
- fprintf(stderr, message);
- exit(1);
- }
+ fprintf(stderr, message);
+ exit(1);
return 0;
}
void cmSystemTools::EnableMSVCDebugHook()
{
- _CrtSetReportHook(cmSystemToolsDebugReport);
+ if(getenv("DART_TEST_FROM_DART"))
+ {
+ _CrtSetReportHook(cmSystemToolsDebugReport);
+ }
}
#else
void cmSystemTools::EnableMSVCDebugHook()