summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2003-08-13 22:08:07 (GMT)
committerBrad King <brad.king@kitware.com>2003-08-13 22:08:07 (GMT)
commitbeda09a96b2139a5e22f7f78c4cdff7783669d99 (patch)
treead92cf82689e709df5d3556832f9ffe23a797a86
parentef603d12f9429db1dec870cb37073a83037e33e6 (diff)
downloadCMake-beda09a96b2139a5e22f7f78c4cdff7783669d99.zip
CMake-beda09a96b2139a5e22f7f78c4cdff7783669d99.tar.gz
CMake-beda09a96b2139a5e22f7f78c4cdff7783669d99.tar.bz2
ENH: Made error message consistent between win9x and non-win9x version of error reporting.
-rw-r--r--Source/kwsys/ProcessWin32.c60
1 files changed, 35 insertions, 25 deletions
diff --git a/Source/kwsys/ProcessWin32.c b/Source/kwsys/ProcessWin32.c
index 35fce7d..2070203 100644
--- a/Source/kwsys/ProcessWin32.c
+++ b/Source/kwsys/ProcessWin32.c
@@ -70,6 +70,7 @@ static DWORD WINAPI kwsysProcessPipeThread(LPVOID ptd);
static void kwsysProcessPipeThreadReadPipe(kwsysProcess* cp, kwsysProcessPipeData* td);
static void kwsysProcessCleanupHandle(PHANDLE h);
static void kwsysProcessCleanup(kwsysProcess* cp, int error);
+static void kwsysProcessCleanErrorMessage(kwsysProcess* cp);
static int kwsysProcessGetTimeoutTime(kwsysProcess* cp, double* userTimeout,
kwsysProcessTime* timeoutTime);
static int kwsysProcessGetTimeoutLeft(kwsysProcessTime* timeoutTime,
@@ -1050,8 +1051,12 @@ int kwsysProcess_WaitForExit(kwsysProcess* cp, double* userTimeout)
}
else if(cp->ErrorMessageLength)
{
- /* Failed to run the process. */
+ /* The Win9x forwarding executing repored data on the special
+ error pipe. Failed to run the process. */
cp->State = kwsysProcess_State_Error;
+
+ /* Remove trailing period and newline from message, if any. */
+ kwsysProcessCleanErrorMessage(cp);
}
else if(cp->TimeoutExpired)
{
@@ -1111,7 +1116,7 @@ int kwsysProcess_WaitForExit(kwsysProcess* cp, double* userTimeout)
else
{
/* Error getting the child return code. */
- strcpy(cp->ErrorMessage, "Error getting child return code.");
+ strcpy(cp->ErrorMessage, "Error getting child return code");
cp->State = kwsysProcess_State_Error;
}
@@ -1261,37 +1266,20 @@ void kwsysProcessCleanup(kwsysProcess* cp, int error)
FORMAT_MESSAGE_IGNORE_INSERTS, 0, original,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
cp->ErrorMessage, CMPE_PIPE_BUFFER_SIZE, 0);
-
- if(length > 0)
- {
- /* Remove trailing period and newline, if any. */
- if(cp->ErrorMessage[length-1] == '\n')
- {
- cp->ErrorMessage[length-1] = 0;
- --length;
- if(length > 0 && cp->ErrorMessage[length-1] == '\r')
- {
- cp->ErrorMessage[length-1] = 0;
- --length;
- }
- }
- if(cp->ErrorMessage[length-1] == '.')
- {
- cp->ErrorMessage[length-1] = 0;
- --length;
- }
- }
- else
+ if(length < 1)
{
/* FormatMessage failed. Use a default message. */
_snprintf(cp->ErrorMessage, CMPE_PIPE_BUFFER_SIZE,
"Process execution failed with error 0x%X. "
- "FormatMessage failed with error 0x%X.",
+ "FormatMessage failed with error 0x%X",
original, GetLastError());
}
-
+
/* Set the error state. */
cp->State = kwsysProcess_State_Error;
+
+ /* Remove trailing period and newline, if any. */
+ kwsysProcessCleanErrorMessage(cp);
}
/* Free memory. */
@@ -1310,6 +1298,28 @@ void kwsysProcessCleanup(kwsysProcess* cp, int error)
}
/*--------------------------------------------------------------------------*/
+void kwsysProcessCleanErrorMessage(kwsysProcess* cp)
+{
+ /* Remove trailing period and newline, if any. */
+ int length = strlen(cp->ErrorMessage);
+ if(cp->ErrorMessage[length-1] == '\n')
+ {
+ cp->ErrorMessage[length-1] = 0;
+ --length;
+ if(length > 0 && cp->ErrorMessage[length-1] == '\r')
+ {
+ cp->ErrorMessage[length-1] = 0;
+ --length;
+ }
+ }
+ if(length > 0 && cp->ErrorMessage[length-1] == '.')
+ {
+ cp->ErrorMessage[length-1] = 0;
+ --length;
+ }
+}
+
+/*--------------------------------------------------------------------------*/
/* Get the time at which either the process or user timeout will
expire. Returns 1 if the user timeout is first, and 0 otherwise. */
int kwsysProcessGetTimeoutTime(kwsysProcess* cp, double* userTimeout,