summaryrefslogtreecommitdiff
blob: 307b43967abb1b3202c8667e796a9e027d299456 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
<pkgmetadata>
	<maintainer type="project">
		<email>haskell@gentoo.org</email>
		<name>Gentoo Haskell</name>
	</maintainer>
	<use>
		<flag name="network">Include network support</flag>
		<flag name="zlib">Include zlib support</flag>
	</use>
	<longdescription>
		/Overview/
		
		The io-streams library contains simple and easy-to-use primitives for I/O
		using streams. Most users will want to import the top-level convenience
		module "System.IO.Streams", which re-exports most of the library:
		
		@
		import           System.IO.Streams (InputStream, OutputStream)
		import qualified System.IO.Streams as Streams
		@
		
		For first-time users, @io-streams@ comes with an included tutorial, which can
		be found in the "System.IO.Streams.Tutorial" module.
		
		/Features/
		
		The @io-streams@ user API has two basic types: @InputStream a@ and
		@OutputStream a@, and three fundamental I/O primitives:
		
		@
		\-\- read an item from an input stream
		Streams.read :: InputStream a -&gt; IO (Maybe a)
		
		\-\- push an item back to an input stream
		Streams.unRead :: a -&gt; InputStream a -&gt; IO ()
		
		\-\- write to an output stream
		Streams.write :: Maybe a -&gt; OutputStream a -&gt; IO ()
		@
		
		Streams can be transformed by composition and hooked together with provided combinators:
		
		@
		ghci&gt; Streams.fromList [1,2,3::Int] &gt;&gt;= Streams.map (*10) &gt;&gt;= Streams.toList
		[10,20,30]
		@
		
		Stream composition leaves the original stream accessible:
		
		@
		ghci&gt; input \&lt;- Streams.fromByteString \"long string\"
		ghci&gt; wrapped \&lt;- Streams.takeBytes 4 input
		ghci&gt; Streams.read wrapped
		Just \"long\"
		ghci&gt; Streams.read wrapped
		Nothing
		ghci&gt; Streams.read input
		Just \" string\"
		@
		
		Simple types and operations in the IO monad mean straightforward and simple
		exception handling and resource cleanup using Haskell standard library
		facilities like 'Control.Exception.bracket'.
		
		@io-streams@ comes with:
		
		* functions to use files, handles, concurrent channels, sockets, lists,
		vectors, and more as streams.
		
		* a variety of combinators for wrapping and transforming streams, including
		compression and decompression using zlib, controlling precisely how many
		bytes are read from or written to a stream, buffering output using
		bytestring builders, folds, maps, filters, zips, etc.
		
		* support for parsing from streams using @attoparsec@.
		
		* support for spawning processes and communicating with them using streams.
	</longdescription>
</pkgmetadata>