mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-31 13:20:59 +00:00 
			
		
		
		
	 f87041bf3a
			
		
	
	
		f87041bf3a
		
	
	
	
	
		
			
			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
		
			
				
	
	
		
			91 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
	
		
			3 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>
 | |
| 
 | |
| 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 const&)> 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&) const;
 | |
|     void process_next_manual_redirect() const;
 | |
|     [[nodiscard]] GC::Ref<FetchTimingInfo> extract_full_timing_info() const;
 | |
|     void abort(JS::Realm&, Optional<JS::Value>);
 | |
|     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 const&)>> m_report_timing_steps;
 | |
| 
 | |
|     // https://fetch.spec.whatwg.org/#fetch-controller-report-timing-steps
 | |
|     // FIXME: serialized abort reason (default null)
 | |
|     //     Null or a Record (result of StructuredSerialize).
 | |
| 
 | |
|     // 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 };
 | |
| };
 | |
| 
 | |
| }
 |