Documentation

FnStream
in package
implements StreamInterface

Compose stream implementations based on a hash of functions.

Allows for easy testing and extension of a provided stream without needing to create a concrete class for a simple extension point.

Tags
final

Interfaces, Classes and Traits

StreamInterface
Describes a data stream.

Table of Contents

$methods  : array<string|int, mixed>
$slots  : array<string|int, mixed>
__construct()  : mixed
__destruct()  : mixed
The close method is called on the underlying stream only if possible.
__get()  : mixed
Lazily determine which methods are not implemented.
__toString()  : string
Reads all data from the stream into a string, from the beginning to end.
__wakeup()  : mixed
An unserialize would allow the __destruct to run when the unserialized value goes out of scope.
close()  : void
Closes the stream and any underlying resources.
decorate()  : FnStream
Adds custom functionality to an underlying stream by intercepting specific method calls.
detach()  : resource|null
Separates any underlying resources from the stream.
eof()  : bool
Returns true if the stream is at the end of the stream.
getContents()  : string
Returns the remaining contents in a string
getMetadata()  : array<string|int, mixed>|mixed|null
Get stream metadata as an associative array or retrieve a specific key.
getSize()  : int|null
Get the size of the stream if known.
isReadable()  : bool
Returns whether or not the stream is readable.
isSeekable()  : bool
Returns whether or not the stream is seekable.
isWritable()  : bool
Returns whether or not the stream is writable.
read()  : string
Read data from the stream.
rewind()  : mixed
Seek to the beginning of the stream.
seek()  : mixed
Seek to a position in the stream.
tell()  : int
Returns the current position of the file read/write pointer
write()  : int
Write data to the stream.

Properties

$methods

private array<string|int, mixed> $methods

$slots

private static array<string|int, mixed> $slots = ['__toString', 'close', 'detach', 'rewind', 'getSize', 'tell', 'eof', 'isSeekable', 'seek', 'isWritable', 'write', 'isReadable', 'read', 'getContents', 'getMetadata']

Methods

__construct()

public __construct(array<string|int, mixed> $methods) : mixed
Parameters
$methods : array<string|int, mixed>

Hash of method name to a callable.

Return values
mixed

__destruct()

The close method is called on the underlying stream only if possible.

public __destruct() : mixed
Return values
mixed

__get()

Lazily determine which methods are not implemented.

public __get(mixed $name) : mixed
Parameters
$name : mixed
Tags
throws
BadMethodCallException
Return values
mixed

__toString()

Reads all data from the stream into a string, from the beginning to end.

public __toString() : string

This method MUST attempt to seek to the beginning of the stream before reading data and read the stream until the end is reached.

Warning: This could attempt to load a large amount of data into memory.

This method MUST NOT raise an exception in order to conform with PHP's string casting operations.

Return values
string

__wakeup()

An unserialize would allow the __destruct to run when the unserialized value goes out of scope.

public __wakeup() : mixed
Tags
throws
LogicException
Return values
mixed

close()

Closes the stream and any underlying resources.

public close() : void
Return values
void

decorate()

Adds custom functionality to an underlying stream by intercepting specific method calls.

public static decorate(StreamInterface $stream, array<string|int, mixed> $methods) : FnStream
Parameters
$stream : StreamInterface

Stream to decorate

$methods : array<string|int, mixed>

Hash of method name to a closure

Return values
FnStream

detach()

Separates any underlying resources from the stream.

public detach() : resource|null

After the stream has been detached, the stream is in an unusable state.

Return values
resource|null

Underlying PHP stream, if any

eof()

Returns true if the stream is at the end of the stream.

public eof() : bool
Return values
bool

getContents()

Returns the remaining contents in a string

public getContents() : string
Return values
string

getMetadata()

Get stream metadata as an associative array or retrieve a specific key.

public getMetadata([mixed $key = null ]) : array<string|int, mixed>|mixed|null

The keys returned are identical to the keys returned from PHP's stream_get_meta_data() function.

Parameters
$key : mixed = null

Specific metadata to retrieve.

Return values
array<string|int, mixed>|mixed|null

Returns an associative array if no key is provided. Returns a specific key value if a key is provided and the value is found, or null if the key is not found.

getSize()

Get the size of the stream if known.

public getSize() : int|null
Return values
int|null

Returns the size in bytes if known, or null if unknown.

isReadable()

Returns whether or not the stream is readable.

public isReadable() : bool
Return values
bool

isSeekable()

Returns whether or not the stream is seekable.

public isSeekable() : bool
Return values
bool

isWritable()

Returns whether or not the stream is writable.

public isWritable() : bool
Return values
bool

read()

Read data from the stream.

public read(mixed $length) : string
Parameters
$length : mixed

Read up to $length bytes from the object and return them. Fewer than $length bytes may be returned if underlying stream call returns fewer bytes.

Return values
string

Returns the data read from the stream, or an empty string if no bytes are available.

rewind()

Seek to the beginning of the stream.

public rewind() : mixed

If the stream is not seekable, this method will raise an exception; otherwise, it will perform a seek(0).

Return values
mixed

seek()

Seek to a position in the stream.

public seek(mixed $offset[, mixed $whence = SEEK_SET ]) : mixed
Parameters
$offset : mixed

Stream offset

$whence : mixed = SEEK_SET

Specifies how the cursor position will be calculated based on the seek offset. Valid values are identical to the built-in PHP $whence values for fseek(). SEEK_SET: Set position equal to offset bytes SEEK_CUR: Set position to current location plus offset SEEK_END: Set position to end-of-stream plus offset.

Return values
mixed

tell()

Returns the current position of the file read/write pointer

public tell() : int
Return values
int

Position of the file pointer

write()

Write data to the stream.

public write(mixed $string) : int
Parameters
$string : mixed

The string that is to be written.

Return values
int

Returns the number of bytes written to the stream.

Search results