PStreams
|
Class template for Output PStreams. More...
#include <pstream.h>
Public Member Functions | |
basic_opstream () | |
Default constructor, creates an uninitialised stream. | |
basic_opstream (const std::string &cmd, pmode mode=pstdin) | |
Constructor that initialises the stream by starting a process. | |
basic_opstream (const std::string &file, const argv_type &argv, pmode mode=pstdin) | |
Constructor that initialises the stream by starting a process. | |
basic_opstream (const argv_type &argv, pmode mode=pstdin) | |
Constructor that initialises the stream by starting a process. | |
~basic_opstream () | |
Destructor. | |
void | open (const std::string &cmd, pmode mode=pstdin) |
Start a process. | |
void | open (const std::string &file, const argv_type &argv, pmode mode=pstdin) |
Start a process. | |
int | close () |
bool | is_open () const |
Report whether the stream's buffer has been initialised. | |
const std::string & | command () const |
Return the command used to initialise the stream. | |
streambuf_type * | rdbuf () const |
Return a pointer to the stream buffer. | |
Static Public Attributes | |
static const pmode | pstdin = std::ios_base::out |
Write to stdin. | |
static const pmode | pstdout = std::ios_base::in |
Read from stdout. | |
static const pmode | pstderr = std::ios_base::app |
Read from stderr. | |
static const pmode | newpg = std::ios_base::trunc |
Create a new process group for the child process. | |
static const pmode | pstdin = std::ios_base::out |
Write to stdin. | |
static const pmode | pstdout = std::ios_base::in |
Read from stdout. | |
static const pmode | pstderr = std::ios_base::app |
Read from stderr. | |
static const pmode | newpg = std::ios_base::trunc |
Create a new process group for the child process. | |
Protected Types | |
typedef basic_pstreambuf< CharT, Traits > | streambuf_type |
typedef std::basic_ios< CharT, Traits > | ios_type |
enum | { bufsz = 32 , pbsz = 2 } |
enum | { bufsz = 32 , pbsz = 2 } |
Protected Member Functions | |
void | do_open (const std::string &cmd, pmode mode) |
Start a process. | |
void | do_open (const std::string &file, const argv_type &argv, pmode mode) |
Start a process. | |
Protected Attributes | |
std::string | command_ |
The command used to start the process. | |
Related Symbols | |
(Note that these are not member symbols.) | |
template<typename C , typename T > | |
std::basic_ostream< C, T > & | peof (std::basic_ostream< C, T > &s) |
Manipulator to close the pipe connected to the process' stdin. | |
Class template for Output PStreams.
Writing to an open opstream writes to the standard input of the command; the command's standard output is the same as that of the process that created the pstream object, unless altered by the command itself.
|
protectedinherited |
|
protectedinherited |
|
inlineexplicit |
Constructor that initialises the stream by starting a process.
Initialises the stream buffer by calling do_open() with the supplied arguments.
cmd | a string containing a shell command. |
mode | the I/O mode to use when opening the pipe. |
|
inline |
Constructor that initialises the stream by starting a process.
Initialises the stream buffer by calling do_open() with the supplied arguments.
file | a string containing the pathname of a program to execute. |
argv | a vector of argument strings passed to the new program. |
mode | the I/O mode to use when opening the pipe. |
|
inlineexplicit |
Constructor that initialises the stream by starting a process.
Initialises the stream buffer by calling do_open
(argv[0],argv,mode|pstdin)
argv | a vector of argument strings passed to the new program. |
mode | the I/O mode to use when opening the pipe. |
|
inline |
Destructor.
Closes the stream and waits for the child to exit.
|
inlineinherited |
Close the pipe, returning the program's exit status, as pclose(3) does.
Calls rdbuf->close() and sets failbit
on error. Returns process's exit status, as pclose(3) does.
|
inlineinherited |
Return the command used to initialise the stream.
|
inlineprotectedinherited |
Start a process.
Calls rdbuf()->open( command , mode ) and sets failbit
on error.
cmd | a string containing a shell command. |
mode | the I/O mode to use when opening the pipe. |
Referenced by redi::basic_opstream< CharT, Traits >::open(), redi::basic_ipstream< CharT, Traits >::open(), redi::basic_pstream< CharT, Traits >::open(), redi::basic_rpstream< CharT, Traits >::open(), redi::basic_opstream< CharT, Traits >::open(), redi::basic_ipstream< CharT, Traits >::open(), redi::basic_pstream< CharT, Traits >::open(), redi::basic_rpstream< CharT, Traits >::open(), redi::pstream_common< CharT, Traits >::pstream_common(), and redi::pstream_common< CharT, Traits >::pstream_common().
|
inlineprotectedinherited |
Start a process.
Calls rdbuf()->open( file, argv, mode ) and sets failbit
on error.
file | a string containing the pathname of a program to execute. |
argv | a vector of argument strings passed to the new program. |
mode | the I/O mode to use when opening the pipe. |
|
inlineinherited |
Report whether the stream's buffer has been initialised.
|
inline |
Start a process.
Calls do_open( cmd , mode|pstdin ).
cmd | a string containing a shell command. |
mode | the I/O mode to use when opening the pipe. |
References redi::pstream_common< CharT, Traits >::do_open(), and redi::pstreams::pstdin.
|
inline |
Start a process.
Calls do_open( file , argv , mode|pstdin ).
file | a string containing the pathname of a program to execute. |
argv | a vector of argument strings passed to the new program. |
mode | the I/O mode to use when opening the pipe. |
References redi::pstream_common< CharT, Traits >::do_open(), and redi::pstreams::pstdin.
|
inlineinherited |
Return a pointer to the stream buffer.
|
related |
Manipulator to close the pipe connected to the process' stdin.
When inserted into an output pstream the manipulator calls basic_pstreambuf<C,T>::peof() to close the output pipe, causing the child process to receive the end-of-file indicator on subsequent reads from its stdin
stream.
s | An output PStream class. |
References redi::basic_pstreambuf< CharT, Traits >::peof().