mirror of
				https://github.com/topjohnwu/Magisk.git
				synced 2025-10-25 01:40:21 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <map>
 | |
| #include <parallel_hashmap/phmap.h>
 | |
| 
 | |
| #include <utils.hpp>
 | |
| 
 | |
| namespace jni_hook {
 | |
| 
 | |
| struct memory_block {
 | |
|     static void *allocate(size_t sz);
 | |
|     static void deallocate(void *, size_t) { /* Monotonic increase */ }
 | |
|     static void release();
 | |
| };
 | |
| 
 | |
| template<class T>
 | |
| using allocator = stateless_allocator<T, memory_block>;
 | |
| 
 | |
| using string = std::basic_string<char, std::char_traits<char>, allocator<char>>;
 | |
| 
 | |
| // Use node_hash_map since it will use less memory because we are using a monotonic allocator
 | |
| template<class K, class V>
 | |
| using hash_map = phmap::node_hash_map<K, V,
 | |
|     phmap::priv::hash_default_hash<K>,
 | |
|     phmap::priv::hash_default_eq<K>,
 | |
|     allocator<std::pair<const K, V>>
 | |
| >;
 | |
| 
 | |
| template<class K, class V>
 | |
| using tree_map = std::map<K, V,
 | |
|     std::less<K>,
 | |
|     allocator<std::pair<const K, V>>
 | |
| >;
 | |
| 
 | |
| } // namespace jni_hook
 | |
| 
 | |
| // Provide heterogeneous lookup for jni_hook::string
 | |
| namespace phmap::priv {
 | |
| template <> struct HashEq<jni_hook::string> : StringHashEqT<char> {};
 | |
| } // namespace phmap::priv
 | 
