diff options
author | Boris Kolpackov <boris@codesynthesis.com> | 2015-06-18 11:37:25 +0200 |
---|---|---|
committer | Boris Kolpackov <boris@codesynthesis.com> | 2015-06-18 11:37:25 +0200 |
commit | 6144c196df4a38689cc027781c356219548a4a90 (patch) | |
tree | 46a7e6b2bc130217ceb325c5abc4369997fba81b /butl/process | |
parent | ad74bfab5650d2766a63ee661219e3413d7a62f8 (diff) |
Move process from build2 to libbutl
Diffstat (limited to 'butl/process')
-rw-r--r-- | butl/process | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/butl/process b/butl/process new file mode 100644 index 0000000..1d16285 --- /dev/null +++ b/butl/process @@ -0,0 +1,66 @@ +// file : butl/process -*- C++ -*- +// copyright : Copyright (c) 2014-2015 Code Synthesis Ltd +// license : MIT; see accompanying LICENSE file + +#ifndef BUTL_PROCESS +#define BUTL_PROCESS + +#ifndef _WIN32 +# include <sys/types.h> // pid_t +#endif + +#include <cassert> +#include <system_error> + +namespace butl +{ + struct process_error: std::system_error + { + process_error (int e, bool child) + : system_error (e, std::system_category ()), child_ (child) {} + + bool + child () const {return child_;} + + private: + bool child_; + }; + + struct process + { + // Start another process using the specified command line. Connect the + // newly created process' stdin to out_fd. Also if connect_* are true, + // connect the created process' stdout and stderr to in_*fd. Throw + // process_error if anything goes wrong. + // + // Note that some of the exceptions (e.g., if exec() failed) can be + // thrown in the child version of us. + // + process (char const* args[], + bool connect_stdin = false, + bool connect_stderr = false, + bool connect_stdout = false); + + // Wait for the process to terminate. Return true if the process + // terminated normally and with the zero exit status. Throw + // process_error if anything goes wrong. + // + bool + wait (); + + ~process () {assert (id == 0);} + +#ifndef _WIN32 + typedef pid_t id_type; +#else + typedef void* id_type; // Win32 HANDLE. +#endif + + id_type id; + int out_fd; // Write to this fd to send to the new process' stdin. + int in_efd; // Read from this fd to receive from the new process' stderr. + int in_ofd; // Read from this fd to receive from the new process' stdout. + }; +} + +#endif // BUTL_PROCESS |