Download the PHP package thruster/stream without Composer
On this page you can find all versions of the php package thruster/stream. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download thruster/stream
More information about thruster/stream
Files in thruster/stream
Package stream
Short Description Thruster Steam Component
License MIT
Homepage https://thruster.io
Informations about the package stream
Stream Component
[] (https://github.com/ThrusterIO/stream/releases) [] (LICENSE) [] (https://travis-ci.org/ThrusterIO/stream) [] (https://scrutinizer-ci.com/g/ThrusterIO/stream) [] (https://scrutinizer-ci.com/g/ThrusterIO/stream) [] (https://packagist.org/packages/thruster/stream)
[] (mailto:[email protected])
The Thruster Stream Component.
Basic readable and writable stream interfaces that support piping.
In order to make the event loop easier to use, this component introduces the concept of streams. They are very similar to the streams found in PHP itself, but have an interface more suited for async I/O.
Mainly it provides interfaces for readable and writable streams, plus a file descriptor based implementation with an in-memory write buffer.
Install
Via Composer
Readable Streams
EventEmitter Events
data
: Emitted whenever data was read from the source.end
: Emitted when the source has reached theeof
.error
: Emitted when an error occurs.close
: Emitted when the connection is closed.
Methods
isReadable()
: Check if the stream is still in a state allowing it to be read from. It becomes unreadable when the connection ends, closes or an error occurs.pause()
: Remove the data source file descriptor from the event loop. This allows you to throttle incoming data.resume()
: Re-attach the data source after apause()
.pipe(WritableStreamInterface $dest, array $options = [])
: Pipe this readable stream into a writable stream. Automatically sends all incoming data to the destination. Automatically throttles based on what the destination can handle.
Writable Streams
EventEmitter Events
drain
: Emitted if the write buffer became full previously and is now ready to accept more data.error
: Emitted whenever an error occurs.close
: Emitted whenever the connection is closed.pipe
: Emitted whenever a readable stream ispipe()
d into this stream.
Methods
isWritable()
: Check if the stream can still be written to. It cannot be written to after an error or when it is closed.write($data)
: Write some data into the stream. If the stream cannot handle it, it should buffer the data or emit anderror
event. If the internal buffer is full after adding$data
,write
should return false, indicating that the caller should stop sending data until the bufferdrain
s.end($data = null)
: Optionally write some final data to the stream, empty the buffer, then close it.
Testing
Contributing
Please see CONDUCT for details.
License
Please see License File for more information.
All versions of stream with dependencies
thruster/promise Version ~1.0
thruster/event-loop Version ~1.0
thruster/event-emitter Version ~1.0