mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 01:42:06 +00:00 
			
		
		
		
	 2d5bee256e
			
		
	
	
		2d5bee256e
		
	
	
	
	
		
			
			Get rid of the bespoke NavigatorObject class and use the modern IDL strategies for creating platform objects to re-implement Navigator and its associcated mixin interfaces. While we're here, implement it in a way that brings WorkerNavigator up to spec :^)
		
			
				
	
	
		
			27 lines
		
	
	
	
		
			737 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
	
		
			737 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibJS/Heap/Heap.h>
 | |
| #include <LibWeb/Bindings/Intrinsics.h>
 | |
| #include <LibWeb/HTML/WorkerGlobalScope.h>
 | |
| #include <LibWeb/HTML/WorkerNavigator.h>
 | |
| 
 | |
| namespace Web::HTML {
 | |
| 
 | |
| JS::NonnullGCPtr<WorkerNavigator> WorkerNavigator::create(WorkerGlobalScope& global_scope)
 | |
| {
 | |
|     return *global_scope.heap().allocate<WorkerNavigator>(global_scope.realm(), global_scope);
 | |
| }
 | |
| 
 | |
| WorkerNavigator::WorkerNavigator(WorkerGlobalScope& global_scope)
 | |
|     : PlatformObject(global_scope.realm())
 | |
| {
 | |
|     set_prototype(&Bindings::cached_web_prototype(global_scope.realm(), "WorkerNavigator"));
 | |
| }
 | |
| 
 | |
| WorkerNavigator::~WorkerNavigator() = default;
 | |
| 
 | |
| }
 |