2003-09-30 18:37:50 +00:00
|
|
|
//===- SystemUtils.h - Utilities to do low-level system stuff ---*- C++ -*-===//
|
2003-10-20 19:46:57 +00:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file was developed by the LLVM research group and is distributed under
|
|
|
|
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2002-12-23 23:50:16 +00:00
|
|
|
//
|
|
|
|
// This file contains functions used to do a variety of low-level, often
|
|
|
|
// system-specific, tasks.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2004-09-01 22:55:40 +00:00
|
|
|
#ifndef LLVM_SUPPORT_SYSTEMUTILS_H
|
|
|
|
#define LLVM_SUPPORT_SYSTEMUTILS_H
|
2002-12-23 23:50:16 +00:00
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
2003-11-11 22:41:34 +00:00
|
|
|
namespace llvm {
|
|
|
|
|
2002-12-23 23:50:16 +00:00
|
|
|
/// isExecutableFile - This function returns true if the filename specified
|
|
|
|
/// exists and is executable.
|
|
|
|
///
|
|
|
|
bool isExecutableFile(const std::string &ExeFileName);
|
|
|
|
|
2004-04-02 05:04:12 +00:00
|
|
|
/// isStandardOutAConsole - Return true if we can tell that the standard output
|
|
|
|
/// stream goes to a terminal window or console.
|
|
|
|
bool isStandardOutAConsole();
|
|
|
|
|
2003-08-07 21:33:33 +00:00
|
|
|
/// FindExecutable - Find a named executable, giving the argv[0] of program
|
|
|
|
/// being executed. This allows us to find another LLVM tool if it is built into
|
|
|
|
/// the same directory, but that directory is neither the current directory, nor
|
|
|
|
/// in the PATH. If the executable cannot be found, return an empty string.
|
|
|
|
///
|
2002-12-23 23:50:16 +00:00
|
|
|
std::string FindExecutable(const std::string &ExeName,
|
2003-09-29 22:37:57 +00:00
|
|
|
const std::string &ProgramPath);
|
2002-12-23 23:50:16 +00:00
|
|
|
|
|
|
|
/// RunProgramWithTimeout - This function executes the specified program, with
|
|
|
|
/// the specified null-terminated argument array, with the stdin/out/err fd's
|
2004-07-24 07:41:31 +00:00
|
|
|
/// redirected, with a timeout specified by the last argument. This terminates
|
2002-12-23 23:50:16 +00:00
|
|
|
/// the calling program if there is an error executing the specified program.
|
|
|
|
/// It returns the return value of the program, or -1 if a timeout is detected.
|
|
|
|
///
|
|
|
|
int RunProgramWithTimeout(const std::string &ProgramPath, const char **Args,
|
2003-09-29 22:37:57 +00:00
|
|
|
const std::string &StdInFile = "",
|
|
|
|
const std::string &StdOutFile = "",
|
2004-07-24 07:41:31 +00:00
|
|
|
const std::string &StdErrFile = "",
|
|
|
|
unsigned NumSeconds = 0);
|
2002-12-23 23:50:16 +00:00
|
|
|
|
2003-09-29 22:37:57 +00:00
|
|
|
/// ExecWait - Execute a program with the given arguments and environment and
|
|
|
|
/// wait for it to terminate.
|
2003-09-17 15:14:25 +00:00
|
|
|
///
|
2003-09-17 19:02:49 +00:00
|
|
|
int ExecWait (const char * const argv[], const char * const envp[]);
|
2003-11-11 22:41:34 +00:00
|
|
|
|
|
|
|
} // End llvm namespace
|
|
|
|
|
2002-12-23 23:50:16 +00:00
|
|
|
#endif
|