From 1439bb9f7e16d01b3883a547e13bda2d303b1984 Mon Sep 17 00:00:00 2001
From: Dave Bakker subscribe
function to obtain a po
for using
wasi:io/poll
.
resource output-stream
An output bytestream.
-output-stream
s are non-blocking to the extent practical on
+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
.
+polled for using wasi:io/poll
.
resource future-forward-result
[method]input-stream.read: func
Perform a non-blocking read from the stream.
@@ -418,3 +420,56 @@ is ready for reading, before performing thesplice
.
u64
, stream-error
>forward: func
Continuously read all data from the input stream and write it to the +output stream.
+Forwarding is done on a background task. The tasks runs until either +stream closes or fails. After that, the streams are dropped and the +returned future is resolved. Dropping the future before it has been +resolved aborts the background task and drops the streams.
+The future resolves with the reason that caused the forwarding to terminate.
+In case one of the streams ended normally, this will be stream-error::closed
.
This function requires exclusive access to the provided streams, +yet it does not change the ownership structure of them. I.e. they remain +children of their parent resources. If the parents place any lifetimes +restrictions on their children, those continue to apply.
+src
: own<input-stream
>dst
: own<output-stream
>future-forward-result
>[method]future-forward-result.subscribe: func
Returns a pollable which becomes ready when either the result is
+available. When this pollable is ready, the get
method will return
+some
.
self
: borrow<future-forward-result
>pollable
>[method]future-forward-result.get: func
Get the resolved value.
+Returns:
+none
: when the future hasn't resolved yet. Use subscribe
to wait
+for its completion.some(error(_))
: when the future is resolved, but the result value
+has already been taken before.some(ok(value))
: when the future is ready with a value. This is
+returned only once.self
: borrow<future-forward-result
>stream-error
>>