ENH: Added support for non-verbose mode output from running a command. This can be used when it is expected that the command may fail.

This commit is contained in:
Brad King 2001-07-23 11:53:52 -04:00
parent dc87e1906d
commit 572ecc9b8a
2 changed files with 24 additions and 10 deletions

View File

@ -805,7 +805,8 @@ bool cmSystemTools::IsOff(const char* val)
bool cmSystemTools::RunCommand(const char* command,
std::string& output)
std::string& output,
bool verbose)
{
const int BUFFER_SIZE = 4096;
char buffer[BUFFER_SIZE];
@ -819,6 +820,8 @@ bool cmSystemTools::RunCommand(const char* command,
system(commandToFile.c_str());
std::ifstream fin(tempFile.c_str());
if(!fin)
{
if(verbose)
{
std::string errormsg = "RunCommand produced no output: command: \"";
errormsg += command;
@ -826,6 +829,7 @@ bool cmSystemTools::RunCommand(const char* command,
errormsg += "\nOutput file: ";
errormsg += tempFile;
cmSystemTools::Error(errormsg.c_str());
}
fin.close();
cmSystemTools::RemoveFile(tempFile.c_str());
return false;
@ -839,7 +843,10 @@ bool cmSystemTools::RunCommand(const char* command,
cmSystemTools::RemoveFile(tempFile.c_str());
return true;
#else
if(verbose)
{
std::cout << "running " << command << std::endl;
}
FILE* cpipe = popen(command, "r");
if(!cpipe)
{
@ -847,8 +854,11 @@ bool cmSystemTools::RunCommand(const char* command,
}
fgets(buffer, BUFFER_SIZE, cpipe);
while(!feof(cpipe))
{
if(verbose)
{
std::cout << buffer << std::flush;
}
output += buffer;
fgets(buffer, BUFFER_SIZE, cpipe);
}

View File

@ -245,8 +245,12 @@ public:
* Run an executable command and put the stdout in output.
* A temporary file is created in the binaryDir for storing the
* output because windows does not have popen.
*
* If verbose is false, no user-viewable output from the program
* being run will be generated.
*/
static bool RunCommand(const char* command, std::string& output);
static bool RunCommand(const char* command, std::string& output,
bool verbose = true);
///! Generate a temporary file name
static std::string TemporaryFileName();