TwiceAsNice
2019-02-18
|
Class template for Bidirectional PStreams. More...
#include <PStream.h>
Public Types | |
typedef pbase_type::pmode | pmode |
Type used to specify how to connect to the process. More... | |
typedef pbase_type::argv_type | argv_type |
Type used to hold the arguments for a command. More... | |
typedef pbase_type::pmode | pmode |
Type used to specify how to connect to the process. More... | |
typedef pbase_type::argv_type | argv_type |
Type used to hold the arguments for a command. More... | |
![]() | |
typedef std::ios_base::openmode | pmode |
Type used to specify how to connect to the process. More... | |
typedef std::vector< std::string > | argv_type |
Type used to hold the arguments for a command. More... | |
typedef int | fd_type |
Type used for file descriptors. More... | |
typedef std::ios_base::openmode | pmode |
Type used to specify how to connect to the process. More... | |
typedef std::vector< std::string > | argv_type |
Type used to hold the arguments for a command. More... | |
typedef int | fd_type |
Type used for file descriptors. More... | |
Public Member Functions | |
basic_pstream () | |
Default constructor, creates an uninitialised stream. More... | |
basic_pstream (const std::string &command, pmode mode=pstdout|pstdin) | |
Constructor that initialises the stream by starting a process. More... | |
basic_pstream (const std::string &file, const argv_type &argv, pmode mode=pstdout|pstdin) | |
Constructor that initialises the stream by starting a process. More... | |
~basic_pstream () | |
Destructor. More... | |
void | open (const std::string &command, pmode mode=pstdout|pstdin) |
Start a process. More... | |
void | open (const std::string &file, const argv_type &argv, pmode mode=pstdout|pstdin) |
Start a process. More... | |
basic_pstream & | out () |
Set streambuf to read from process' stdout . More... | |
basic_pstream & | err () |
Set streambuf to read from process' stderr . More... | |
basic_pstream () | |
Default constructor, creates an uninitialised stream. More... | |
basic_pstream (const std::string &command, pmode mode=pstdout|pstdin) | |
Constructor that initialises the stream by starting a process. More... | |
basic_pstream (const std::string &file, const argv_type &argv, pmode mode=pstdout|pstdin) | |
Constructor that initialises the stream by starting a process. More... | |
~basic_pstream () | |
Destructor. More... | |
void | open (const std::string &command, pmode mode=pstdout|pstdin) |
Start a process. More... | |
void | open (const std::string &file, const argv_type &argv, pmode mode=pstdout|pstdin) |
Start a process. More... | |
basic_pstream & | out () |
Set streambuf to read from process' stdout . More... | |
basic_pstream & | err () |
Set streambuf to read from process' stderr . More... | |
![]() | |
void | close () |
Close the pipe. More... | |
bool | is_open () const |
Report whether the stream's buffer has been initialised. More... | |
const std::string & | command () const |
Return the command used to initialise the stream. More... | |
streambuf_type * | rdbuf () const |
Return a pointer to the stream buffer. More... | |
void | close () |
Close the pipe. More... | |
bool | is_open () const |
Report whether the stream's buffer has been initialised. More... | |
const std::string & | command () const |
Return the command used to initialise the stream. More... | |
streambuf_type * | rdbuf () const |
Return a pointer to the stream buffer. More... | |
Private Types | |
typedef std::basic_iostream< CharT, Traits > | iostream_type |
typedef pstream_common< CharT, Traits > | pbase_type |
typedef std::basic_iostream< CharT, Traits > | iostream_type |
typedef pstream_common< CharT, Traits > | pbase_type |
Private Attributes | |
streambuf_type | buf_ |
The stream buffer. More... | |
streambuf_type | buf_ |
The stream buffer. More... | |
Additional Inherited Members | |
![]() | |
static const pmode | pstdin = std::ios_base::out |
Write to stdin. More... | |
static const pmode | pstdout = std::ios_base::in |
Read from stdout. More... | |
static const pmode | pstderr = std::ios_base::app |
Read from stderr. More... | |
![]() | |
typedef basic_pstreambuf< CharT, Traits > | streambuf_type |
typedef basic_pstreambuf< CharT, Traits > | streambuf_type |
![]() | |
enum | { bufsz = 32 } |
enum | { pbsz = 2 } |
enum | { bufsz = 32 } |
enum | { pbsz = 2 } |
![]() | |
pstream_common () | |
Default constructor. More... | |
pstream_common (const std::string &command, pmode mode) | |
Constructor that initialises the stream by starting a process. More... | |
pstream_common (const std::string &file, const argv_type &argv, pmode mode) | |
Constructor that initialises the stream by starting a process. More... | |
virtual | ~pstream_common ()=0 |
Pure virtual destructor. More... | |
void | do_open (const std::string &command, pmode mode) |
Start a process. More... | |
void | do_open (const std::string &file, const argv_type &argv, pmode mode) |
Start a process. More... | |
pstream_common () | |
Default constructor. More... | |
pstream_common (const std::string &command, pmode mode) | |
Constructor that initialises the stream by starting a process. More... | |
pstream_common (const std::string &file, const argv_type &argv, pmode mode) | |
Constructor that initialises the stream by starting a process. More... | |
virtual | ~pstream_common ()=0 |
Pure virtual destructor. More... | |
void | do_open (const std::string &command, pmode mode) |
Start a process. More... | |
void | do_open (const std::string &file, const argv_type &argv, pmode mode) |
Start a process. More... | |
![]() | |
std::string | command_ |
The command used to start the process. More... | |
streambuf_type | buf_ |
The stream buffer. More... | |
Class template for Bidirectional PStreams.
Writing to a pstream opened with pmode
pstdin
writes to the standard input of the command. Reading from a pstream opened with pmode
pstdout
and/or pstderr
reads the command's standard output and/or standard error. Any of the process' stdin
, stdout
or stderr
that is not connected to the pstream (as specified by the pmode
) will be the same as the process that created the pstream object, unless altered by the command itself.
typedef pbase_type::argv_type Nice::basic_pstream< CharT, Traits >::argv_type |
Type used to hold the arguments for a command.
typedef pbase_type::argv_type Nice::basic_pstream< CharT, Traits >::argv_type |
Type used to hold the arguments for a command.
|
private |
|
private |
|
private |
|
private |
typedef pbase_type::pmode Nice::basic_pstream< CharT, Traits >::pmode |
Type used to specify how to connect to the process.
typedef pbase_type::pmode Nice::basic_pstream< CharT, Traits >::pmode |
Type used to specify how to connect to the process.
|
inline |
Default constructor, creates an uninitialised stream.
|
inline |
Constructor that initialises the stream by starting a process.
Initialises the stream buffer by calling do_open() with the supplied arguments.
command | 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. |
|
inline |
Destructor.
Closes the stream and waits for the child to exit.
|
inline |
Default constructor, creates an uninitialised stream.
|
inline |
Constructor that initialises the stream by starting a process.
Initialises the stream buffer by calling do_open() with the supplied arguments.
command | 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. |
|
inline |
Destructor.
Closes the stream and waits for the child to exit.
|
inline |
Set streambuf to read from process' stderr
.
*this
|
inline |
Set streambuf to read from process' stderr
.
*this
|
inline |
Start a process.
Calls do_open( command , mode ).
command | a string containing a shell command. |
mode | the I/O mode to use when opening the pipe. |
|
inline |
Start a process.
Calls do_open( command , mode ).
command | a string containing a shell command. |
mode | the I/O mode to use when opening the pipe. |
|
inline |
Start a process.
Calls do_open( file , argv , mode ).
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. |
|
inline |
Start a process.
Calls do_open( file , argv , mode ).
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. |
|
inline |
Set streambuf to read from process' stdout
.
*this
|
inline |
Set streambuf to read from process' stdout
.
*this
|
private |
The stream buffer.
|
private |
The stream buffer.