mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 20:32:35 +00:00 
			
		
		
		
	 72c9f56c66
			
		
	
	
		72c9f56c66
		
	
	
	
	
		
			
			Stop worrying about tiny OOMs. Work towards #20449. While going through these, I also changed the function signature in many places where returning ThrowCompletionOr<T> is no longer necessary.
		
			
				
	
	
		
			44 lines
		
	
	
	
		
			997 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
	
		
			997 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Idan Horowitz <idan.horowitz@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibJS/Runtime/Set.h>
 | |
| 
 | |
| namespace JS {
 | |
| 
 | |
| NonnullGCPtr<Set> Set::create(Realm& realm)
 | |
| {
 | |
|     return realm.heap().allocate<Set>(realm, realm.intrinsics().set_prototype());
 | |
| }
 | |
| 
 | |
| Set::Set(Object& prototype)
 | |
|     : Object(ConstructWithPrototypeTag::Tag, prototype)
 | |
| {
 | |
| }
 | |
| 
 | |
| void Set::initialize(Realm& realm)
 | |
| {
 | |
|     m_values = Map::create(realm);
 | |
| }
 | |
| 
 | |
| NonnullGCPtr<Set> Set::copy() const
 | |
| {
 | |
|     auto& vm = this->vm();
 | |
|     auto& realm = *vm.current_realm();
 | |
|     // FIXME: This is very inefficient, but there's no better way to do this at the moment, as the underlying Map
 | |
|     //  implementation of m_values uses a non-copyable RedBlackTree.
 | |
|     auto result = Set::create(realm);
 | |
|     for (auto const& entry : *this)
 | |
|         result->set_add(entry.key);
 | |
|     return *result;
 | |
| }
 | |
| 
 | |
| void Set::visit_edges(Cell::Visitor& visitor)
 | |
| {
 | |
|     Base::visit_edges(visitor);
 | |
|     visitor.visit(m_values);
 | |
| }
 | |
| 
 | |
| }
 |