| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- <?php
- namespace GuzzleHttp\Stream;
- /**
- * Describes a stream instance.
- */
- interface StreamInterface
- {
- /**
- * Attempts to seek to the beginning of the stream and reads all data into
- * a string until the end of the stream is reached.
- *
- * Warning: This could attempt to load a large amount of data into memory.
- *
- * @return string
- */
- public function __toString();
- /**
- * Closes the stream and any underlying resources.
- */
- public function close();
- /**
- * Separates any underlying resources from the stream.
- *
- * After the underlying resource has been detached, the stream object is in
- * an unusable state. If you wish to use a Stream object as a PHP stream
- * but keep the Stream object in a consistent state, use
- * {@see GuzzleHttp\Stream\GuzzleStreamWrapper::getResource}.
- *
- * @return resource|null Returns the underlying PHP stream resource or null
- * if the Stream object did not utilize an underlying
- * stream resource.
- */
- public function detach();
- /**
- * Replaces the underlying stream resource with the provided stream.
- *
- * Use this method to replace the underlying stream with another; as an
- * example, in server-side code, if you decide to return a file, you
- * would replace the original content-oriented stream with the file
- * stream.
- *
- * Any internal state such as caching of cursor position should be reset
- * when attach() is called, as the stream has changed.
- *
- * @param resource $stream
- *
- * @return void
- */
- public function attach($stream);
- /**
- * Get the size of the stream if known
- *
- * @return int|null Returns the size in bytes if known, or null if unknown
- */
- public function getSize();
- /**
- * Returns the current position of the file read/write pointer
- *
- * @return int|bool Returns the position of the file pointer or false on error
- */
- public function tell();
- /**
- * Returns true if the stream is at the end of the stream.
- *
- * @return bool
- */
- public function eof();
- /**
- * Returns whether or not the stream is seekable
- *
- * @return bool
- */
- public function isSeekable();
- /**
- * Seek to a position in the stream
- *
- * @param int $offset Stream offset
- * @param int $whence 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 bool Returns true on success or false on failure
- * @link http://www.php.net/manual/en/function.fseek.php
- */
- public function seek($offset, $whence = SEEK_SET);
- /**
- * Returns whether or not the stream is writable
- *
- * @return bool
- */
- public function isWritable();
- /**
- * Write data to the stream
- *
- * @param string $string The string that is to be written.
- *
- * @return int|bool Returns the number of bytes written to the stream on
- * success returns false on failure (e.g., broken pipe,
- * writer needs to slow down, buffer is full, etc.)
- */
- public function write($string);
- /**
- * Returns whether or not the stream is readable
- *
- * @return bool
- */
- public function isReadable();
- /**
- * Read data from the stream
- *
- * @param int $length 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 string Returns the data read from the stream.
- */
- public function read($length);
- /**
- * Returns the remaining contents of the stream as a string.
- *
- * Note: this could potentially load a large amount of data into memory.
- *
- * @return string
- */
- public function getContents();
- /**
- * Get stream metadata as an associative array or retrieve a specific key.
- *
- * The keys returned are identical to the keys returned from PHP's
- * stream_get_meta_data() function.
- *
- * @param string $key Specific metadata to retrieve.
- *
- * @return array|mixed|null Returns an associative array if no key is
- * 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.
- * @see http://php.net/manual/en/function.stream-get-meta-data.php
- */
- public function getMetadata($key = null);
- }
|