mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 15:27:35 +00:00
LibWeb: Implement AO ReadableStreamByobReaderRead
We've finally implemented enough of the Streams AOs so that we are close to actually performing read operations with BYOB readers.
This commit is contained in:
parent
3d37cb0753
commit
9662872b20
2 changed files with 23 additions and 0 deletions
|
@ -811,6 +811,28 @@ void readable_byte_stream_controller_pull_into(ReadableByteStreamController& con
|
||||||
MUST(readable_byte_stream_controller_call_pull_if_needed(controller));
|
MUST(readable_byte_stream_controller_call_pull_if_needed(controller));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// https://streams.spec.whatwg.org/#readable-stream-byob-reader-read
|
||||||
|
void readable_stream_byob_reader_read(ReadableStreamBYOBReader& reader, JS::Value view, ReadIntoRequest& read_into_request)
|
||||||
|
{
|
||||||
|
// 1. Let stream be reader.[[stream]].
|
||||||
|
auto stream = reader.stream();
|
||||||
|
|
||||||
|
// 2. Assert: stream is not undefined.
|
||||||
|
VERIFY(stream);
|
||||||
|
|
||||||
|
// 3. Set stream.[[disturbed]] to true.
|
||||||
|
stream->set_disturbed(true);
|
||||||
|
|
||||||
|
// 4. If stream.[[state]] is "errored", perform readIntoRequest’s error steps given stream.[[storedError]].
|
||||||
|
if (stream->is_errored()) {
|
||||||
|
read_into_request.on_error(stream->stored_error());
|
||||||
|
}
|
||||||
|
// 5. Otherwise, perform ! ReadableByteStreamControllerPullInto(stream.[[controller]], view, readIntoRequest).
|
||||||
|
else {
|
||||||
|
readable_byte_stream_controller_pull_into(*stream->controller()->get<JS::NonnullGCPtr<ReadableByteStreamController>>(), view, read_into_request);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// https://streams.spec.whatwg.org/#abstract-opdef-readablestreamdefaultreaderrelease
|
// https://streams.spec.whatwg.org/#abstract-opdef-readablestreamdefaultreaderrelease
|
||||||
WebIDL::ExceptionOr<void> readable_stream_default_reader_release(ReadableStreamDefaultReader& reader)
|
WebIDL::ExceptionOr<void> readable_stream_default_reader_release(ReadableStreamDefaultReader& reader)
|
||||||
{
|
{
|
||||||
|
|
|
@ -55,6 +55,7 @@ void readable_stream_default_reader_error_read_requests(ReadableStreamDefaultRea
|
||||||
void readable_stream_byob_reader_error_read_into_requests(ReadableStreamBYOBReader&, JS::Value error);
|
void readable_stream_byob_reader_error_read_into_requests(ReadableStreamBYOBReader&, JS::Value error);
|
||||||
JS::Value readable_byte_stream_controller_convert_pull_into_descriptor(JS::Realm&, PullIntoDescriptor const&);
|
JS::Value readable_byte_stream_controller_convert_pull_into_descriptor(JS::Realm&, PullIntoDescriptor const&);
|
||||||
void readable_byte_stream_controller_pull_into(ReadableByteStreamController&, JS::Value view_value, ReadIntoRequest&);
|
void readable_byte_stream_controller_pull_into(ReadableByteStreamController&, JS::Value view_value, ReadIntoRequest&);
|
||||||
|
void readable_stream_byob_reader_read(ReadableStreamBYOBReader&, JS::Value view, ReadIntoRequest&);
|
||||||
void readable_byte_stream_controller_fill_head_pull_into_descriptor(ReadableByteStreamController const&, u64 size, PullIntoDescriptor&);
|
void readable_byte_stream_controller_fill_head_pull_into_descriptor(ReadableByteStreamController const&, u64 size, PullIntoDescriptor&);
|
||||||
|
|
||||||
WebIDL::ExceptionOr<void> readable_stream_default_reader_read(ReadableStreamDefaultReader&, ReadRequest&);
|
WebIDL::ExceptionOr<void> readable_stream_default_reader_read(ReadableStreamDefaultReader&, ReadRequest&);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue