mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-31 13:20:59 +00:00 
			
		
		
		
	 7fad8c333d
			
		
	
	
		7fad8c333d
		
	
	
	
	
		
			
			This reduces the rebuilt targets when touching StructuredSerialize.h from ~1200 to ~400. The remaining are due to generated IPC headers.
		
			
				
	
	
		
			112 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Badge.h>
 | |
| #include <AK/HashMap.h>
 | |
| #include <LibGC/Function.h>
 | |
| #include <LibGC/Ptr.h>
 | |
| #include <LibJS/Forward.h>
 | |
| #include <LibJS/Heap/Cell.h>
 | |
| #include <LibJS/Runtime/VM.h>
 | |
| #include <LibWeb/Fetch/Infrastructure/FetchTimingInfo.h>
 | |
| #include <LibWeb/Forward.h>
 | |
| #include <LibWeb/HTML/EventLoop/Task.h>
 | |
| #include <LibWeb/HTML/StructuredSerializeTypes.h>
 | |
| 
 | |
| namespace Web::Fetch::Infrastructure {
 | |
| 
 | |
| // https://fetch.spec.whatwg.org/#fetch-controller
 | |
| class FetchController : public JS::Cell {
 | |
|     GC_CELL(FetchController, JS::Cell);
 | |
|     GC_DECLARE_ALLOCATOR(FetchController);
 | |
| 
 | |
| public:
 | |
|     enum class State {
 | |
|         Ongoing,
 | |
|         Terminated,
 | |
|         Aborted,
 | |
|     };
 | |
| 
 | |
|     [[nodiscard]] static GC::Ref<FetchController> create(JS::VM&);
 | |
| 
 | |
|     void set_full_timing_info(GC::Ref<FetchTimingInfo> full_timing_info) { m_full_timing_info = full_timing_info; }
 | |
|     void set_report_timing_steps(Function<void(JS::Object&)> report_timing_steps);
 | |
|     void set_next_manual_redirect_steps(Function<void()> next_manual_redirect_steps);
 | |
| 
 | |
|     [[nodiscard]] State state() const { return m_state; }
 | |
| 
 | |
|     void report_timing(JS::Object&) const;
 | |
|     void process_next_manual_redirect() const;
 | |
|     [[nodiscard]] GC::Ref<FetchTimingInfo> extract_full_timing_info() const;
 | |
|     void abort(JS::Realm&, Optional<JS::Value>);
 | |
|     JS::Value deserialize_a_serialized_abort_reason(JS::Realm&);
 | |
|     void terminate();
 | |
| 
 | |
|     void set_fetch_params(Badge<FetchParams>, GC::Ref<FetchParams> fetch_params) { m_fetch_params = fetch_params; }
 | |
| 
 | |
|     void stop_fetch();
 | |
| 
 | |
|     u64 next_fetch_task_id() { return m_next_fetch_task_id++; }
 | |
|     void fetch_task_queued(u64 fetch_task_id, HTML::TaskID event_id);
 | |
|     void fetch_task_complete(u64 fetch_task_id);
 | |
| 
 | |
| private:
 | |
|     FetchController();
 | |
| 
 | |
|     virtual void visit_edges(JS::Cell::Visitor&) override;
 | |
| 
 | |
|     // https://fetch.spec.whatwg.org/#fetch-controller-state
 | |
|     // state (default "ongoing")
 | |
|     //    "ongoing", "terminated", or "aborted"
 | |
|     State m_state { State::Ongoing };
 | |
| 
 | |
|     // https://fetch.spec.whatwg.org/#fetch-controller-full-timing-info
 | |
|     // full timing info (default null)
 | |
|     //    Null or a fetch timing info.
 | |
|     GC::Ptr<FetchTimingInfo> m_full_timing_info;
 | |
| 
 | |
|     // https://fetch.spec.whatwg.org/#fetch-controller-report-timing-steps
 | |
|     // report timing steps (default null)
 | |
|     //    Null or an algorithm accepting a global object.
 | |
|     GC::Ptr<GC::Function<void(JS::Object&)>> m_report_timing_steps;
 | |
| 
 | |
|     // https://fetch.spec.whatwg.org/#fetch-controller-report-timing-steps
 | |
|     // serialized abort reason (default null)
 | |
|     //     Null or a Record (result of StructuredSerialize).
 | |
|     Optional<HTML::SerializationRecord> m_serialized_abort_reason;
 | |
| 
 | |
|     // https://fetch.spec.whatwg.org/#fetch-controller-next-manual-redirect-steps
 | |
|     // next manual redirect steps (default null)
 | |
|     //     Null or an algorithm accepting nothing.
 | |
|     GC::Ptr<GC::Function<void()>> m_next_manual_redirect_steps;
 | |
| 
 | |
|     GC::Ptr<FetchParams> m_fetch_params;
 | |
| 
 | |
|     HashMap<u64, HTML::TaskID> m_ongoing_fetch_tasks;
 | |
|     u64 m_next_fetch_task_id { 0 };
 | |
| };
 | |
| 
 | |
| class FetchControllerHolder : public JS::Cell {
 | |
|     GC_CELL(FetchControllerHolder, JS::Cell);
 | |
|     GC_DECLARE_ALLOCATOR(FetchControllerHolder);
 | |
| 
 | |
| public:
 | |
|     static GC::Ref<FetchControllerHolder> create(JS::VM&);
 | |
| 
 | |
|     [[nodiscard]] GC::Ptr<FetchController> const& controller() const { return m_controller; }
 | |
|     void set_controller(GC::Ref<FetchController> controller) { m_controller = controller; }
 | |
| 
 | |
| private:
 | |
|     FetchControllerHolder();
 | |
| 
 | |
|     virtual void visit_edges(Cell::Visitor&) override;
 | |
| 
 | |
|     GC::Ptr<FetchController> m_controller;
 | |
| };
 | |
| 
 | |
| }
 |