Documentation ¶
Overview ¶
Package streams represents the imported interface "wasi:io/streams@0.2.0".
WASI I/O is an I/O abstraction API which is currently focused on providing stream types.
In the future, the component model is expected to add built-in stream types; when it does, they are expected to subsume this API.
Index ¶
- type Error
- type InputStream
- func (self InputStream) BlockingRead(len_ uint64) (result cm.Result[cm.List[uint8], cm.List[uint8], StreamError])
- func (self InputStream) BlockingSkip(len_ uint64) (result cm.Result[uint64, uint64, StreamError])
- func (self InputStream) Read(len_ uint64) (result cm.Result[cm.List[uint8], cm.List[uint8], StreamError])
- func (self InputStream) ResourceDrop()
- func (self InputStream) Skip(len_ uint64) (result cm.Result[uint64, uint64, StreamError])
- func (self InputStream) Subscribe() (result Pollable)
- type OutputStream
- func (self OutputStream) BlockingFlush() (result cm.Result[StreamError, struct{}, StreamError])
- func (self OutputStream) BlockingSplice(src InputStream, len_ uint64) (result cm.Result[uint64, uint64, StreamError])
- func (self OutputStream) BlockingWriteAndFlush(contents cm.List[uint8]) (result cm.Result[StreamError, struct{}, StreamError])
- func (self OutputStream) BlockingWriteZeroesAndFlush(len_ uint64) (result cm.Result[StreamError, struct{}, StreamError])
- func (self OutputStream) CheckWrite() (result cm.Result[uint64, uint64, StreamError])
- func (self OutputStream) Flush() (result cm.Result[StreamError, struct{}, StreamError])
- func (self OutputStream) ResourceDrop()
- func (self OutputStream) Splice(src InputStream, len_ uint64) (result cm.Result[uint64, uint64, StreamError])
- func (self OutputStream) Subscribe() (result Pollable)
- func (self OutputStream) Write(contents cm.List[uint8]) (result cm.Result[StreamError, struct{}, StreamError])
- func (self OutputStream) WriteZeroes(len_ uint64) (result cm.Result[StreamError, struct{}, StreamError])
- type Pollable
- type StreamError
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Error ¶
Error represents the imported type alias "wasi:io/streams@0.2.0#error".
See ioerror.Error for more information.
type InputStream ¶
InputStream represents the imported resource "wasi:io/streams@0.2.0#input-stream".
An input bytestream.
`input-stream`s are *non-blocking* to the extent practical on underlying platforms. I/O operations always return promptly; if fewer bytes are promptly available than requested, they return the number of bytes promptly available, which could even be zero. To wait for data to be available, use the `subscribe` function to obtain a `pollable` which can be polled for using `wasi:io/poll`.
resource input-stream
func (InputStream) BlockingRead ¶
func (self InputStream) BlockingRead(len_ uint64) (result cm.Result[cm.List[uint8], cm.List[uint8], StreamError])
BlockingRead represents the imported method "blocking-read".
Read bytes from a stream, after blocking until at least one byte can be read. Except for blocking, behavior is identical to `read`.
blocking-read: func(len: u64) -> result<list<u8>, stream-error>
func (InputStream) BlockingSkip ¶
func (self InputStream) BlockingSkip(len_ uint64) (result cm.Result[uint64, uint64, StreamError])
BlockingSkip represents the imported method "blocking-skip".
Skip bytes from a stream, after blocking until at least one byte can be skipped. Except for blocking behavior, identical to `skip`.
blocking-skip: func(len: u64) -> result<u64, stream-error>
func (InputStream) Read ¶
func (self InputStream) Read(len_ uint64) (result cm.Result[cm.List[uint8], cm.List[uint8], StreamError])
Read represents the imported method "read".
Perform a non-blocking read from the stream.
When the source of a `read` is binary data, the bytes from the source are returned verbatim. When the source of a `read` is known to the implementation to be text, bytes containing the UTF-8 encoding of the text are returned.
This function returns a list of bytes containing the read data, when successful. The returned list will contain up to `len` bytes; it may return fewer than requested, but not more. The list is empty when no bytes are available for reading at this time. The pollable given by `subscribe` will be ready when more bytes are available.
This function fails with a `stream-error` when the operation encounters an error, giving `last-operation-failed`, or when the stream is closed, giving `closed`.
When the caller gives a `len` of 0, it represents a request to read 0 bytes. If the stream is still open, this call should succeed and return an empty list, or otherwise fail with `closed`.
The `len` parameter is a `u64`, which could represent a list of u8 which is not possible to allocate in wasm32, or not desirable to allocate as as a return value by the callee. The callee may return a list of bytes less than `len` in size while more bytes are available for reading.
read: func(len: u64) -> result<list<u8>, stream-error>
func (InputStream) ResourceDrop ¶
func (self InputStream) ResourceDrop()
ResourceDrop represents the imported resource-drop for resource "input-stream".
Drops a resource handle.
func (InputStream) Skip ¶
func (self InputStream) Skip(len_ uint64) (result cm.Result[uint64, uint64, StreamError])
Skip represents the imported method "skip".
Skip bytes from a stream. Returns number of bytes skipped.
Behaves identical to `read`, except instead of returning a list of bytes, returns the number of bytes consumed from the stream.
skip: func(len: u64) -> result<u64, stream-error>
func (InputStream) Subscribe ¶
func (self InputStream) Subscribe() (result Pollable)
Subscribe represents the imported method "subscribe".
Create a `pollable` which will resolve once either the specified stream has bytes available to read or the other end of the stream has been closed. The created `pollable` is a child resource of the `input-stream`. Implementations may trap if the `input-stream` is dropped before all derived `pollable`s created with this function are dropped.
subscribe: func() -> pollable
type OutputStream ¶
OutputStream represents the imported resource "wasi:io/streams@0.2.0#output-stream".
An output bytestream.
`output-stream`s are *non-blocking* to the extent practical on underlying platforms. Except where specified otherwise, I/O operations also always return promptly, after the number of bytes that can be written promptly, which could even be zero. To wait for the stream to be ready to accept data, the `subscribe` function to obtain a `pollable` which can be polled for using `wasi:io/poll`.
resource output-stream
func (OutputStream) BlockingFlush ¶
func (self OutputStream) BlockingFlush() (result cm.Result[StreamError, struct{}, StreamError])
BlockingFlush represents the imported method "blocking-flush".
Request to flush buffered output, and block until flush completes and stream is ready for writing again.
blocking-flush: func() -> result<_, stream-error>
func (OutputStream) BlockingSplice ¶
func (self OutputStream) BlockingSplice(src InputStream, len_ uint64) (result cm.Result[uint64, uint64, StreamError])
BlockingSplice represents the imported method "blocking-splice".
Read from one stream and write to another, with blocking.
This is similar to `splice`, except that it blocks until the `output-stream` is ready for writing, and the `input-stream` is ready for reading, before performing the `splice`.
blocking-splice: func(src: borrow<input-stream>, len: u64) -> result<u64, stream-error>
func (OutputStream) BlockingWriteAndFlush ¶
func (self OutputStream) BlockingWriteAndFlush(contents cm.List[uint8]) (result cm.Result[StreamError, struct{}, StreamError])
BlockingWriteAndFlush represents the imported method "blocking-write-and-flush".
Perform a write of up to 4096 bytes, and then flush the stream. Block until all of these operations are complete, or an error occurs.
This is a convenience wrapper around the use of `check-write`, `subscribe`, `write`, and `flush`, and is implemented with the following pseudo-code:
let pollable = this.subscribe(); while !contents.is_empty() { // Wait for the stream to become writable pollable.block(); let Ok(n) = this.check-write(); // eliding error handling let len = min(n, contents.len()); let (chunk, rest) = contents.split_at(len); this.write(chunk ); // eliding error handling contents = rest; } this.flush(); // Wait for completion of `flush` pollable.block(); // Check for any errors that arose during `flush` let _ = this.check-write(); // eliding error handling blocking-write-and-flush: func(contents: list<u8>) -> result<_, stream-error>
func (OutputStream) BlockingWriteZeroesAndFlush ¶
func (self OutputStream) BlockingWriteZeroesAndFlush(len_ uint64) (result cm.Result[StreamError, struct{}, StreamError])
BlockingWriteZeroesAndFlush represents the imported method "blocking-write-zeroes-and-flush".
Perform a write of up to 4096 zeroes, and then flush the stream. Block until all of these operations are complete, or an error occurs.
This is a convenience wrapper around the use of `check-write`, `subscribe`, `write-zeroes`, and `flush`, and is implemented with the following pseudo-code:
let pollable = this.subscribe(); while num_zeroes != 0 { // Wait for the stream to become writable pollable.block(); let Ok(n) = this.check-write(); // eliding error handling let len = min(n, num_zeroes); this.write-zeroes(len); // eliding error handling num_zeroes -= len; } this.flush(); // Wait for completion of `flush` pollable.block(); // Check for any errors that arose during `flush` let _ = this.check-write(); // eliding error handling blocking-write-zeroes-and-flush: func(len: u64) -> result<_, stream-error>
func (OutputStream) CheckWrite ¶
func (self OutputStream) CheckWrite() (result cm.Result[uint64, uint64, StreamError])
CheckWrite represents the imported method "check-write".
Check readiness for writing. This function never blocks.
Returns the number of bytes permitted for the next call to `write`, or an error. Calling `write` with more bytes than this function has permitted will trap.
When this function returns 0 bytes, the `subscribe` pollable will become ready when this function will report at least 1 byte, or an error.
check-write: func() -> result<u64, stream-error>
func (OutputStream) Flush ¶
func (self OutputStream) Flush() (result cm.Result[StreamError, struct{}, StreamError])
Flush represents the imported method "flush".
Request to flush buffered output. This function never blocks.
This tells the output-stream that the caller intends any buffered output to be flushed. the output which is expected to be flushed is all that has been passed to `write` prior to this call.
Upon calling this function, the `output-stream` will not accept any writes (`check-write` will return `ok(0)`) until the flush has completed. The `subscribe` pollable will become ready when the flush has completed and the stream can accept more writes.
flush: func() -> result<_, stream-error>
func (OutputStream) ResourceDrop ¶
func (self OutputStream) ResourceDrop()
ResourceDrop represents the imported resource-drop for resource "output-stream".
Drops a resource handle.
func (OutputStream) Splice ¶
func (self OutputStream) Splice(src InputStream, len_ uint64) (result cm.Result[uint64, uint64, StreamError])
Splice represents the imported method "splice".
Read from one stream and write to another.
The behavior of splice is equivelant to: 1. calling `check-write` on the `output-stream` 2. calling `read` on the `input-stream` with the smaller of the `check-write` permitted length and the `len` provided to `splice` 3. calling `write` on the `output-stream` with that read data.
Any error reported by the call to `check-write`, `read`, or `write` ends the splice and reports that error.
This function returns the number of bytes transferred; it may be less than `len`.
splice: func(src: borrow<input-stream>, len: u64) -> result<u64, stream-error>
func (OutputStream) Subscribe ¶
func (self OutputStream) Subscribe() (result Pollable)
Subscribe represents the imported method "subscribe".
Create a `pollable` which will resolve once the output-stream is ready for more writing, or an error has occured. When this pollable is ready, `check-write` will return `ok(n)` with n>0, or an error.
If the stream is closed, this pollable is always ready immediately.
The created `pollable` is a child resource of the `output-stream`. Implementations may trap if the `output-stream` is dropped before all derived `pollable`s created with this function are dropped.
subscribe: func() -> pollable
func (OutputStream) Write ¶
func (self OutputStream) Write(contents cm.List[uint8]) (result cm.Result[StreamError, struct{}, StreamError])
Write represents the imported method "write".
Perform a write. This function never blocks.
When the destination of a `write` is binary data, the bytes from `contents` are written verbatim. When the destination of a `write` is known to the implementation to be text, the bytes of `contents` are transcoded from UTF-8 into the encoding of the destination and then written.
Precondition: check-write gave permit of Ok(n) and contents has a length of less than or equal to n. Otherwise, this function will trap.
returns Err(closed) without writing if the stream has closed since the last call to check-write provided a permit.
write: func(contents: list<u8>) -> result<_, stream-error>
func (OutputStream) WriteZeroes ¶
func (self OutputStream) WriteZeroes(len_ uint64) (result cm.Result[StreamError, struct{}, StreamError])
WriteZeroes represents the imported method "write-zeroes".
Write zeroes to a stream.
This should be used precisely like `write` with the exact same preconditions (must use check-write first), but instead of passing a list of bytes, you simply pass the number of zero-bytes that should be written.
write-zeroes: func(len: u64) -> result<_, stream-error>
type Pollable ¶
Pollable represents the imported type alias "wasi:io/streams@0.2.0#pollable".
See poll.Pollable for more information.
type StreamError ¶
StreamError represents the imported variant "wasi:io/streams@0.2.0#stream-error".
An error for input-stream and output-stream operations.
variant stream-error { last-operation-failed(error), closed, }
func StreamErrorClosed ¶
func StreamErrorClosed() StreamError
StreamErrorClosed returns a StreamError of case "closed".
The stream is closed: no more input will be accepted by the stream. A closed output-stream will return this error on all future operations.
func StreamErrorLastOperationFailed ¶
func StreamErrorLastOperationFailed(data Error) StreamError
StreamErrorLastOperationFailed returns a StreamError of case "last-operation-failed".
The last operation (a write or flush) failed before completion.
More information is available in the `error` payload.
func (*StreamError) Closed ¶
func (self *StreamError) Closed() bool
Closed returns true if StreamError represents the variant case "closed".
func (*StreamError) LastOperationFailed ¶
func (self *StreamError) LastOperationFailed() *Error
LastOperationFailed returns a non-nil *Error if StreamError represents the variant case "last-operation-failed".
func (StreamError) String ¶
func (v StreamError) String() string
String implements fmt.Stringer, returning the variant case name of v.