mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 17:12:32 +00:00 
			
		
		
		
	 5aacec65ab
			
		
	
	
		5aacec65ab
		
	
	
	
	
		
			
			This isn't perfect (especially the global object situation in activate_event_handler), but I believe it's in a much more complete state now :^) This fixes the issue of crashing in prepare_for_ordinary_call with the `i < m_size` crash, as it now uses the IDL callback functions which requires the Environment Settings Object. The environment settings object for the callback is fetched at the time the callback is created, for example, WrapperGenerator gets the incumbent settings object for the callback at the time of wrapping. This allows us to remove passing in ScriptExecutionContext into EventTarget's constructor. With this, we can now drop ScriptExecutionContext.
		
			
				
	
	
		
			29 lines
		
	
	
	
		
			647 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
	
		
			647 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | ||
|  * Copyright (c) 2021, Luke Wilde <lukew@serenityos.org>
 | ||
|  *
 | ||
|  * SPDX-License-Identifier: BSD-2-Clause
 | ||
|  */
 | ||
| 
 | ||
| #include <LibWeb/DOM/AbortController.h>
 | ||
| #include <LibWeb/DOM/AbortSignal.h>
 | ||
| 
 | ||
| namespace Web::DOM {
 | ||
| 
 | ||
| // https://dom.spec.whatwg.org/#dom-abortcontroller-abortcontroller
 | ||
| AbortController::AbortController()
 | ||
|     : m_signal(AbortSignal::create())
 | ||
| {
 | ||
| }
 | ||
| 
 | ||
| AbortController::~AbortController()
 | ||
| {
 | ||
| }
 | ||
| 
 | ||
| // https://dom.spec.whatwg.org/#dom-abortcontroller-abort
 | ||
| void AbortController::abort(JS::Value reason)
 | ||
| {
 | ||
|     // The abort(reason) method steps are to signal abort on this’s signal with reason if it is given.
 | ||
|     m_signal->signal_abort(reason);
 | ||
| }
 | ||
| 
 | ||
| }
 |