AbstractOperations.h 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. /*
  2. * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
  3. * Copyright (c) 2023, Matthew Olsson <mattco@serenityos.org>
  4. * Copyright (c) 2023-2024, Shannon Booth <shannon@serenityos.org>
  5. * Copyright (c) 2023, Kenneth Myhra <kennethmyhra@serenityos.org>
  6. *
  7. * SPDX-License-Identifier: BSD-2-Clause
  8. */
  9. #pragma once
  10. #include <LibJS/Heap/GCPtr.h>
  11. #include <LibWeb/Forward.h>
  12. #include <LibWeb/Streams/ReadableStream.h>
  13. #include <LibWeb/WebIDL/CallbackType.h>
  14. #include <LibWeb/WebIDL/ExceptionOr.h>
  15. #include <LibWeb/WebIDL/Promise.h>
  16. namespace Web::Streams {
  17. using SizeAlgorithm = JS::HeapFunction<JS::Completion(JS::Value)>;
  18. using PullAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>>()>;
  19. using CancelAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>>(JS::Value)>;
  20. using StartAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::Value>()>;
  21. using AbortAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>>(JS::Value)>;
  22. using CloseAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>>()>;
  23. using WriteAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>>(JS::Value)>;
  24. using FlushAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>>()>;
  25. using TransformAlgorithm = JS::HeapFunction<WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>>(JS::Value)>;
  26. WebIDL::ExceptionOr<JS::NonnullGCPtr<ReadableStreamDefaultReader>> acquire_readable_stream_default_reader(ReadableStream&);
  27. WebIDL::ExceptionOr<JS::NonnullGCPtr<ReadableStreamBYOBReader>> acquire_readable_stream_byob_reader(ReadableStream&);
  28. bool is_readable_stream_locked(ReadableStream const&);
  29. JS::NonnullGCPtr<SizeAlgorithm> extract_size_algorithm(JS::VM&, QueuingStrategy const&);
  30. WebIDL::ExceptionOr<double> extract_high_water_mark(QueuingStrategy const&, double default_hwm);
  31. void readable_stream_close(ReadableStream&);
  32. void readable_stream_error(ReadableStream&, JS::Value error);
  33. void readable_stream_add_read_request(ReadableStream&, JS::NonnullGCPtr<ReadRequest>);
  34. void readable_stream_add_read_into_request(ReadableStream&, JS::NonnullGCPtr<ReadIntoRequest>);
  35. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> readable_stream_cancel(ReadableStream&, JS::Value reason);
  36. void readable_stream_fulfill_read_into_request(ReadableStream&, JS::Value chunk, bool done);
  37. void readable_stream_fulfill_read_request(ReadableStream&, JS::Value chunk, bool done);
  38. size_t readable_stream_get_num_read_into_requests(ReadableStream const&);
  39. size_t readable_stream_get_num_read_requests(ReadableStream const&);
  40. bool readable_stream_has_byob_reader(ReadableStream const&);
  41. bool readable_stream_has_default_reader(ReadableStream const&);
  42. WebIDL::ExceptionOr<ReadableStreamPair> readable_stream_tee(JS::Realm&, ReadableStream&, bool clone_for_branch2);
  43. WebIDL::ExceptionOr<ReadableStreamPair> readable_stream_default_tee(JS::Realm& realm, ReadableStream& stream, bool clone_for_branch2);
  44. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> readable_stream_reader_generic_cancel(ReadableStreamGenericReaderMixin&, JS::Value reason);
  45. void readable_stream_reader_generic_initialize(ReadableStreamReader, ReadableStream&);
  46. WebIDL::ExceptionOr<void> readable_stream_reader_generic_release(ReadableStreamGenericReaderMixin&);
  47. void readable_stream_default_reader_error_read_requests(ReadableStreamDefaultReader&, JS::Value error);
  48. void readable_stream_byob_reader_error_read_into_requests(ReadableStreamBYOBReader&, JS::Value error);
  49. JS::Value readable_byte_stream_controller_convert_pull_into_descriptor(JS::Realm&, PullIntoDescriptor const&);
  50. void readable_byte_stream_controller_pull_into(ReadableByteStreamController&, WebIDL::ArrayBufferView&, ReadIntoRequest&);
  51. void readable_stream_byob_reader_read(ReadableStreamBYOBReader&, WebIDL::ArrayBufferView&, ReadIntoRequest&);
  52. void readable_byte_stream_controller_fill_head_pull_into_descriptor(ReadableByteStreamController const&, u64 size, PullIntoDescriptor&);
  53. WebIDL::ExceptionOr<void> readable_stream_default_reader_read(ReadableStreamDefaultReader&, ReadRequest&);
  54. WebIDL::ExceptionOr<void> readable_stream_default_reader_release(ReadableStreamDefaultReader&);
  55. void readable_stream_byob_reader_release(ReadableStreamBYOBReader&);
  56. WebIDL::ExceptionOr<void> set_up_readable_stream_default_reader(ReadableStreamDefaultReader&, ReadableStream&);
  57. WebIDL::ExceptionOr<void> set_up_readable_stream_byob_reader(ReadableStreamBYOBReader&, ReadableStream&);
  58. void readable_stream_default_controller_close(ReadableStreamDefaultController&);
  59. bool readable_stream_default_controller_has_backpressure(ReadableStreamDefaultController&);
  60. WebIDL::ExceptionOr<void> readable_stream_default_controller_enqueue(ReadableStreamDefaultController&, JS::Value chunk);
  61. WebIDL::ExceptionOr<void> readable_stream_default_controller_can_pull_if_needed(ReadableStreamDefaultController&);
  62. bool readable_stream_default_controller_should_call_pull(ReadableStreamDefaultController&);
  63. void readable_stream_default_controller_clear_algorithms(ReadableStreamDefaultController&);
  64. void readable_stream_default_controller_error(ReadableStreamDefaultController&, JS::Value error);
  65. Optional<double> readable_stream_default_controller_get_desired_size(ReadableStreamDefaultController&);
  66. bool readable_stream_default_controller_can_close_or_enqueue(ReadableStreamDefaultController&);
  67. WebIDL::ExceptionOr<void> set_up_readable_stream_default_controller(ReadableStream&, ReadableStreamDefaultController&, JS::NonnullGCPtr<StartAlgorithm>, JS::NonnullGCPtr<PullAlgorithm>, JS::NonnullGCPtr<CancelAlgorithm>, double high_water_mark, JS::NonnullGCPtr<SizeAlgorithm>);
  68. WebIDL::ExceptionOr<void> set_up_readable_stream_default_controller_from_underlying_source(ReadableStream&, JS::Value underlying_source_value, UnderlyingSource, double high_water_mark, JS::NonnullGCPtr<SizeAlgorithm>);
  69. WebIDL::ExceptionOr<void> set_up_readable_stream_controller_with_byte_reading_support(ReadableStream&, JS::GCPtr<PullAlgorithm> = {}, JS::GCPtr<CancelAlgorithm> = {}, double high_water_mark = 0);
  70. WebIDL::ExceptionOr<void> set_up_readable_byte_stream_controller(ReadableStream&, ReadableByteStreamController&, JS::NonnullGCPtr<StartAlgorithm>, JS::NonnullGCPtr<PullAlgorithm>, JS::NonnullGCPtr<CancelAlgorithm>, double high_water_mark, JS::Value auto_allocate_chunk_size);
  71. WebIDL::ExceptionOr<void> set_up_readable_byte_stream_controller_from_underlying_source(ReadableStream&, JS::Value underlying_source, UnderlyingSource const& underlying_source_dict, double high_water_mark);
  72. JS::GCPtr<ReadableStreamBYOBRequest> readable_byte_stream_controller_get_byob_request(JS::NonnullGCPtr<ReadableByteStreamController>);
  73. WebIDL::ExceptionOr<void> readable_byte_stream_controller_respond_in_readable_state(ReadableByteStreamController&, u64 bytes_written, PullIntoDescriptor&);
  74. void readable_byte_stream_controller_respond_in_closed_state(ReadableByteStreamController&, PullIntoDescriptor&);
  75. WebIDL::ExceptionOr<void> readable_byte_stream_controller_respond_internal(ReadableByteStreamController&, u64 bytes_written);
  76. WebIDL::ExceptionOr<void> readable_byte_stream_controller_respond(ReadableByteStreamController&, u64 bytes_written);
  77. WebIDL::ExceptionOr<void> readable_byte_stream_controller_respond_with_new_view(JS::Realm&, ReadableByteStreamController&, WebIDL::ArrayBufferView&);
  78. WebIDL::ExceptionOr<void> readable_stream_enqueue(ReadableStreamController& controller, JS::Value chunk);
  79. WebIDL::ExceptionOr<void> readable_byte_stream_controller_enqueue(ReadableByteStreamController& controller, JS::Value chunk);
  80. WebIDL::ExceptionOr<JS::NonnullGCPtr<JS::ArrayBuffer>> transfer_array_buffer(JS::Realm& realm, JS::ArrayBuffer& buffer);
  81. WebIDL::ExceptionOr<void> readable_byte_stream_controller_enqueue_detached_pull_into_queue(ReadableByteStreamController& controller, PullIntoDescriptor& pull_into_descriptor);
  82. void readable_byte_stream_controller_commit_pull_into_descriptor(ReadableStream&, PullIntoDescriptor const&);
  83. WebIDL::ExceptionOr<void> readable_byte_stream_controller_process_read_requests_using_queue(ReadableByteStreamController& controller);
  84. void readable_byte_stream_controller_process_pull_into_descriptors_using_queue(ReadableByteStreamController&);
  85. void readable_byte_stream_controller_enqueue_chunk_to_queue(ReadableByteStreamController& controller, JS::NonnullGCPtr<JS::ArrayBuffer> buffer, u32 byte_offset, u32 byte_length);
  86. WebIDL::ExceptionOr<void> readable_byte_stream_controller_enqueue_cloned_chunk_to_queue(ReadableByteStreamController& controller, JS::ArrayBuffer& buffer, u64 byte_offset, u64 byte_length);
  87. PullIntoDescriptor readable_byte_stream_controller_shift_pending_pull_into(ReadableByteStreamController& controller);
  88. WebIDL::ExceptionOr<void> readable_byte_stream_controller_call_pull_if_needed(ReadableByteStreamController&);
  89. void readable_byte_stream_controller_clear_algorithms(ReadableByteStreamController&);
  90. void readable_byte_stream_controller_clear_pending_pull_intos(ReadableByteStreamController&);
  91. WebIDL::ExceptionOr<void> readable_byte_stream_controller_close(ReadableByteStreamController&);
  92. void readable_byte_stream_controller_error(ReadableByteStreamController&, JS::Value error);
  93. WebIDL::ExceptionOr<void> readable_byte_stream_controller_fill_read_request_from_queue(ReadableByteStreamController&, JS::NonnullGCPtr<ReadRequest>);
  94. bool readable_byte_stream_controller_fill_pull_into_descriptor_from_queue(ReadableByteStreamController&, PullIntoDescriptor&);
  95. Optional<double> readable_byte_stream_controller_get_desired_size(ReadableByteStreamController const&);
  96. WebIDL::ExceptionOr<void> readable_byte_stream_controller_handle_queue_drain(ReadableByteStreamController&);
  97. void readable_byte_stream_controller_invalidate_byob_request(ReadableByteStreamController&);
  98. bool readable_byte_stream_controller_should_call_pull(ReadableByteStreamController const&);
  99. WebIDL::ExceptionOr<JS::NonnullGCPtr<ReadableStream>> create_readable_stream(JS::Realm& realm, JS::NonnullGCPtr<StartAlgorithm> start_algorithm, JS::NonnullGCPtr<PullAlgorithm> pull_algorithm, JS::NonnullGCPtr<CancelAlgorithm> cancel_algorithm, Optional<double> high_water_mark = {}, JS::GCPtr<SizeAlgorithm> size_algorithm = {});
  100. WebIDL::ExceptionOr<JS::NonnullGCPtr<ReadableStream>> create_readable_byte_stream(JS::Realm& realm, JS::NonnullGCPtr<StartAlgorithm> start_algorithm, JS::NonnullGCPtr<PullAlgorithm> pull_algorithm, JS::NonnullGCPtr<CancelAlgorithm> cancel_algorithm);
  101. WebIDL::ExceptionOr<JS::NonnullGCPtr<WritableStream>> create_writable_stream(JS::Realm& realm, JS::NonnullGCPtr<StartAlgorithm> start_algorithm, JS::NonnullGCPtr<WriteAlgorithm> write_algorithm, JS::NonnullGCPtr<CloseAlgorithm> close_algorithm, JS::NonnullGCPtr<AbortAlgorithm> abort_algorithm, double high_water_mark, JS::NonnullGCPtr<SizeAlgorithm> size_algorithm);
  102. void initialize_readable_stream(ReadableStream&);
  103. void initialize_writable_stream(WritableStream&);
  104. WebIDL::ExceptionOr<JS::NonnullGCPtr<WritableStreamDefaultWriter>> acquire_writable_stream_default_writer(WritableStream&);
  105. bool is_writable_stream_locked(WritableStream const&);
  106. WebIDL::ExceptionOr<void> set_up_writable_stream_default_writer(WritableStreamDefaultWriter&, WritableStream&);
  107. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> writable_stream_abort(WritableStream&, JS::Value reason);
  108. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> writable_stream_close(WritableStream&);
  109. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> writable_stream_add_write_request(WritableStream&);
  110. bool writable_stream_close_queued_or_in_flight(WritableStream const&);
  111. WebIDL::ExceptionOr<void> writable_stream_deal_with_rejection(WritableStream&, JS::Value error);
  112. WebIDL::ExceptionOr<void> writable_stream_finish_erroring(WritableStream&);
  113. void writable_stream_finish_in_flight_close(WritableStream&);
  114. WebIDL::ExceptionOr<void> writable_stream_finish_in_flight_close_with_error(WritableStream&, JS::Value error);
  115. void writable_stream_finish_in_flight_write(WritableStream&);
  116. WebIDL::ExceptionOr<void> writable_stream_finish_in_flight_write_with_error(WritableStream&, JS::Value error);
  117. bool writable_stream_has_operation_marked_in_flight(WritableStream const&);
  118. void writable_stream_mark_close_request_in_flight(WritableStream&);
  119. void writable_stream_mark_first_write_request_in_flight(WritableStream&);
  120. void writable_stream_reject_close_and_closed_promise_if_needed(WritableStream&);
  121. WebIDL::ExceptionOr<void> writable_stream_start_erroring(WritableStream&, JS::Value reason);
  122. void writable_stream_update_backpressure(WritableStream&, bool backpressure);
  123. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> writable_stream_default_writer_abort(WritableStreamDefaultWriter&, JS::Value reason);
  124. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> writable_stream_default_writer_close(WritableStreamDefaultWriter&);
  125. void writable_stream_default_writer_ensure_closed_promise_rejected(WritableStreamDefaultWriter&, JS::Value error);
  126. void writable_stream_default_writer_ensure_ready_promise_rejected(WritableStreamDefaultWriter&, JS::Value error);
  127. Optional<double> writable_stream_default_writer_get_desired_size(WritableStreamDefaultWriter const&);
  128. WebIDL::ExceptionOr<void> writable_stream_default_writer_release(WritableStreamDefaultWriter&);
  129. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> writable_stream_default_writer_write(WritableStreamDefaultWriter&, JS::Value chunk);
  130. WebIDL::ExceptionOr<void> set_up_writable_stream_default_controller(WritableStream&, WritableStreamDefaultController&, JS::NonnullGCPtr<StartAlgorithm>, JS::NonnullGCPtr<WriteAlgorithm>, JS::NonnullGCPtr<CloseAlgorithm>, JS::NonnullGCPtr<AbortAlgorithm>, double high_water_mark, JS::NonnullGCPtr<SizeAlgorithm>);
  131. WebIDL::ExceptionOr<void> set_up_writable_stream_default_controller_from_underlying_sink(WritableStream&, JS::Value underlying_sink_value, UnderlyingSink&, double high_water_mark, JS::NonnullGCPtr<SizeAlgorithm> size_algorithm);
  132. WebIDL::ExceptionOr<void> writable_stream_default_controller_advance_queue_if_needed(WritableStreamDefaultController&);
  133. void writable_stream_default_controller_clear_algorithms(WritableStreamDefaultController&);
  134. WebIDL::ExceptionOr<void> writable_stream_default_controller_close(WritableStreamDefaultController&);
  135. WebIDL::ExceptionOr<void> writable_stream_default_controller_error(WritableStreamDefaultController&, JS::Value error);
  136. WebIDL::ExceptionOr<void> writable_stream_default_controller_error_if_needed(WritableStreamDefaultController&, JS::Value error);
  137. bool writable_stream_default_controller_get_backpressure(WritableStreamDefaultController const&);
  138. WebIDL::ExceptionOr<JS::Value> writable_stream_default_controller_get_chunk_size(WritableStreamDefaultController&, JS::Value chunk);
  139. double writable_stream_default_controller_get_desired_size(WritableStreamDefaultController const&);
  140. WebIDL::ExceptionOr<void> writable_stream_default_controller_process_close(WritableStreamDefaultController&);
  141. WebIDL::ExceptionOr<void> writable_stream_default_controller_process_write(WritableStreamDefaultController&, JS::Value chunk);
  142. WebIDL::ExceptionOr<void> writable_stream_default_controller_write(WritableStreamDefaultController&, JS::Value chunk, JS::Value chunk_size);
  143. WebIDL::ExceptionOr<void> initialize_transform_stream(TransformStream&, JS::NonnullGCPtr<JS::PromiseCapability> start_promise, double writable_high_water_mark, JS::NonnullGCPtr<SizeAlgorithm> writable_size_algorithm, double readable_high_water_mark, JS::NonnullGCPtr<SizeAlgorithm> readable_size_algorithm);
  144. void set_up_transform_stream_default_controller(TransformStream&, TransformStreamDefaultController&, JS::NonnullGCPtr<TransformAlgorithm>, JS::NonnullGCPtr<FlushAlgorithm>);
  145. WebIDL::ExceptionOr<void> set_up_transform_stream_default_controller_from_transformer(TransformStream&, JS::Value transformer, Transformer&);
  146. void transform_stream_default_controller_clear_algorithms(TransformStreamDefaultController&);
  147. WebIDL::ExceptionOr<void> transform_stream_default_controller_enqueue(TransformStreamDefaultController&, JS::Value chunk);
  148. WebIDL::ExceptionOr<void> transform_stream_default_controller_error(TransformStreamDefaultController&, JS::Value error);
  149. WebIDL::ExceptionOr<void> transform_stream_default_controller_terminate(TransformStreamDefaultController&);
  150. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> transform_stream_default_controller_perform_transform(TransformStreamDefaultController&, JS::Value chunk);
  151. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> transform_stream_default_sink_abort_algorithm(TransformStream&, JS::Value reason);
  152. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> transform_stream_default_sink_close_algorithm(TransformStream&);
  153. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> transform_stream_default_sink_write_algorithm(TransformStream&, JS::Value chunk);
  154. WebIDL::ExceptionOr<JS::NonnullGCPtr<WebIDL::Promise>> transform_stream_default_source_pull_algorithm(TransformStream&);
  155. WebIDL::ExceptionOr<void> transform_stream_error(TransformStream&, JS::Value error);
  156. WebIDL::ExceptionOr<void> transform_stream_error_writable_and_unblock_write(TransformStream&, JS::Value error);
  157. WebIDL::ExceptionOr<void> transform_stream_set_backpressure(TransformStream&, bool backpressure);
  158. bool is_non_negative_number(JS::Value);
  159. bool can_transfer_array_buffer(JS::ArrayBuffer const& array_buffer);
  160. WebIDL::ExceptionOr<JS::Value> clone_as_uint8_array(JS::Realm&, WebIDL::ArrayBufferView&);
  161. WebIDL::ExceptionOr<JS::Value> structured_clone(JS::Realm&, JS::Value value);
  162. JS::Value create_close_sentinel();
  163. bool is_close_sentinel(JS::Value);
  164. JS::ThrowCompletionOr<JS::Handle<WebIDL::CallbackType>> property_to_callback(JS::VM& vm, JS::Value value, JS::PropertyKey const& property_key, WebIDL::OperationReturnsPromise);
  165. // https://streams.spec.whatwg.org/#value-with-size
  166. struct ValueWithSize {
  167. JS::Value value;
  168. double size;
  169. };
  170. // https://streams.spec.whatwg.org/#dequeue-value
  171. template<typename T>
  172. JS::Value dequeue_value(T& container)
  173. {
  174. // 1. Assert: container has [[queue]] and [[queueTotalSize]] internal slots.
  175. // 2. Assert: container.[[queue]] is not empty.
  176. VERIFY(!container.queue().is_empty());
  177. // 3. Let valueWithSize be container.[[queue]][0].
  178. // 4. Remove valueWithSize from container.[[queue]].
  179. auto value_with_size = container.queue().take_first();
  180. // 5. Set container.[[queueTotalSize]] to container.[[queueTotalSize]] − valueWithSize’s size.
  181. container.set_queue_total_size(container.queue_total_size() - value_with_size.size);
  182. // 6. If container.[[queueTotalSize]] < 0, set container.[[queueTotalSize]] to 0. (This can occur due to rounding errors.)
  183. if (container.queue_total_size() < 0.0)
  184. container.set_queue_total_size(0.0);
  185. // 7. Return valueWithSize’s value.
  186. return value_with_size.value;
  187. }
  188. // https://streams.spec.whatwg.org/#enqueue-value-with-size
  189. template<typename T>
  190. WebIDL::ExceptionOr<void> enqueue_value_with_size(T& container, JS::Value value, JS::Value size_value)
  191. {
  192. // 1. Assert: container has [[queue]] and [[queueTotalSize]] internal slots.
  193. // 2. If ! IsNonNegativeNumber(size) is false, throw a RangeError exception.
  194. if (!is_non_negative_number(size_value))
  195. return WebIDL::SimpleException { WebIDL::SimpleExceptionType::RangeError, "Chunk has non-positive size"sv };
  196. auto size = size_value.as_double();
  197. // 3. If size is +∞, throw a RangeError exception.
  198. if (size == HUGE_VAL)
  199. return WebIDL::SimpleException { WebIDL::SimpleExceptionType::RangeError, "Chunk has infinite size"sv };
  200. // 4. Append a new value-with-size with value value and size size to container.[[queue]].
  201. container.queue().append({ value, size });
  202. // 5. Set container.[[queueTotalSize]] to container.[[queueTotalSize]] + size.
  203. container.set_queue_total_size(container.queue_total_size() + size);
  204. return {};
  205. }
  206. // https://streams.spec.whatwg.org/#peek-queue-value
  207. template<typename T>
  208. JS::Value peek_queue_value(T& container)
  209. {
  210. // 1. Assert: container has [[queue]] and [[queueTotalSize]] internal slots.
  211. // 2. Assert: container.[[queue]] is not empty.
  212. VERIFY(!container.queue().is_empty());
  213. // 3. Let valueWithSize be container.[[queue]][0].
  214. auto& value_with_size = container.queue().first();
  215. // 4. Return valueWithSize’s value.
  216. return value_with_size.value;
  217. }
  218. // https://streams.spec.whatwg.org/#reset-queue
  219. template<typename T>
  220. void reset_queue(T& container)
  221. {
  222. // 1. Assert: container has [[queue]] and [[queueTotalSize]] internal slots.
  223. // 2. Set container.[[queue]] to a new empty list.
  224. container.queue().clear();
  225. // 3. Set container.[[queueTotalSize]] to 0.
  226. container.set_queue_total_size(0);
  227. }
  228. }