mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-19 15:32:31 +00:00
LibGC+Everywhere: Factor out a LibGC from LibJS
Resulting in a massive rename across almost everywhere! Alongside the namespace change, we now have the following names: * JS::NonnullGCPtr -> GC::Ref * JS::GCPtr -> GC::Ptr * JS::HeapFunction -> GC::Function * JS::CellImpl -> GC::Cell * JS::Handle -> GC::Root
This commit is contained in:
parent
ce23efc5f6
commit
f87041bf3a
Notes:
github-actions[bot]
2024-11-15 13:50:17 +00:00
Author: https://github.com/shannonbooth
Commit: f87041bf3a
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/2345
1722 changed files with 9939 additions and 9906 deletions
|
@ -21,7 +21,7 @@ struct ReadableStreamReadResult {
|
|||
};
|
||||
|
||||
class ReadRequest : public JS::Cell {
|
||||
JS_CELL(ReadRequest, JS::Cell);
|
||||
GC_CELL(ReadRequest, JS::Cell);
|
||||
|
||||
public:
|
||||
virtual ~ReadRequest() = default;
|
||||
|
@ -32,20 +32,20 @@ public:
|
|||
};
|
||||
|
||||
class ReadLoopReadRequest final : public ReadRequest {
|
||||
JS_CELL(ReadLoopReadRequest, ReadRequest);
|
||||
JS_DECLARE_ALLOCATOR(ReadLoopReadRequest);
|
||||
GC_CELL(ReadLoopReadRequest, ReadRequest);
|
||||
GC_DECLARE_ALLOCATOR(ReadLoopReadRequest);
|
||||
|
||||
public:
|
||||
// successSteps, which is an algorithm accepting a byte sequence
|
||||
using SuccessSteps = JS::HeapFunction<void(ByteBuffer)>;
|
||||
using SuccessSteps = GC::Function<void(ByteBuffer)>;
|
||||
|
||||
// failureSteps, which is an algorithm accepting a JavaScript value
|
||||
using FailureSteps = JS::HeapFunction<void(JS::Value error)>;
|
||||
using FailureSteps = GC::Function<void(JS::Value error)>;
|
||||
|
||||
// AD-HOC: callback triggered on every chunk received from the stream.
|
||||
using ChunkSteps = JS::HeapFunction<void(ByteBuffer)>;
|
||||
using ChunkSteps = GC::Function<void(ByteBuffer)>;
|
||||
|
||||
ReadLoopReadRequest(JS::VM& vm, JS::Realm& realm, ReadableStreamDefaultReader& reader, JS::NonnullGCPtr<SuccessSteps> success_steps, JS::NonnullGCPtr<FailureSteps> failure_steps, JS::GCPtr<ChunkSteps> chunk_steps = {});
|
||||
ReadLoopReadRequest(JS::VM& vm, JS::Realm& realm, ReadableStreamDefaultReader& reader, GC::Ref<SuccessSteps> success_steps, GC::Ref<FailureSteps> failure_steps, GC::Ptr<ChunkSteps> chunk_steps = {});
|
||||
|
||||
virtual void on_chunk(JS::Value chunk) override;
|
||||
|
||||
|
@ -57,12 +57,12 @@ private:
|
|||
virtual void visit_edges(Visitor&) override;
|
||||
|
||||
JS::VM& m_vm;
|
||||
JS::NonnullGCPtr<JS::Realm> m_realm;
|
||||
JS::NonnullGCPtr<ReadableStreamDefaultReader> m_reader;
|
||||
GC::Ref<JS::Realm> m_realm;
|
||||
GC::Ref<ReadableStreamDefaultReader> m_reader;
|
||||
ByteBuffer m_bytes;
|
||||
JS::NonnullGCPtr<SuccessSteps> m_success_steps;
|
||||
JS::NonnullGCPtr<FailureSteps> m_failure_steps;
|
||||
JS::GCPtr<ChunkSteps> m_chunk_steps;
|
||||
GC::Ref<SuccessSteps> m_success_steps;
|
||||
GC::Ref<FailureSteps> m_failure_steps;
|
||||
GC::Ptr<ChunkSteps> m_chunk_steps;
|
||||
};
|
||||
|
||||
// https://streams.spec.whatwg.org/#readablestreamdefaultreader
|
||||
|
@ -70,23 +70,23 @@ class ReadableStreamDefaultReader final
|
|||
: public Bindings::PlatformObject
|
||||
, public ReadableStreamGenericReaderMixin {
|
||||
WEB_PLATFORM_OBJECT(ReadableStreamDefaultReader, Bindings::PlatformObject);
|
||||
JS_DECLARE_ALLOCATOR(ReadableStreamDefaultReader);
|
||||
GC_DECLARE_ALLOCATOR(ReadableStreamDefaultReader);
|
||||
|
||||
public:
|
||||
static WebIDL::ExceptionOr<JS::NonnullGCPtr<ReadableStreamDefaultReader>> construct_impl(JS::Realm&, JS::NonnullGCPtr<ReadableStream>);
|
||||
static WebIDL::ExceptionOr<GC::Ref<ReadableStreamDefaultReader>> construct_impl(JS::Realm&, GC::Ref<ReadableStream>);
|
||||
|
||||
virtual ~ReadableStreamDefaultReader() override = default;
|
||||
|
||||
JS::NonnullGCPtr<WebIDL::Promise> read();
|
||||
GC::Ref<WebIDL::Promise> read();
|
||||
|
||||
void read_a_chunk(Fetch::Infrastructure::IncrementalReadLoopReadRequest& read_request);
|
||||
void read_all_bytes(JS::NonnullGCPtr<ReadLoopReadRequest::SuccessSteps>, JS::NonnullGCPtr<ReadLoopReadRequest::FailureSteps>);
|
||||
void read_all_chunks(JS::NonnullGCPtr<ReadLoopReadRequest::ChunkSteps>, JS::NonnullGCPtr<ReadLoopReadRequest::SuccessSteps>, JS::NonnullGCPtr<ReadLoopReadRequest::FailureSteps>);
|
||||
JS::NonnullGCPtr<WebIDL::Promise> read_all_bytes_deprecated();
|
||||
void read_all_bytes(GC::Ref<ReadLoopReadRequest::SuccessSteps>, GC::Ref<ReadLoopReadRequest::FailureSteps>);
|
||||
void read_all_chunks(GC::Ref<ReadLoopReadRequest::ChunkSteps>, GC::Ref<ReadLoopReadRequest::SuccessSteps>, GC::Ref<ReadLoopReadRequest::FailureSteps>);
|
||||
GC::Ref<WebIDL::Promise> read_all_bytes_deprecated();
|
||||
|
||||
void release_lock();
|
||||
|
||||
SinglyLinkedList<JS::NonnullGCPtr<ReadRequest>>& read_requests() { return m_read_requests; }
|
||||
SinglyLinkedList<GC::Ref<ReadRequest>>& read_requests() { return m_read_requests; }
|
||||
|
||||
private:
|
||||
explicit ReadableStreamDefaultReader(JS::Realm&);
|
||||
|
@ -95,7 +95,7 @@ private:
|
|||
|
||||
virtual void visit_edges(Cell::Visitor&) override;
|
||||
|
||||
SinglyLinkedList<JS::NonnullGCPtr<ReadRequest>> m_read_requests;
|
||||
SinglyLinkedList<GC::Ref<ReadRequest>> m_read_requests;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue