aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2004-12-19 17:59:57 +0000
committerReid Spencer <rspencer@reidspencer.com>2004-12-19 17:59:57 +0000
commit7eae81d4da604521bdea953285bdfa1e8bc4d110 (patch)
treea8525a6f79035bf65e06b0ff9f48679c36296fce
parent2418bf9546387ea0cd206d3f0e4a8952f6a90eb4 (diff)
downloadexternal_llvm-7eae81d4da604521bdea953285bdfa1e8bc4d110.zip
external_llvm-7eae81d4da604521bdea953285bdfa1e8bc4d110.tar.gz
external_llvm-7eae81d4da604521bdea953285bdfa1e8bc4d110.tar.bz2
For PR351:
Incorporate the abilities of RunPRogramWithTimeout into sys::Program::ExecuteAndWait so that redirection and a timeout are optionally supported. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19039 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/llvm/System/Program.h19
1 files changed, 15 insertions, 4 deletions
diff --git a/include/llvm/System/Program.h b/include/llvm/System/Program.h
index 45fb950..6528d68 100644
--- a/include/llvm/System/Program.h
+++ b/include/llvm/System/Program.h
@@ -56,15 +56,26 @@ namespace sys {
/// @brief Executes the program with the given set of \p args.
static int ExecuteAndWait(
const Path& path, ///< The path to the program to execute
- const std::vector<std::string>& args,
+ const char** args,
///< A vector of strings that are passed to the program.
- ///< The first element should *not* be the name of the program.
- const char ** env = 0
+ ///< The first element should be the name of the program. The list
+ ///< *must* be terminated by a null char* entry.
+ const char ** env = 0,
///< An optional vector of strings to use for the program's
///< environment. If not provided, the current program's environment
///< will be used.
+ const sys::Path** redirects = 0,
+ ///< An optional array of pointers to Paths. If the array is null,
+ ///< no redirection is done. The array should have a size of at least
+ ///< three. If the pointer in the array are not null, then the
+ ///< inferior process's stdin(0), stdout(1), and stderr(2) will be
+ ///< redirected to the corresponding Paths.
+ unsigned secondsToWait = 0
+ ///< If non-zero, this specifies the amount of time to wait for the
+ ///< child process to exit. If the time expires, the child is killed
+ ///< and this call returns. If zero, this function will wait until
+ ///< the child finishes or forever if it doesn't.
);
- /// @}
};
}
}