mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-06-08 05:27:14 +09:00

Our existing implementation of stream piping was extremely ad-hoc. It did nothing to handle closed/errored streams, and did not read from or write to streams in a way required by the spec. This new implementation uses a custom JS::Cell to drive the read/write loop.
39 lines
1.6 KiB
C++
39 lines
1.6 KiB
C++
/*
|
|
* Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
|
|
* Copyright (c) 2023, networkException <networkexception@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibJS/Forward.h>
|
|
#include <LibJS/Runtime/PromiseCapability.h>
|
|
#include <LibJS/Runtime/Value.h>
|
|
#include <LibWeb/Forward.h>
|
|
#include <LibWeb/WebIDL/ExceptionOr.h>
|
|
|
|
namespace Web::WebIDL {
|
|
|
|
using ReactionSteps = GC::Function<WebIDL::ExceptionOr<JS::Value>(JS::Value)>;
|
|
|
|
// https://webidl.spec.whatwg.org/#es-promise
|
|
using Promise = JS::PromiseCapability;
|
|
|
|
GC::Ref<Promise> create_promise(JS::Realm&);
|
|
GC::Ref<Promise> create_resolved_promise(JS::Realm&, JS::Value);
|
|
GC::Ref<Promise> create_rejected_promise(JS::Realm&, JS::Value);
|
|
void resolve_promise(JS::Realm&, Promise const&, JS::Value = JS::js_undefined());
|
|
void reject_promise(JS::Realm&, Promise const&, JS::Value);
|
|
GC::Ref<Promise> react_to_promise(Promise const&, GC::Ptr<ReactionSteps> on_fulfilled_callback, GC::Ptr<ReactionSteps> on_rejected_callback);
|
|
GC::Ref<Promise> upon_fulfillment(Promise const&, GC::Ref<ReactionSteps>);
|
|
GC::Ref<Promise> upon_rejection(Promise const&, GC::Ref<ReactionSteps>);
|
|
void mark_promise_as_handled(Promise const&);
|
|
bool is_promise_fulfilled(Promise const&);
|
|
void wait_for_all(JS::Realm&, Vector<GC::Ref<Promise>> const& promises, Function<void(Vector<JS::Value> const&)> success_steps, Function<void(JS::Value)> failure_steps);
|
|
GC::Ref<Promise> get_promise_for_wait_for_all(JS::Realm&, Vector<GC::Ref<Promise>> const& promises);
|
|
|
|
// Non-spec, convenience method.
|
|
GC::Ref<Promise> create_rejected_promise_from_exception(JS::Realm&, Exception);
|
|
|
|
}
|