mirror of
https://github.com/topjohnwu/Magisk.git
synced 2024-12-23 08:27:40 +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
|