MeshLib C++ Docs
Loading...
Searching...
No Matches
MRHeapBytes.h
Go to the documentation of this file.
1#pragma once
2
3#include "MRMeshFwd.h"
4#include <vector>
5#include <memory>
6
7namespace MR
8{
9
12
14template<typename T>
15[[nodiscard]] inline size_t heapBytes( const std::vector<T> & vec )
16{
17 constexpr bool hasHeapBytes = requires( const T& t ) { t.heapBytes(); };
18 if constexpr ( hasHeapBytes )
19 {
20 size_t res = vec.capacity() * sizeof( T );
21 for ( const T & t : vec )
22 res += t.heapBytes();
23 return res;
24 }
25 else
26 {
27 return vec.capacity() * sizeof( T );
28 }
29}
30
31template<typename T, typename U>
32[[nodiscard]] inline size_t heapBytes( const Vector<T, U>& vec )
33{
34 constexpr bool hasHeapBytes = requires( const T & t ) { t.heapBytes(); };
35 if constexpr ( hasHeapBytes )
36 {
37 size_t res = vec.size() * sizeof( T );
38 for ( const T & t : vec )
39 res += t.heapBytes();
40 return res;
41 }
42 else
43 {
44 return vec.size() * sizeof( T );
45 }
46}
47
49template<typename T>
50[[nodiscard]] inline size_t heapBytes( const std::unique_ptr<T> & ptr )
51{
52 if ( !ptr )
53 return 0;
54 return sizeof( T ) + ptr->heapBytes();
55}
56
58template<typename T>
59[[nodiscard]] inline size_t heapBytes( const std::shared_ptr<T> & ptr )
60{
61 if ( !ptr )
62 return 0;
63 return sizeof( T ) + ptr->heapBytes();
64}
65
67template<typename T>
68[[nodiscard]] inline size_t heapBytes( const std::function<T> & )
69{
70 return 0;
71}
72
74template<typename ...Ts>
75[[nodiscard]] inline size_t heapBytes( const phmap::flat_hash_map<Ts...>& hashMap )
76{
77 // from parallel_hashmap/phmap.h:
78 // The control state and slot array are stored contiguously in a shared heap
79 // allocation. The layout of this allocation is: `capacity()` control bytes,
80 // one sentinel control byte, `Group::kWidth - 1` cloned control bytes,
81 // <possible padding>, `capacity()` slots
82 const auto cap = hashMap.capacity();
83 constexpr size_t kWidth = 16; // the usage of phmap::priv::Group::kWidth here will require inclusion of phmap.h
84 return cap + kWidth + cap * sizeof( typename phmap::flat_hash_map<Ts...>::slot_type );
85}
86
88
89} // namespace MR
std::vector<T>-like container that requires specific indexing type,
Definition MRMesh/MRVector.h:20
std::size_t size() const
Definition MRMesh/MRVector.h:42
size_t heapBytes(const std::vector< T > &vec)
returns the amount of memory given vector occupies on heap
Definition MRHeapBytes.h:15