other versions
- wheezy 3.01.00-1+b1
- jessie 3.23.01-1
- testing 4.04.00-1
- unstable 4.04.00-1
- experimental 4.07.00-1
other sections
FBB::Pipe(3bobcat) | Error handler | FBB::Pipe(3bobcat) |
NAME¶
FBB::Pipe - Defines a system level pipeSYNOPSIS¶
#include <bobcat/pipe>DESCRIPTION¶
FBB::Pipe objects may be used to construct a pipe. FBB::Pipe objects offer a simple interface to the reading and writing ends of pipes. FBB::Pipe objects are object-wrappers around the pipe(2) system call.NAMESPACE¶
FBBINHERITS FROM¶
-CONSTRUCTORS¶
- o
- Pipe():
- This constructor throws an Errno exception if the default Pipe constructor did not properly complete. The thrown Errno object’s which() member shows the system’s errno value set by the failing pipe(2) function.
- o
- Pipe(int const *fd):
MEMBER FUNCTIONS¶
- o
- int readFd() const:
- o
- void readFrom(int filedescriptor):
- o
- void readFrom(int const *filedescriptors, size_t n):
- o
- int readOnly():
- o
- void verify() const:
- o
- int writeFd() const:
- o
- void writtenBy(int filedescriptor):
- o
- void writtenBy(int const *filedescriptors, size_t
n):
- o
- int writeOnly():
PROTECTED ENUMERATION¶
The RW protected enumeration has the following elements:- o
- READ:
- o
- WRITE:
PROTECTED DATA¶
- o
- int d_fd[2]:
EXAMPLE¶
#include <bobcat/pipe> #include <sys/types.h> #include <sys/wait.h> #include <unistd.h> #include <iostream> #include <string> using namespace std; using namespace FBB; int main() { Pipe p; // construct a pipe cout << "Read file descriptor: " << p.getReadFd() << endl; cout << "Write file descriptor: " << p.getWriteFd() << endl; int pid = fork(); if (pid == -1) return 1; if (!pid) //child { p.readFrom(STDIN_FILENO); // read what goes into the pipe string s; getline(cin, s); cout << "CHILD: Got `" << s << "’" << endl; getline(cin, s); cout << "CHILD: Got `" << s << "’" << endl; return 0; } p.writtenBy(STDOUT_FILENO); // write to the pipe via cout cout << "first line" << endl; cout << "second line" << endl; waitpid(pid, 0, 0); return 0; }
FILES¶
bobcat/pipe - defines the class interfaceSEE ALSO¶
bobcat(7), pipe(2), mkfifo(3)BUGS¶
Note that when the pipe goes out of scope, no close(2) operation is performed on the pipe’s ends. If the pipe should be closed by the desctructor, derive a class from Pipe(3bobcat), whose destructor performs the required closing-operation.DISTRIBUTION FILES¶
- o
- bobcat_3.01.00-x.dsc: detached signature;
- o
- bobcat_3.01.00-x.tar.gz: source archive;
- o
- bobcat_3.01.00-x_i386.changes: change log;
- o
- libbobcat1_3.01.00-x_*.deb: debian package holding the libraries;
- o
- libbobcat1-dev_3.01.00-x_*.deb: debian package holding the libraries, headers and manual pages;
- o
- http://sourceforge.net/projects/bobcat: public
archive location;
BOBCAT¶
Bobcat is an acronym of `Brokken’s Own Base Classes And Templates’.COPYRIGHT¶
This is free software, distributed under the terms of the GNU General Public License (GPL).AUTHOR¶
Frank B. Brokken ( f.b.brokken@rug.nl).2005-2012 | libbobcat1-dev_3.01.00-x.tar.gz |