[llvm-commits] CVS: llvm/include/llvm/System/Program.h

Reid Spencer reid at x10sys.com
Sun Dec 19 10:00:08 PST 2004



Changes in directory llvm/include/llvm/System:

Program.h updated: 1.3 -> 1.4
---
Log message:

For PR351: http://llvm.cs.uiuc.edu/PR351 :
Incorporate the abilities of RunPRogramWithTimeout into 
sys::Program::ExecuteAndWait so that redirection and a timeout are optionally 
supported.

---
Diffs of the changes:  (+15 -4)

Index: llvm/include/llvm/System/Program.h
diff -u llvm/include/llvm/System/Program.h:1.3 llvm/include/llvm/System/Program.h:1.4
--- llvm/include/llvm/System/Program.h:1.3	Mon Dec 13 22:17:12 2004
+++ llvm/include/llvm/System/Program.h	Sun Dec 19 11:59:57 2004
@@ -56,15 +56,26 @@
       /// @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.
       );
-    /// @}
   };
 }
 }






More information about the llvm-commits mailing list