Skip to content

Commit 08dc767

Browse files
committed
Add the readable stream interface
1 parent a8a29c5 commit 08dc767

File tree

1 file changed

+76
-0
lines changed

1 file changed

+76
-0
lines changed
Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
<?php
2+
3+
/**
4+
* Streams
5+
*
6+
* Permission is hereby granted, free of charge, to any person obtaining a copy
7+
* of this software and associated documentation files (the "Software"), to deal
8+
* in the Software without restriction, including without limitation the rights
9+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10+
* copies of the Software, and to permit persons to whom the Software is
11+
* furnished to do so, subject to the following conditions:
12+
*
13+
* The above copyright notice and this permission notice shall be included in all
14+
* copies or substantial portions of the Software.
15+
*
16+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22+
* SOFTWARE.
23+
*
24+
* @category Library
25+
* @package Streams
26+
* @author Axel Nana <[email protected]>
27+
* @copyright 2019 Aliens Group.
28+
* @license MIT <https://github.com/ElementaryFramework/Streams/blob/master/LICENSE>
29+
* @version GIT: 0.0.1
30+
*/
31+
32+
namespace ElementaryFramework\Core\Streams;
33+
34+
/**
35+
* Readable Stream Interface
36+
*
37+
* Interface with base methods to implement a
38+
* stream with read-only capabilities.
39+
*
40+
* @package Streams
41+
* @author Axel Nana <[email protected]>
42+
*/
43+
interface IReadableStream extends IStream
44+
{
45+
/**
46+
* Checks if the stream is in a readable state.
47+
*
48+
* @return boolean
49+
*/
50+
function isReadable() : bool;
51+
52+
/**
53+
* Pauses the stream and stop reading incoming data events.
54+
*
55+
* @return void
56+
*/
57+
function pause() : void;
58+
59+
/**
60+
* Resumes reading incoming data events.
61+
*
62+
* @return void
63+
*/
64+
function resume() : void;
65+
66+
/**
67+
* Pipes all data from this readable stream to a writable destination.
68+
*
69+
* @param IWritableStream $destination The writable stream destination.
70+
* @param boolean $autoEnd Define if the $destination stream must
71+
* end at the same time of this readable stream.
72+
*
73+
* @return IReadableStream A readable stream from the destination.
74+
*/
75+
function pipe(IWritableStream $destination, bool $autoEnd = true) : IReadableStream;
76+
}

0 commit comments

Comments
 (0)