mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-24 22:42:07 +00:00 
			
		
		
		
	 8d4d01d99a
			
		
	
	
		8d4d01d99a
		
	
	
	
	
		
			
			The HTMLMediaElement will need to stop fetching processes when its load algorithm is invoked while a fetch is ongoing. We don't have a way to really stop the process, due to the way it runs on nested deferred task invocations. So for now, this swaps the fetch callbacks (e.g. to process a fetch response) with empty callbacks.
		
			
				
	
	
		
			57 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | ||
|  * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
 | ||
|  *
 | ||
|  * SPDX-License-Identifier: BSD-2-Clause
 | ||
|  */
 | ||
| 
 | ||
| #include <LibJS/Heap/Heap.h>
 | ||
| #include <LibJS/Runtime/VM.h>
 | ||
| #include <LibWeb/Fetch/Infrastructure/FetchParams.h>
 | ||
| #include <LibWeb/Fetch/Infrastructure/HTTP/Responses.h>
 | ||
| 
 | ||
| namespace Web::Fetch::Infrastructure {
 | ||
| 
 | ||
| FetchParams::FetchParams(JS::NonnullGCPtr<Request> request, JS::NonnullGCPtr<FetchAlgorithms> algorithms, JS::NonnullGCPtr<FetchController> controller, JS::NonnullGCPtr<FetchTimingInfo> timing_info)
 | ||
|     : m_request(request)
 | ||
|     , m_algorithms(algorithms)
 | ||
|     , m_controller(controller)
 | ||
|     , m_timing_info(timing_info)
 | ||
| {
 | ||
|     m_controller->set_fetch_params({}, *this);
 | ||
| }
 | ||
| 
 | ||
| JS::NonnullGCPtr<FetchParams> FetchParams::create(JS::VM& vm, JS::NonnullGCPtr<Request> request, JS::NonnullGCPtr<FetchTimingInfo> timing_info)
 | ||
| {
 | ||
|     auto algorithms = Infrastructure::FetchAlgorithms::create(vm, {});
 | ||
|     auto controller = Infrastructure::FetchController::create(vm);
 | ||
|     return vm.heap().allocate_without_realm<FetchParams>(request, algorithms, controller, timing_info);
 | ||
| }
 | ||
| 
 | ||
| void FetchParams::visit_edges(JS::Cell::Visitor& visitor)
 | ||
| {
 | ||
|     Base::visit_edges(visitor);
 | ||
|     visitor.visit(m_request);
 | ||
|     visitor.visit(m_algorithms);
 | ||
|     visitor.visit(m_controller);
 | ||
|     visitor.visit(m_timing_info);
 | ||
|     if (m_task_destination.has<JS::NonnullGCPtr<JS::Object>>())
 | ||
|         visitor.visit(m_task_destination.get<JS::NonnullGCPtr<JS::Object>>());
 | ||
|     if (m_preloaded_response_candidate.has<JS::NonnullGCPtr<Response>>())
 | ||
|         visitor.visit(m_preloaded_response_candidate.get<JS::NonnullGCPtr<Response>>());
 | ||
| }
 | ||
| 
 | ||
| // https://fetch.spec.whatwg.org/#fetch-params-aborted
 | ||
| bool FetchParams::is_aborted() const
 | ||
| {
 | ||
|     // A fetch params fetchParams is aborted if its controller’s state is "aborted".
 | ||
|     return m_controller->state() == FetchController::State::Aborted;
 | ||
| }
 | ||
| 
 | ||
| // https://fetch.spec.whatwg.org/#fetch-params-canceled
 | ||
| bool FetchParams::is_canceled() const
 | ||
| {
 | ||
|     // A fetch params fetchParams is canceled if its controller’s state is "aborted" or "terminated".
 | ||
|     return m_controller->state() == FetchController::State::Aborted || m_controller->state() == FetchController::State::Terminated;
 | ||
| }
 | ||
| 
 | ||
| }
 |