mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-24 17:09:43 +00:00 
			
		
		
		
	Revert "LibJS: Use HashMap::ensure() in VM string cache helpers"
This reverts commit 5810ddf339.
Appears to have introduced flakiness on WPT.
	
	
This commit is contained in:
		
					parent
					
						
							
								0d62803f15
							
						
					
				
			
			
				commit
				
					
						7a2fe53c65
					
				
			
		
		
		Notes:
		
			github-actions[bot]
		
		2025-10-06 10:18:09 +00:00 
		
	
	Author: https://github.com/awesomekling
Commit: 7a2fe53c65
	
					 2 changed files with 13 additions and 10 deletions
				
			
		|  | @ -35,9 +35,12 @@ GC::Ref<PrimitiveString> PrimitiveString::create(VM& vm, Utf16String const& stri | |||
|     } | ||||
| 
 | ||||
|     auto& string_cache = vm.utf16_string_cache(); | ||||
|     return *string_cache.ensure(string, [&] { | ||||
|         return vm.heap().allocate<PrimitiveString>(string); | ||||
|     }); | ||||
|     if (auto it = string_cache.find(string); it != string_cache.end()) | ||||
|         return *it->value; | ||||
| 
 | ||||
|     auto new_string = vm.heap().allocate<PrimitiveString>(string); | ||||
|     string_cache.set(move(string), new_string); | ||||
|     return *new_string; | ||||
| } | ||||
| 
 | ||||
| GC::Ref<PrimitiveString> PrimitiveString::create(VM& vm, Utf16View const& string) | ||||
|  | @ -64,9 +67,9 @@ GC::Ref<PrimitiveString> PrimitiveString::create(VM& vm, String const& string) | |||
|     if (auto it = string_cache.find(string); it != string_cache.end()) | ||||
|         return *it->value; | ||||
| 
 | ||||
|     return string_cache.ensure(string, [&] { | ||||
|         return vm.heap().allocate<PrimitiveString>(string); | ||||
|     }); | ||||
|     auto new_string = vm.heap().allocate<PrimitiveString>(string); | ||||
|     string_cache.set(move(string), new_string); | ||||
|     return *new_string; | ||||
| } | ||||
| 
 | ||||
| GC::Ref<PrimitiveString> PrimitiveString::create(VM& vm, StringView string) | ||||
|  |  | |||
|  | @ -75,12 +75,12 @@ public: | |||
|     JS_ENUMERATE_WELL_KNOWN_SYMBOLS | ||||
| #undef __JS_ENUMERATE | ||||
| 
 | ||||
|     HashMap<String, GC::Ref<PrimitiveString>>& string_cache() | ||||
|     HashMap<String, GC::Ptr<PrimitiveString>>& string_cache() | ||||
|     { | ||||
|         return m_string_cache; | ||||
|     } | ||||
| 
 | ||||
|     HashMap<Utf16String, GC::Ref<PrimitiveString>>& utf16_string_cache() | ||||
|     HashMap<Utf16String, GC::Ptr<PrimitiveString>>& utf16_string_cache() | ||||
|     { | ||||
|         return m_utf16_string_cache; | ||||
|     } | ||||
|  | @ -323,8 +323,8 @@ private: | |||
| 
 | ||||
|     void run_queued_promise_jobs_impl(); | ||||
| 
 | ||||
|     HashMap<String, GC::Ref<PrimitiveString>> m_string_cache; | ||||
|     HashMap<Utf16String, GC::Ref<PrimitiveString>> m_utf16_string_cache; | ||||
|     HashMap<String, GC::Ptr<PrimitiveString>> m_string_cache; | ||||
|     HashMap<Utf16String, GC::Ptr<PrimitiveString>> m_utf16_string_cache; | ||||
| 
 | ||||
|     static constexpr size_t numeric_string_cache_size = 1000; | ||||
|     AK::Array<GC::Ptr<PrimitiveString>, numeric_string_cache_size> m_numeric_string_cache; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue