summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2003-12-13 15:36:22 (GMT)
committerBrad King <brad.king@kitware.com>2003-12-13 15:36:22 (GMT)
commitdc96992e5680bad5d0ed226022f8d409269c6eae (patch)
tree491086155f8428596a009ee757e47df24dd978f6 /Source
parent128f3cbd00b6e2ebae663072837d6d4124659a96 (diff)
downloadCMake-dc96992e5680bad5d0ed226022f8d409269c6eae.zip
CMake-dc96992e5680bad5d0ed226022f8d409269c6eae.tar.gz
CMake-dc96992e5680bad5d0ed226022f8d409269c6eae.tar.bz2
ENH: Code is now robust to New method returning NULL.
Diffstat (limited to 'Source')
-rw-r--r--Source/kwsys/ProcessUNIX.c47
-rw-r--r--Source/kwsys/ProcessWin32.c56
2 files changed, 84 insertions, 19 deletions
diff --git a/Source/kwsys/ProcessUNIX.c b/Source/kwsys/ProcessUNIX.c
index cf0fb73..6888d59 100644
--- a/Source/kwsys/ProcessUNIX.c
+++ b/Source/kwsys/ProcessUNIX.c
@@ -183,6 +183,12 @@ kwsysProcess* kwsysProcess_New()
/*--------------------------------------------------------------------------*/
void kwsysProcess_Delete(kwsysProcess* cp)
{
+ /* Make sure we have an instance. */
+ if(!cp)
+ {
+ return;
+ }
+
/* If the process is executing, wait for it to finish. */
if(cp->State == kwsysProcess_State_Executing)
{
@@ -203,6 +209,10 @@ void kwsysProcess_Delete(kwsysProcess* cp)
int kwsysProcess_SetCommand(kwsysProcess* cp, char const* const* command)
{
int i;
+ if(!cp)
+ {
+ return 0;
+ }
for(i=0; i < cp->NumberOfCommands; ++i)
{
char** c = cp->Commands[i];
@@ -232,7 +242,7 @@ int kwsysProcess_AddCommand(kwsysProcess* cp, char const* const* command)
char*** newCommands;
/* Make sure we have a command to add. */
- if(!command)
+ if(!cp || !command)
{
return 0;
}
@@ -300,6 +310,10 @@ int kwsysProcess_AddCommand(kwsysProcess* cp, char const* const* command)
/*--------------------------------------------------------------------------*/
void kwsysProcess_SetTimeout(kwsysProcess* cp, double timeout)
{
+ if(!cp)
+ {
+ return;
+ }
cp->Timeout = timeout;
if(cp->Timeout < 0)
{
@@ -310,6 +324,10 @@ void kwsysProcess_SetTimeout(kwsysProcess* cp, double timeout)
/*--------------------------------------------------------------------------*/
void kwsysProcess_SetWorkingDirectory(kwsysProcess* cp, const char* dir)
{
+ if(!cp)
+ {
+ return;
+ }
if(cp->WorkingDirectory == dir)
{
return;
@@ -349,31 +367,35 @@ void kwsysProcess_SetOption(kwsysProcess* cp, int optionId, int value)
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetState(kwsysProcess* cp)
{
- return cp->State;
+ return cp? cp->State : kwsysProcess_State_Error;
}
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetExitException(kwsysProcess* cp)
{
- return cp->ExitException;
+ return cp? cp->ExitException : kwsysProcess_Exception_Other;
}
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetExitCode(kwsysProcess* cp)
{
- return cp->ExitCode;
+ return cp? cp->ExitCode : 0;
}
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetExitValue(kwsysProcess* cp)
{
- return cp->ExitValue;
+ return cp? cp->ExitValue : -1;
}
/*--------------------------------------------------------------------------*/
const char* kwsysProcess_GetErrorString(kwsysProcess* cp)
{
- if(cp->State == kwsysProcess_State_Error)
+ if(!cp)
+ {
+ return "Process management structure could not be allocated.";
+ }
+ else if(cp->State == kwsysProcess_State_Error)
{
return cp->ErrorMessage;
}
@@ -388,7 +410,7 @@ void kwsysProcess_Execute(kwsysProcess* cp)
kwsysProcessCreateInformation si = {-1, -1, -1, -1, {-1, -1}};
/* Do not execute a second copy simultaneously. */
- if(cp->State == kwsysProcess_State_Executing)
+ if(!cp || cp->State == kwsysProcess_State_Executing)
{
return;
}
@@ -500,6 +522,13 @@ int kwsysProcess_WaitForData(kwsysProcess* cp, char** data, int* length,
int pipeId = kwsysProcess_Pipe_None;
int numReady = 0;
+ /* Make sure we are executing a process. */
+ if(!cp || cp->State != kwsysProcess_State_Executing || cp->Killed ||
+ cp->TimeoutExpired)
+ {
+ return kwsysProcess_Pipe_None;
+ }
+
/* Record the time at which user timeout period starts. */
if(userTimeout)
{
@@ -687,7 +716,7 @@ int kwsysProcess_WaitForExit(kwsysProcess* cp, double* userTimeout)
int pipe = 0;
/* Make sure we are executing a process. */
- if(cp->State != kwsysProcess_State_Executing)
+ if(!cp || cp->State != kwsysProcess_State_Executing)
{
return 1;
}
@@ -804,7 +833,7 @@ void kwsysProcess_Kill(kwsysProcess* cp)
int i;
/* Make sure we are executing a process. */
- if(cp->State != kwsysProcess_State_Executing)
+ if(!cp || cp->State != kwsysProcess_State_Executing)
{
return;
}
diff --git a/Source/kwsys/ProcessWin32.c b/Source/kwsys/ProcessWin32.c
index 07a7855..6563fc9 100644
--- a/Source/kwsys/ProcessWin32.c
+++ b/Source/kwsys/ProcessWin32.c
@@ -406,6 +406,12 @@ void kwsysProcess_Delete(kwsysProcess* cp)
{
int i;
+ /* Make sure we have an instance. */
+ if(!cp)
+ {
+ return;
+ }
+
/* If the process is executing, wait for it to finish. */
if(cp->State == kwsysProcess_State_Executing)
{
@@ -466,6 +472,10 @@ void kwsysProcess_Delete(kwsysProcess* cp)
int kwsysProcess_SetCommand(kwsysProcess* cp, char const* const* command)
{
int i;
+ if(!cp)
+ {
+ return 0;
+ }
for(i=0; i < cp->NumberOfCommands; ++i)
{
free(cp->Commands[i]);
@@ -490,7 +500,7 @@ int kwsysProcess_AddCommand(kwsysProcess* cp, char const* const* command)
char** newCommands;
/* Make sure we have a command to add. */
- if(!command)
+ if(!cp || !command)
{
return 0;
}
@@ -693,12 +703,24 @@ int kwsysProcess_AddCommand(kwsysProcess* cp, char const* const* command)
/*--------------------------------------------------------------------------*/
void kwsysProcess_SetTimeout(kwsysProcess* cp, double timeout)
{
+ if(!cp)
+ {
+ return;
+ }
cp->Timeout = timeout;
+ if(cp->Timeout < 0)
+ {
+ cp->Timeout = 0;
+ }
}
/*--------------------------------------------------------------------------*/
void kwsysProcess_SetWorkingDirectory(kwsysProcess* cp, const char* dir)
{
+ if(!cp)
+ {
+ return;
+ }
if(cp->WorkingDirectory)
{
free(cp->WorkingDirectory);
@@ -723,6 +745,11 @@ void kwsysProcess_SetWorkingDirectory(kwsysProcess* cp, const char* dir)
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetOption(kwsysProcess* cp, int optionId)
{
+ if(!cp)
+ {
+ return 0;
+ }
+
switch(optionId)
{
case kwsysProcess_Option_HideWindow: return cp->HideWindow;
@@ -733,6 +760,11 @@ int kwsysProcess_GetOption(kwsysProcess* cp, int optionId)
/*--------------------------------------------------------------------------*/
void kwsysProcess_SetOption(kwsysProcess* cp, int optionId, int value)
{
+ if(!cp)
+ {
+ return;
+ }
+
switch(optionId)
{
case kwsysProcess_Option_HideWindow: cp->HideWindow = value; break;
@@ -743,31 +775,35 @@ void kwsysProcess_SetOption(kwsysProcess* cp, int optionId, int value)
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetState(kwsysProcess* cp)
{
- return cp->State;
+ return cp? cp->State : kwsysProcess_State_Error;
}
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetExitException(kwsysProcess* cp)
{
- return cp->ExitException;
+ return cp? cp->ExitException : kwsysProcess_Exception_Other;
}
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetExitValue(kwsysProcess* cp)
{
- return cp->ExitValue;
+ return cp? cp->ExitValue : -1;
}
/*--------------------------------------------------------------------------*/
int kwsysProcess_GetExitCode(kwsysProcess* cp)
{
- return cp->ExitCode;
+ return cp? cp->ExitCode : 0;
}
/*--------------------------------------------------------------------------*/
const char* kwsysProcess_GetErrorString(kwsysProcess* cp)
{
- if(cp->State == kwsysProcess_State_Error)
+ if(!cp)
+ {
+ return "Process management structure could not be allocated.";
+ }
+ else if(cp->State == kwsysProcess_State_Error)
{
return cp->ErrorMessage;
}
@@ -783,7 +819,7 @@ void kwsysProcess_Execute(kwsysProcess* cp)
kwsysProcessCreateInformation si;
/* Do not execute a second time. */
- if(cp->State == kwsysProcess_State_Executing)
+ if(!cp || cp->State == kwsysProcess_State_Executing)
{
return;
}
@@ -935,7 +971,7 @@ int kwsysProcess_WaitForData(kwsysProcess* cp, char** data, int* length,
DWORD w;
/* Make sure we are executing a process. */
- if(cp->State != kwsysProcess_State_Executing || cp->Killed ||
+ if(!cp || cp->State != kwsysProcess_State_Executing || cp->Killed ||
cp->TimeoutExpired)
{
return kwsysProcess_Pipe_None;
@@ -1070,7 +1106,7 @@ int kwsysProcess_WaitForExit(kwsysProcess* cp, double* userTimeout)
int pipe;
/* Make sure we are executing a process. */
- if(cp->State != kwsysProcess_State_Executing)
+ if(!cp || cp->State != kwsysProcess_State_Executing)
{
return 1;
}
@@ -1174,7 +1210,7 @@ void kwsysProcess_Kill(kwsysProcess* cp)
int i;
/* Make sure we are executing a process. */
- if(cp->State != kwsysProcess_State_Executing || cp->TimeoutExpired ||
+ if(!cp || cp->State != kwsysProcess_State_Executing || cp->TimeoutExpired ||
cp->Killed || cp->Terminated)
{
return;