This class is not intended to be instantiated directly, please see StreamPipe.
More...
This class is not intended to be instantiated directly, please see StreamPipe.
- Note
- stream classes are not designed to be accessed from multiple threads; they have been implemented without locking for fast and efficient use when used from a single thread. For methods that would be unsafe to use in another thread, any use of such methods in threads other than the thread where the constructor was called will cause a
STREAM-THREAD-ERROR
to be thrown, unless the stream is handed off to another thread using the StreamBase::unassignThread() method in the thread that currently owns the stream, and the StreamBase::reassignThread() method in the new thread.
- See also
-
- Since
- Qore 0.8.13
◆ close()
nothing Qore::PipeOutputStream::close |
( |
| ) |
|
|
virtual |
Closes the output stream and releases any resources.
- Exceptions
-
OUTPUT-STREAM-CLOSED-ERROR | the output stream has already been closed |
STREAM-THREAD-ERROR | this exception is thrown if this method is called from any thread other than the thread that created the object |
Implements Qore::OutputStream.
◆ reportError()
nothing Qore::PipeOutputStream::reportError |
( |
hash |
ex | ) |
|
Causes all operations on both pipe streams to wake up and throw an exception.
Normally used from the background thread to report an error to the main thread.
- Parameters
-
ex | the exception, must contain strings 'err' and 'desc' |
◆ write()
nothing Qore::PipeOutputStream::write |
( |
binary |
data | ) |
|
|
virtual |
Writes bytes to the output stream.
- Exceptions
-
OUTPUT-STREAM-CLOSED-ERROR | the output stream has already been closed |
STREAM-THREAD-ERROR | this exception is thrown if this method is called from any thread other than the thread that created the object |
Implements Qore::OutputStream.