/tmp/bitcoin/src/prevector.h
Line | Count | Source |
1 | | // Copyright (c) 2015-present The Bitcoin Core developers |
2 | | // Distributed under the MIT software license, see the accompanying |
3 | | // file COPYING or http://www.opensource.org/licenses/mit-license.php. |
4 | | |
5 | | #ifndef BITCOIN_PREVECTOR_H |
6 | | #define BITCOIN_PREVECTOR_H |
7 | | |
8 | | #include <algorithm> |
9 | | #include <cassert> |
10 | | #include <cstddef> |
11 | | #include <cstdint> |
12 | | #include <cstdlib> |
13 | | #include <cstring> |
14 | | #include <iterator> |
15 | | #include <type_traits> |
16 | | #include <utility> |
17 | | |
18 | | /** Implements a drop-in replacement for std::vector<T> which stores up to N |
19 | | * elements directly (without heap allocation). The types Size and Diff are |
20 | | * used to store element counts, and can be any unsigned + signed type. |
21 | | * |
22 | | * Storage layout is either: |
23 | | * - Direct allocation: |
24 | | * - Size _size: the number of used elements (between 0 and N) |
25 | | * - T direct[N]: an array of N elements of type T |
26 | | * (only the first _size are initialized). |
27 | | * - Indirect allocation: |
28 | | * - Size _size: the number of used elements plus N + 1 |
29 | | * - Size capacity: the number of allocated elements |
30 | | * - T* indirect: a pointer to an array of capacity elements of type T |
31 | | * (only the first _size are initialized). |
32 | | * |
33 | | * The data type T must be movable by memmove/realloc(). Once we switch to C++, |
34 | | * move constructors can be used instead. |
35 | | */ |
36 | | template<unsigned int N, typename T, typename Size = uint32_t, typename Diff = int32_t> |
37 | | class prevector { |
38 | | static_assert(std::is_trivially_copyable_v<T>); |
39 | | |
40 | | public: |
41 | | static constexpr unsigned int STATIC_SIZE{N}; |
42 | | |
43 | | typedef Size size_type; |
44 | | typedef Diff difference_type; |
45 | | typedef T value_type; |
46 | | typedef value_type& reference; |
47 | | typedef const value_type& const_reference; |
48 | | typedef value_type* pointer; |
49 | | typedef const value_type* const_pointer; |
50 | | |
51 | | class iterator { |
52 | | T* ptr{}; |
53 | | public: |
54 | | typedef Diff difference_type; |
55 | | typedef T* pointer; |
56 | | typedef T& reference; |
57 | | using element_type = T; |
58 | | using iterator_category = std::contiguous_iterator_tag; |
59 | | iterator() = default; |
60 | 86.0M | iterator(T* ptr_) : ptr(ptr_) {}prevector<36u, unsigned char, unsigned int, int>::iterator::iterator(unsigned char*) Line | Count | Source | 60 | 69.5M | iterator(T* ptr_) : ptr(ptr_) {} |
prevector<16u, unsigned char, unsigned int, int>::iterator::iterator(unsigned char*) Line | Count | Source | 60 | 1.97M | iterator(T* ptr_) : ptr(ptr_) {} |
prevector<8u, int, unsigned int, int>::iterator::iterator(int*) Line | Count | Source | 60 | 14.4M | iterator(T* ptr_) : ptr(ptr_) {} |
Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::iterator::iterator(unsigned char*) prevector<35u, unsigned char, unsigned int, int>::iterator::iterator(unsigned char*) Line | Count | Source | 60 | 760 | iterator(T* ptr_) : ptr(ptr_) {} |
|
61 | 144M | T& operator*() const { return *ptr; }prevector<36u, unsigned char, unsigned int, int>::iterator::operator*() const Line | Count | Source | 61 | 128M | T& operator*() const { return *ptr; } |
prevector<16u, unsigned char, unsigned int, int>::iterator::operator*() const Line | Count | Source | 61 | 3.94M | T& operator*() const { return *ptr; } |
prevector<8u, int, unsigned int, int>::iterator::operator*() const Line | Count | Source | 61 | 11.3M | T& operator*() const { return *ptr; } |
Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::iterator::operator*() const prevector<35u, unsigned char, unsigned int, int>::iterator::operator*() const Line | Count | Source | 61 | 760 | T& operator*() const { return *ptr; } |
|
62 | 35.6k | T* operator->() const { return ptr; }Unexecuted instantiation: prevector<16u, unsigned char, unsigned int, int>::iterator::operator->() const Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::iterator::operator->() const prevector<36u, unsigned char, unsigned int, int>::iterator::operator->() const Line | Count | Source | 62 | 35.6k | T* operator->() const { return ptr; } |
Unexecuted instantiation: prevector<35u, unsigned char, unsigned int, int>::iterator::operator->() const |
63 | 2.06M | T& operator[](size_type pos) const { return ptr[pos]; } |
64 | 41.8M | iterator& operator++() { ptr++; return *this; }prevector<36u, unsigned char, unsigned int, int>::iterator::operator++() Line | Count | Source | 64 | 37.7M | iterator& operator++() { ptr++; return *this; } |
prevector<8u, int, unsigned int, int>::iterator::operator++() Line | Count | Source | 64 | 4.12M | iterator& operator++() { ptr++; return *this; } |
|
65 | 4.12M | iterator& operator--() { ptr--; return *this; } |
66 | | iterator operator++(int) { iterator copy(*this); ++(*this); return copy; } |
67 | | iterator operator--(int) { iterator copy(*this); --(*this); return copy; } |
68 | 25.7M | difference_type friend operator-(iterator a, iterator b) { return (&(*a) - &(*b)); }operator-(prevector<36u, unsigned char, unsigned int, int>::iterator, prevector<36u, unsigned char, unsigned int, int>::iterator) Line | Count | Source | 68 | 24.7M | difference_type friend operator-(iterator a, iterator b) { return (&(*a) - &(*b)); } |
operator-(prevector<16u, unsigned char, unsigned int, int>::iterator, prevector<16u, unsigned char, unsigned int, int>::iterator) Line | Count | Source | 68 | 658k | difference_type friend operator-(iterator a, iterator b) { return (&(*a) - &(*b)); } |
operator-(prevector<8u, int, unsigned int, int>::iterator, prevector<8u, int, unsigned int, int>::iterator) Line | Count | Source | 68 | 391k | difference_type friend operator-(iterator a, iterator b) { return (&(*a) - &(*b)); } |
Unexecuted instantiation: operator-(prevector<33u, unsigned char, unsigned int, int>::iterator, prevector<33u, unsigned char, unsigned int, int>::iterator) operator-(prevector<35u, unsigned char, unsigned int, int>::iterator, prevector<35u, unsigned char, unsigned int, int>::iterator) Line | Count | Source | 68 | 380 | difference_type friend operator-(iterator a, iterator b) { return (&(*a) - &(*b)); } |
|
69 | 4.27M | iterator operator+(size_type n) const { return iterator(ptr + n); } |
70 | | iterator friend operator+(size_type n, iterator x) { return x + n; } |
71 | | iterator& operator+=(size_type n) { ptr += n; return *this; } |
72 | 2.06M | iterator operator-(size_type n) const { return iterator(ptr - n); } |
73 | | iterator& operator-=(size_type n) { ptr -= n; return *this; } |
74 | 44.8M | bool operator==(iterator x) const { return ptr == x.ptr; }prevector<36u, unsigned char, unsigned int, int>::iterator::operator==(prevector<36u, unsigned char, unsigned int, int>::iterator) const Line | Count | Source | 74 | 37.8M | bool operator==(iterator x) const { return ptr == x.ptr; } |
prevector<8u, int, unsigned int, int>::iterator::operator==(prevector<8u, int, unsigned int, int>::iterator) const Line | Count | Source | 74 | 6.99M | bool operator==(iterator x) const { return ptr == x.ptr; } |
|
75 | 0 | auto operator<=>(iterator x) const { return ptr <=> x.ptr; }Unexecuted instantiation: prevector<16u, unsigned char, unsigned int, int>::iterator::operator<=>(prevector<16u, unsigned char, unsigned int, int>::iterator) const Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::iterator::operator<=>(prevector<33u, unsigned char, unsigned int, int>::iterator) const Unexecuted instantiation: prevector<36u, unsigned char, unsigned int, int>::iterator::operator<=>(prevector<36u, unsigned char, unsigned int, int>::iterator) const Unexecuted instantiation: prevector<8u, int, unsigned int, int>::iterator::operator<=>(prevector<8u, int, unsigned int, int>::iterator) const Unexecuted instantiation: prevector<35u, unsigned char, unsigned int, int>::iterator::operator<=>(prevector<35u, unsigned char, unsigned int, int>::iterator) const |
76 | | }; |
77 | | |
78 | | class const_iterator { |
79 | | const T* ptr{}; |
80 | | public: |
81 | | typedef Diff difference_type; |
82 | | typedef const T* pointer; |
83 | | typedef const T& reference; |
84 | | using element_type = const T; |
85 | | using iterator_category = std::contiguous_iterator_tag; |
86 | | const_iterator() = default; |
87 | 1.55G | const_iterator(const T* ptr_) : ptr(ptr_) {}prevector<16u, unsigned char, unsigned int, int>::const_iterator::const_iterator(unsigned char const*) Line | Count | Source | 87 | 11.0M | const_iterator(const T* ptr_) : ptr(ptr_) {} |
prevector<36u, unsigned char, unsigned int, int>::const_iterator::const_iterator(unsigned char const*) Line | Count | Source | 87 | 1.54G | const_iterator(const T* ptr_) : ptr(ptr_) {} |
prevector<8u, int, unsigned int, int>::const_iterator::const_iterator(int const*) Line | Count | Source | 87 | 3.76M | const_iterator(const T* ptr_) : ptr(ptr_) {} |
|
88 | 739k | const_iterator(iterator x) : ptr(&(*x)) {} |
89 | 17.8G | const T& operator*() const { return *ptr; }prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator*() const Line | Count | Source | 89 | 17.8G | const T& operator*() const { return *ptr; } |
prevector<16u, unsigned char, unsigned int, int>::const_iterator::operator*() const Line | Count | Source | 89 | 19.1M | const T& operator*() const { return *ptr; } |
prevector<8u, int, unsigned int, int>::const_iterator::operator*() const Line | Count | Source | 89 | 16.6M | const T& operator*() const { return *ptr; } |
|
90 | 3.91M | const T* operator->() const { return ptr; }prevector<16u, unsigned char, unsigned int, int>::const_iterator::operator->() const Line | Count | Source | 90 | 480 | const T* operator->() const { return ptr; } |
prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator->() const Line | Count | Source | 90 | 3.91M | const T* operator->() const { return ptr; } |
|
91 | 179k | const T& operator[](size_type pos) const { return ptr[pos]; } |
92 | 16.1G | const_iterator& operator++() { ptr++; return *this; }prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator++() Line | Count | Source | 92 | 16.0G | const_iterator& operator++() { ptr++; return *this; } |
prevector<16u, unsigned char, unsigned int, int>::const_iterator::operator++() Line | Count | Source | 92 | 13.7M | const_iterator& operator++() { ptr++; return *this; } |
prevector<8u, int, unsigned int, int>::const_iterator::operator++() Line | Count | Source | 92 | 12.4M | const_iterator& operator++() { ptr++; return *this; } |
|
93 | 4.12M | const_iterator& operator--() { ptr--; return *this; }prevector<8u, int, unsigned int, int>::const_iterator::operator--() Line | Count | Source | 93 | 4.12M | const_iterator& operator--() { ptr--; return *this; } |
Unexecuted instantiation: prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator--() |
94 | 669M | const_iterator operator++(int) { const_iterator copy(*this); ++(*this); return copy; } |
95 | | const_iterator operator--(int) { const_iterator copy(*this); --(*this); return copy; } |
96 | 719M | difference_type friend operator-(const_iterator a, const_iterator b) { return (&(*a) - &(*b)); }operator-(prevector<36u, unsigned char, unsigned int, int>::const_iterator, prevector<36u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 96 | 718M | difference_type friend operator-(const_iterator a, const_iterator b) { return (&(*a) - &(*b)); } |
operator-(prevector<16u, unsigned char, unsigned int, int>::const_iterator, prevector<16u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 96 | 470k | difference_type friend operator-(const_iterator a, const_iterator b) { return (&(*a) - &(*b)); } |
operator-(prevector<8u, int, unsigned int, int>::const_iterator, prevector<8u, int, unsigned int, int>::const_iterator) Line | Count | Source | 96 | 1.07M | difference_type friend operator-(const_iterator a, const_iterator b) { return (&(*a) - &(*b)); } |
|
97 | 6.12M | const_iterator operator+(size_type n) const { return const_iterator(ptr + n); } |
98 | | const_iterator friend operator+(size_type n, const_iterator x) { return x + n; } |
99 | 9.46M | const_iterator& operator+=(size_type n) { ptr += n; return *this; } |
100 | 590 | const_iterator operator-(size_type n) const { return const_iterator(ptr - n); } |
101 | | const_iterator& operator-=(size_type n) { ptr -= n; return *this; } |
102 | 15.3G | bool operator==(const_iterator x) const { return ptr == x.ptr; }prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator==(prevector<36u, unsigned char, unsigned int, int>::const_iterator) const Line | Count | Source | 102 | 15.3G | bool operator==(const_iterator x) const { return ptr == x.ptr; } |
prevector<16u, unsigned char, unsigned int, int>::const_iterator::operator==(prevector<16u, unsigned char, unsigned int, int>::const_iterator) const Line | Count | Source | 102 | 16.4M | bool operator==(const_iterator x) const { return ptr == x.ptr; } |
prevector<8u, int, unsigned int, int>::const_iterator::operator==(prevector<8u, int, unsigned int, int>::const_iterator) const Line | Count | Source | 102 | 11.7M | bool operator==(const_iterator x) const { return ptr == x.ptr; } |
|
103 | 1.33G | auto operator<=>(const_iterator x) const { return ptr <=> x.ptr; }Unexecuted instantiation: prevector<16u, unsigned char, unsigned int, int>::const_iterator::operator<=>(prevector<16u, unsigned char, unsigned int, int>::const_iterator) const prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator<=>(prevector<36u, unsigned char, unsigned int, int>::const_iterator) const Line | Count | Source | 103 | 1.33G | auto operator<=>(const_iterator x) const { return ptr <=> x.ptr; } |
Unexecuted instantiation: prevector<8u, int, unsigned int, int>::const_iterator::operator<=>(prevector<8u, int, unsigned int, int>::const_iterator) const |
104 | | }; |
105 | | |
106 | | private: |
107 | | #pragma pack(push, 1) |
108 | | union direct_or_indirect { |
109 | | char direct[sizeof(T) * N]; |
110 | | struct { |
111 | | char* indirect; |
112 | | size_type capacity; |
113 | | } indirect_contents; |
114 | | }; |
115 | | #pragma pack(pop) |
116 | | alignas(char*) direct_or_indirect _union = {}; |
117 | | size_type _size = 0; |
118 | | |
119 | | static_assert(alignof(char*) % alignof(size_type) == 0 && sizeof(char*) % alignof(size_type) == 0, "size_type cannot have more restrictive alignment requirement than pointer"); |
120 | | static_assert(alignof(char*) % alignof(T) == 0, "value_type T cannot have more restrictive alignment requirement than pointer"); |
121 | | |
122 | 117M | T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; }prevector<36u, unsigned char, unsigned int, int>::direct_ptr(int) Line | Count | Source | 122 | 106M | T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; } |
prevector<16u, unsigned char, unsigned int, int>::direct_ptr(int) Line | Count | Source | 122 | 8.04M | T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; } |
prevector<33u, unsigned char, unsigned int, int>::direct_ptr(int) Line | Count | Source | 122 | 684k | T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; } |
prevector<8u, int, unsigned int, int>::direct_ptr(int) Line | Count | Source | 122 | 2.94M | T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; } |
prevector<4u, Network, unsigned int, int>::direct_ptr(int) Line | Count | Source | 122 | 94 | T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; } |
prevector<35u, unsigned char, unsigned int, int>::direct_ptr(int) Line | Count | Source | 122 | 1.52k | T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; } |
|
123 | 280M | const T* direct_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.direct) + pos; }prevector<36u, unsigned char, unsigned int, int>::direct_ptr(int) const Line | Count | Source | 123 | 256M | const T* direct_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.direct) + pos; } |
prevector<16u, unsigned char, unsigned int, int>::direct_ptr(int) const Line | Count | Source | 123 | 22.2M | const T* direct_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.direct) + pos; } |
prevector<8u, int, unsigned int, int>::direct_ptr(int) const Line | Count | Source | 123 | 1.60M | const T* direct_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.direct) + pos; } |
prevector<33u, unsigned char, unsigned int, int>::direct_ptr(int) const Line | Count | Source | 123 | 86.6k | const T* direct_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.direct) + pos; } |
|
124 | 34.8M | T* indirect_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.indirect_contents.indirect) + pos; }prevector<36u, unsigned char, unsigned int, int>::indirect_ptr(int) Line | Count | Source | 124 | 20.4M | T* indirect_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.indirect_contents.indirect) + pos; } |
prevector<16u, unsigned char, unsigned int, int>::indirect_ptr(int) Line | Count | Source | 124 | 2.31k | T* indirect_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.indirect_contents.indirect) + pos; } |
Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::indirect_ptr(int) prevector<8u, int, unsigned int, int>::indirect_ptr(int) Line | Count | Source | 124 | 14.3M | T* indirect_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.indirect_contents.indirect) + pos; } |
Unexecuted instantiation: prevector<4u, Network, unsigned int, int>::indirect_ptr(int) Unexecuted instantiation: prevector<35u, unsigned char, unsigned int, int>::indirect_ptr(int) |
125 | 1.32G | const T* indirect_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.indirect_contents.indirect) + pos; }prevector<36u, unsigned char, unsigned int, int>::indirect_ptr(int) const Line | Count | Source | 125 | 1.31G | const T* indirect_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.indirect_contents.indirect) + pos; } |
prevector<16u, unsigned char, unsigned int, int>::indirect_ptr(int) const Line | Count | Source | 125 | 5.71k | const T* indirect_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.indirect_contents.indirect) + pos; } |
prevector<8u, int, unsigned int, int>::indirect_ptr(int) const Line | Count | Source | 125 | 2.15M | const T* indirect_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.indirect_contents.indirect) + pos; } |
Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::indirect_ptr(int) const |
126 | 4.04G | bool is_direct() const { return _size <= N; }prevector<36u, unsigned char, unsigned int, int>::is_direct() const Line | Count | Source | 126 | 3.95G | bool is_direct() const { return _size <= N; } |
prevector<16u, unsigned char, unsigned int, int>::is_direct() const Line | Count | Source | 126 | 58.8M | bool is_direct() const { return _size <= N; } |
prevector<33u, unsigned char, unsigned int, int>::is_direct() const Line | Count | Source | 126 | 1.89M | bool is_direct() const { return _size <= N; } |
prevector<8u, int, unsigned int, int>::is_direct() const Line | Count | Source | 126 | 29.1M | bool is_direct() const { return _size <= N; } |
prevector<4u, Network, unsigned int, int>::is_direct() const Line | Count | Source | 126 | 376 | bool is_direct() const { return _size <= N; } |
prevector<35u, unsigned char, unsigned int, int>::is_direct() const Line | Count | Source | 126 | 3.61k | bool is_direct() const { return _size <= N; } |
|
127 | | |
128 | 124M | void change_capacity(size_type new_capacity) { |
129 | 124M | if (new_capacity <= N) { |
130 | 122M | if (!is_direct()) { |
131 | 44.7k | T* indirect = indirect_ptr(0); |
132 | 44.7k | T* src = indirect; |
133 | 44.7k | T* dst = direct_ptr(0); |
134 | 44.7k | memcpy(dst, src, size() * sizeof(T)); |
135 | 44.7k | free(indirect); |
136 | 44.7k | _size -= N + 1; |
137 | 44.7k | } |
138 | 122M | } else { |
139 | 2.41M | if (!is_direct()) { |
140 | | /* FIXME: Because malloc/realloc here won't call new_handler if allocation fails, assert |
141 | | success. These should instead use an allocator or new/delete so that handlers |
142 | | are called as necessary, but performance would be slightly degraded by doing so. */ |
143 | 83.0k | _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity)); |
144 | 83.0k | assert(_union.indirect_contents.indirect); |
145 | 83.0k | _union.indirect_contents.capacity = new_capacity; |
146 | 2.32M | } else { |
147 | 2.32M | char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity)); |
148 | 2.32M | assert(new_indirect); |
149 | 2.32M | T* src = direct_ptr(0); |
150 | 2.32M | T* dst = reinterpret_cast<T*>(new_indirect); |
151 | 2.32M | memcpy(dst, src, size() * sizeof(T)); |
152 | 2.32M | _union.indirect_contents.indirect = new_indirect; |
153 | 2.32M | _union.indirect_contents.capacity = new_capacity; |
154 | 2.32M | _size += N + 1; |
155 | 2.32M | } |
156 | 2.41M | } |
157 | 124M | } prevector<36u, unsigned char, unsigned int, int>::change_capacity(unsigned int) Line | Count | Source | 128 | 118M | void change_capacity(size_type new_capacity) { | 129 | 118M | if (new_capacity <= N) { | 130 | 116M | if (!is_direct()) { | 131 | 44.0k | T* indirect = indirect_ptr(0); | 132 | 44.0k | T* src = indirect; | 133 | 44.0k | T* dst = direct_ptr(0); | 134 | 44.0k | memcpy(dst, src, size() * sizeof(T)); | 135 | 44.0k | free(indirect); | 136 | 44.0k | _size -= N + 1; | 137 | 44.0k | } | 138 | 116M | } else { | 139 | 2.20M | if (!is_direct()) { | 140 | | /* FIXME: Because malloc/realloc here won't call new_handler if allocation fails, assert | 141 | | success. These should instead use an allocator or new/delete so that handlers | 142 | | are called as necessary, but performance would be slightly degraded by doing so. */ | 143 | 78.9k | _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity)); | 144 | 78.9k | assert(_union.indirect_contents.indirect); | 145 | 78.9k | _union.indirect_contents.capacity = new_capacity; | 146 | 2.12M | } else { | 147 | 2.12M | char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity)); | 148 | 2.12M | assert(new_indirect); | 149 | 2.12M | T* src = direct_ptr(0); | 150 | 2.12M | T* dst = reinterpret_cast<T*>(new_indirect); | 151 | 2.12M | memcpy(dst, src, size() * sizeof(T)); | 152 | 2.12M | _union.indirect_contents.indirect = new_indirect; | 153 | 2.12M | _union.indirect_contents.capacity = new_capacity; | 154 | 2.12M | _size += N + 1; | 155 | 2.12M | } | 156 | 2.20M | } | 157 | 118M | } |
prevector<16u, unsigned char, unsigned int, int>::change_capacity(unsigned int) Line | Count | Source | 128 | 5.40M | void change_capacity(size_type new_capacity) { | 129 | 5.40M | if (new_capacity <= N) { | 130 | 5.40M | if (!is_direct()) { | 131 | 0 | T* indirect = indirect_ptr(0); | 132 | 0 | T* src = indirect; | 133 | 0 | T* dst = direct_ptr(0); | 134 | 0 | memcpy(dst, src, size() * sizeof(T)); | 135 | 0 | free(indirect); | 136 | 0 | _size -= N + 1; | 137 | 0 | } | 138 | 5.40M | } else { | 139 | 1.98k | if (!is_direct()) { | 140 | | /* FIXME: Because malloc/realloc here won't call new_handler if allocation fails, assert | 141 | | success. These should instead use an allocator or new/delete so that handlers | 142 | | are called as necessary, but performance would be slightly degraded by doing so. */ | 143 | 0 | _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity)); | 144 | 0 | assert(_union.indirect_contents.indirect); | 145 | 0 | _union.indirect_contents.capacity = new_capacity; | 146 | 1.98k | } else { | 147 | 1.98k | char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity)); | 148 | 1.98k | assert(new_indirect); | 149 | 1.99k | T* src = direct_ptr(0); | 150 | 1.99k | T* dst = reinterpret_cast<T*>(new_indirect); | 151 | 1.99k | memcpy(dst, src, size() * sizeof(T)); | 152 | 1.99k | _union.indirect_contents.indirect = new_indirect; | 153 | 1.99k | _union.indirect_contents.capacity = new_capacity; | 154 | 1.99k | _size += N + 1; | 155 | 1.99k | } | 156 | 1.98k | } | 157 | 5.40M | } |
prevector<33u, unsigned char, unsigned int, int>::change_capacity(unsigned int) Line | Count | Source | 128 | 86.6k | void change_capacity(size_type new_capacity) { | 129 | 86.6k | if (new_capacity <= N) { | 130 | 86.6k | if (!is_direct()) { | 131 | 0 | T* indirect = indirect_ptr(0); | 132 | 0 | T* src = indirect; | 133 | 0 | T* dst = direct_ptr(0); | 134 | 0 | memcpy(dst, src, size() * sizeof(T)); | 135 | 0 | free(indirect); | 136 | 0 | _size -= N + 1; | 137 | 0 | } | 138 | 86.6k | } else { | 139 | 0 | if (!is_direct()) { | 140 | | /* FIXME: Because malloc/realloc here won't call new_handler if allocation fails, assert | 141 | | success. These should instead use an allocator or new/delete so that handlers | 142 | | are called as necessary, but performance would be slightly degraded by doing so. */ | 143 | 0 | _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity)); | 144 | 0 | assert(_union.indirect_contents.indirect); | 145 | 0 | _union.indirect_contents.capacity = new_capacity; | 146 | 0 | } else { | 147 | 0 | char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity)); | 148 | 0 | assert(new_indirect); | 149 | 0 | T* src = direct_ptr(0); | 150 | 0 | T* dst = reinterpret_cast<T*>(new_indirect); | 151 | 0 | memcpy(dst, src, size() * sizeof(T)); | 152 | 0 | _union.indirect_contents.indirect = new_indirect; | 153 | 0 | _union.indirect_contents.capacity = new_capacity; | 154 | 0 | _size += N + 1; | 155 | 0 | } | 156 | 0 | } | 157 | 86.6k | } |
prevector<8u, int, unsigned int, int>::change_capacity(unsigned int) Line | Count | Source | 128 | 544k | void change_capacity(size_type new_capacity) { | 129 | 544k | if (new_capacity <= N) { | 130 | 339k | if (!is_direct()) { | 131 | 658 | T* indirect = indirect_ptr(0); | 132 | 658 | T* src = indirect; | 133 | 658 | T* dst = direct_ptr(0); | 134 | 658 | memcpy(dst, src, size() * sizeof(T)); | 135 | 658 | free(indirect); | 136 | 658 | _size -= N + 1; | 137 | 658 | } | 138 | 339k | } else { | 139 | 204k | if (!is_direct()) { | 140 | | /* FIXME: Because malloc/realloc here won't call new_handler if allocation fails, assert | 141 | | success. These should instead use an allocator or new/delete so that handlers | 142 | | are called as necessary, but performance would be slightly degraded by doing so. */ | 143 | 4.07k | _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity)); | 144 | 4.07k | assert(_union.indirect_contents.indirect); | 145 | 4.07k | _union.indirect_contents.capacity = new_capacity; | 146 | 200k | } else { | 147 | 200k | char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity)); | 148 | 200k | assert(new_indirect); | 149 | 200k | T* src = direct_ptr(0); | 150 | 200k | T* dst = reinterpret_cast<T*>(new_indirect); | 151 | 200k | memcpy(dst, src, size() * sizeof(T)); | 152 | 200k | _union.indirect_contents.indirect = new_indirect; | 153 | 200k | _union.indirect_contents.capacity = new_capacity; | 154 | 200k | _size += N + 1; | 155 | 200k | } | 156 | 204k | } | 157 | 544k | } |
Unexecuted instantiation: prevector<4u, Network, unsigned int, int>::change_capacity(unsigned int) prevector<35u, unsigned char, unsigned int, int>::change_capacity(unsigned int) Line | Count | Source | 128 | 190 | void change_capacity(size_type new_capacity) { | 129 | 190 | if (new_capacity <= N) { | 130 | 190 | if (!is_direct()) { | 131 | 0 | T* indirect = indirect_ptr(0); | 132 | 0 | T* src = indirect; | 133 | 0 | T* dst = direct_ptr(0); | 134 | 0 | memcpy(dst, src, size() * sizeof(T)); | 135 | 0 | free(indirect); | 136 | 0 | _size -= N + 1; | 137 | 0 | } | 138 | 190 | } else { | 139 | 0 | if (!is_direct()) { | 140 | | /* FIXME: Because malloc/realloc here won't call new_handler if allocation fails, assert | 141 | | success. These should instead use an allocator or new/delete so that handlers | 142 | | are called as necessary, but performance would be slightly degraded by doing so. */ | 143 | 0 | _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity)); | 144 | 0 | assert(_union.indirect_contents.indirect); | 145 | 0 | _union.indirect_contents.capacity = new_capacity; | 146 | 0 | } else { | 147 | 0 | char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity)); | 148 | 0 | assert(new_indirect); | 149 | 0 | T* src = direct_ptr(0); | 150 | 0 | T* dst = reinterpret_cast<T*>(new_indirect); | 151 | 0 | memcpy(dst, src, size() * sizeof(T)); | 152 | 0 | _union.indirect_contents.indirect = new_indirect; | 153 | 0 | _union.indirect_contents.capacity = new_capacity; | 154 | 0 | _size += N + 1; | 155 | 0 | } | 156 | 0 | } | 157 | 190 | } |
|
158 | | |
159 | 150M | T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); }prevector<36u, unsigned char, unsigned int, int>::item_ptr(int) Line | Count | Source | 159 | 124M | T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<16u, unsigned char, unsigned int, int>::item_ptr(int) Line | Count | Source | 159 | 8.04M | T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<33u, unsigned char, unsigned int, int>::item_ptr(int) Line | Count | Source | 159 | 684k | T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<8u, int, unsigned int, int>::item_ptr(int) Line | Count | Source | 159 | 17.1M | T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<4u, Network, unsigned int, int>::item_ptr(int) Line | Count | Source | 159 | 94 | T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<35u, unsigned char, unsigned int, int>::item_ptr(int) Line | Count | Source | 159 | 1.52k | T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
|
160 | 1.60G | const T* item_ptr(difference_type pos) const { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); }prevector<36u, unsigned char, unsigned int, int>::item_ptr(int) const Line | Count | Source | 160 | 1.57G | const T* item_ptr(difference_type pos) const { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<16u, unsigned char, unsigned int, int>::item_ptr(int) const Line | Count | Source | 160 | 22.2M | const T* item_ptr(difference_type pos) const { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<8u, int, unsigned int, int>::item_ptr(int) const Line | Count | Source | 160 | 3.76M | const T* item_ptr(difference_type pos) const { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
prevector<33u, unsigned char, unsigned int, int>::item_ptr(int) const Line | Count | Source | 160 | 86.6k | const T* item_ptr(difference_type pos) const { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); } |
|
161 | | |
162 | 3.14M | void fill(T* dst, ptrdiff_t count, const T& value = T{}) { |
163 | 3.14M | std::fill_n(dst, count, value); |
164 | 3.14M | } prevector<36u, unsigned char, unsigned int, int>::fill(unsigned char*, long, unsigned char const&) Line | Count | Source | 162 | 522k | void fill(T* dst, ptrdiff_t count, const T& value = T{}) { | 163 | 522k | std::fill_n(dst, count, value); | 164 | 522k | } |
prevector<33u, unsigned char, unsigned int, int>::fill(unsigned char*, long, unsigned char const&) Line | Count | Source | 162 | 214k | void fill(T* dst, ptrdiff_t count, const T& value = T{}) { | 163 | 214k | std::fill_n(dst, count, value); | 164 | 214k | } |
prevector<16u, unsigned char, unsigned int, int>::fill(unsigned char*, long, unsigned char const&) Line | Count | Source | 162 | 2.38M | void fill(T* dst, ptrdiff_t count, const T& value = T{}) { | 163 | 2.38M | std::fill_n(dst, count, value); | 164 | 2.38M | } |
prevector<8u, int, unsigned int, int>::fill(int*, long, int const&) Line | Count | Source | 162 | 23.3k | void fill(T* dst, ptrdiff_t count, const T& value = T{}) { | 163 | 23.3k | std::fill_n(dst, count, value); | 164 | 23.3k | } |
|
165 | | |
166 | | template <std::input_iterator InputIterator> |
167 | 56.2M | void fill(T* dst, InputIterator first, InputIterator last) { |
168 | 15.3G | while (first != last) { |
169 | 15.2G | new(static_cast<void*>(dst)) T(*first); |
170 | 15.2G | ++dst; |
171 | 15.2G | ++first; |
172 | 15.2G | } |
173 | 56.2M | } void prevector<36u, unsigned char, unsigned int, int>::fill<unsigned char const*>(unsigned char*, unsigned char const*, unsigned char const*) Line | Count | Source | 167 | 393 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 1.42k | while (first != last) { | 169 | 1.02k | new(static_cast<void*>(dst)) T(*first); | 170 | 1.02k | ++dst; | 171 | 1.02k | ++first; | 172 | 1.02k | } | 173 | 393 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>) Line | Count | Source | 167 | 2.69M | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 81.8M | while (first != last) { | 169 | 79.1M | new(static_cast<void*>(dst)) T(*first); | 170 | 79.1M | ++dst; | 171 | 79.1M | ++first; | 172 | 79.1M | } | 173 | 2.69M | } |
void prevector<16u, unsigned char, unsigned int, int>::fill<prevector<16u, unsigned char, unsigned int, int>::const_iterator>(unsigned char*, prevector<16u, unsigned char, unsigned int, int>::const_iterator, prevector<16u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 167 | 3.05M | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 15.5M | while (first != last) { | 169 | 12.5M | new(static_cast<void*>(dst)) T(*first); | 170 | 12.5M | ++dst; | 171 | 12.5M | ++first; | 172 | 12.5M | } | 173 | 3.05M | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<prevector<36u, unsigned char, unsigned int, int>::const_iterator>(unsigned char*, prevector<36u, unsigned char, unsigned int, int>::const_iterator, prevector<36u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 167 | 49.0M | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 15.1G | while (first != last) { | 169 | 15.0G | new(static_cast<void*>(dst)) T(*first); | 170 | 15.0G | ++dst; | 171 | 15.0G | ++first; | 172 | 15.0G | } | 173 | 49.0M | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>) Line | Count | Source | 167 | 39.7k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 1.61M | while (first != last) { | 169 | 1.57M | new(static_cast<void*>(dst)) T(*first); | 170 | 1.57M | ++dst; | 171 | 1.57M | ++first; | 172 | 1.57M | } | 173 | 39.7k | } |
void prevector<33u, unsigned char, unsigned int, int>::fill<unsigned char*>(unsigned char*, unsigned char*, unsigned char*) Line | Count | Source | 167 | 1 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 33 | while (first != last) { | 169 | 32 | new(static_cast<void*>(dst)) T(*first); | 170 | 32 | ++dst; | 171 | 32 | ++first; | 172 | 32 | } | 173 | 1 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<prevector<36u, unsigned char, unsigned int, int>::iterator>(unsigned char*, prevector<36u, unsigned char, unsigned int, int>::iterator, prevector<36u, unsigned char, unsigned int, int>::iterator) Line | Count | Source | 167 | 22.7k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 37.3M | while (first != last) { | 169 | 37.3M | new(static_cast<void*>(dst)) T(*first); | 170 | 37.3M | ++dst; | 171 | 37.3M | ++first; | 172 | 37.3M | } | 173 | 22.7k | } |
void prevector<8u, int, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int>>>>(int*, __gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int>>>, __gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int>>>) Line | Count | Source | 167 | 267k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 2.33M | while (first != last) { | 169 | 2.06M | new(static_cast<void*>(dst)) T(*first); | 170 | 2.06M | ++dst; | 171 | 2.06M | ++first; | 172 | 2.06M | } | 173 | 267k | } |
void prevector<8u, int, unsigned int, int>::fill<prevector<8u, int, unsigned int, int>::iterator>(int*, prevector<8u, int, unsigned int, int>::iterator, prevector<8u, int, unsigned int, int>::iterator) Line | Count | Source | 167 | 267k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 2.33M | while (first != last) { | 169 | 2.06M | new(static_cast<void*>(dst)) T(*first); | 170 | 2.06M | ++dst; | 171 | 2.06M | ++first; | 172 | 2.06M | } | 173 | 267k | } |
void prevector<8u, int, unsigned int, int>::fill<int*>(int*, int*, int*) Line | Count | Source | 167 | 4.24k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 14.7k | while (first != last) { | 169 | 10.5k | new(static_cast<void*>(dst)) T(*first); | 170 | 10.5k | ++dst; | 171 | 10.5k | ++first; | 172 | 10.5k | } | 173 | 4.24k | } |
void prevector<8u, int, unsigned int, int>::fill<prevector<8u, int, unsigned int, int>::const_iterator>(int*, prevector<8u, int, unsigned int, int>::const_iterator, prevector<8u, int, unsigned int, int>::const_iterator) Line | Count | Source | 167 | 8.17k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 53.4k | while (first != last) { | 169 | 45.2k | new(static_cast<void*>(dst)) T(*first); | 170 | 45.2k | ++dst; | 171 | 45.2k | ++first; | 172 | 45.2k | } | 173 | 8.17k | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::vector<unsigned char, std::allocator<unsigned char>>>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::vector<unsigned char, std::allocator<unsigned char>>>, __gnu_cxx::__normal_iterator<unsigned char const*, std::vector<unsigned char, std::allocator<unsigned char>>>) Line | Count | Source | 167 | 193k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 23.8M | while (first != last) { | 169 | 23.6M | new(static_cast<void*>(dst)) T(*first); | 170 | 23.6M | ++dst; | 171 | 23.6M | ++first; | 172 | 23.6M | } | 173 | 193k | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 4ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 4ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 4ul>::__iter_tag>) Line | Count | Source | 167 | 7 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 35 | while (first != last) { | 169 | 28 | new(static_cast<void*>(dst)) T(*first); | 170 | 28 | ++dst; | 171 | 28 | ++first; | 172 | 28 | } | 173 | 7 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 8ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 8ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 8ul>::__iter_tag>) Line | Count | Source | 167 | 4 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 36 | while (first != last) { | 169 | 32 | new(static_cast<void*>(dst)) T(*first); | 170 | 32 | ++dst; | 171 | 32 | ++first; | 172 | 32 | } | 173 | 4 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 1ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 1ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 1ul>::__iter_tag>) Line | Count | Source | 167 | 6 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 12 | while (first != last) { | 169 | 6 | new(static_cast<void*>(dst)) T(*first); | 170 | 6 | ++dst; | 171 | 6 | ++first; | 172 | 6 | } | 173 | 6 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 5ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 5ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 5ul>::__iter_tag>) Line | Count | Source | 167 | 2 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 12 | while (first != last) { | 169 | 10 | new(static_cast<void*>(dst)) T(*first); | 170 | 10 | ++dst; | 171 | 10 | ++first; | 172 | 10 | } | 173 | 2 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 3ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 3ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 3ul>::__iter_tag>) Line | Count | Source | 167 | 7 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 28 | while (first != last) { | 169 | 21 | new(static_cast<void*>(dst)) T(*first); | 170 | 21 | ++dst; | 171 | 21 | ++first; | 172 | 21 | } | 173 | 7 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 7ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 7ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 7ul>::__iter_tag>) Line | Count | Source | 167 | 2 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 16 | while (first != last) { | 169 | 14 | new(static_cast<void*>(dst)) T(*first); | 170 | 14 | ++dst; | 171 | 14 | ++first; | 172 | 14 | } | 173 | 2 | } |
void prevector<36u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 25ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 25ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 25ul>::__iter_tag>) Line | Count | Source | 167 | 2 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 52 | while (first != last) { | 169 | 50 | new(static_cast<void*>(dst)) T(*first); | 170 | 50 | ++dst; | 171 | 50 | ++first; | 172 | 50 | } | 173 | 2 | } |
void prevector<16u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>) Line | Count | Source | 167 | 9.95k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 90.2k | while (first != last) { | 169 | 80.2k | new(static_cast<void*>(dst)) T(*first); | 170 | 80.2k | ++dst; | 171 | 80.2k | ++first; | 172 | 80.2k | } | 173 | 9.95k | } |
void prevector<16u, unsigned char, unsigned int, int>::fill<unsigned char*>(unsigned char*, unsigned char*, unsigned char*) Line | Count | Source | 167 | 10 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 110 | while (first != last) { | 169 | 100 | new(static_cast<void*>(dst)) T(*first); | 170 | 100 | ++dst; | 171 | 100 | ++first; | 172 | 100 | } | 173 | 10 | } |
void prevector<16u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>) Line | Count | Source | 167 | 41 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 1.35k | while (first != last) { | 169 | 1.31k | new(static_cast<void*>(dst)) T(*first); | 170 | 1.31k | ++dst; | 171 | 1.31k | ++first; | 172 | 1.31k | } | 173 | 41 | } |
void prevector<16u, unsigned char, unsigned int, int>::fill<unsigned char const*>(unsigned char*, unsigned char const*, unsigned char const*) Line | Count | Source | 167 | 572k | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 2.86M | while (first != last) { | 169 | 2.28M | new(static_cast<void*>(dst)) T(*first); | 170 | 2.28M | ++dst; | 171 | 2.28M | ++first; | 172 | 2.28M | } | 173 | 572k | } |
void prevector<35u, unsigned char, unsigned int, int>::fill<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>>(unsigned char*, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>) Line | Count | Source | 167 | 190 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 6.27k | while (first != last) { | 169 | 6.08k | new(static_cast<void*>(dst)) T(*first); | 170 | 6.08k | ++dst; | 171 | 6.08k | ++first; | 172 | 6.08k | } | 173 | 190 | } |
void prevector<35u, unsigned char, unsigned int, int>::fill<unsigned char*>(unsigned char*, unsigned char*, unsigned char*) Line | Count | Source | 167 | 190 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 570 | while (first != last) { | 169 | 380 | new(static_cast<void*>(dst)) T(*first); | 170 | 380 | ++dst; | 171 | 380 | ++first; | 172 | 380 | } | 173 | 190 | } |
void prevector<35u, unsigned char, unsigned int, int>::fill<unsigned char const*>(unsigned char*, unsigned char const*, unsigned char const*) Line | Count | Source | 167 | 190 | void fill(T* dst, InputIterator first, InputIterator last) { | 168 | 380 | while (first != last) { | 169 | 190 | new(static_cast<void*>(dst)) T(*first); | 170 | 190 | ++dst; | 171 | 190 | ++first; | 172 | 190 | } | 173 | 190 | } |
|
174 | | |
175 | | public: |
176 | 144k | void assign(size_type n, const T& val) { |
177 | 144k | clear(); |
178 | 144k | if (capacity() < n) { |
179 | 94.4k | change_capacity(n); |
180 | 94.4k | } |
181 | 144k | _size += n; |
182 | 144k | fill(item_ptr(0), n, val); |
183 | 144k | } prevector<36u, unsigned char, unsigned int, int>::assign(unsigned int, unsigned char const&) Line | Count | Source | 176 | 143k | void assign(size_type n, const T& val) { | 177 | 143k | clear(); | 178 | 143k | if (capacity() < n) { | 179 | 94.2k | change_capacity(n); | 180 | 94.2k | } | 181 | 143k | _size += n; | 182 | 143k | fill(item_ptr(0), n, val); | 183 | 143k | } |
prevector<16u, unsigned char, unsigned int, int>::assign(unsigned int, unsigned char const&) Line | Count | Source | 176 | 6 | void assign(size_type n, const T& val) { | 177 | 6 | clear(); | 178 | 6 | if (capacity() < n) { | 179 | 0 | change_capacity(n); | 180 | 0 | } | 181 | 6 | _size += n; | 182 | 6 | fill(item_ptr(0), n, val); | 183 | 6 | } |
prevector<8u, int, unsigned int, int>::assign(unsigned int, int const&) Line | Count | Source | 176 | 291 | void assign(size_type n, const T& val) { | 177 | 291 | clear(); | 178 | 291 | if (capacity() < n) { | 179 | 120 | change_capacity(n); | 180 | 120 | } | 181 | 291 | _size += n; | 182 | 291 | fill(item_ptr(0), n, val); | 183 | 291 | } |
|
184 | | |
185 | | template <std::input_iterator InputIterator> |
186 | 2.45M | void assign(InputIterator first, InputIterator last) { |
187 | 2.45M | size_type n = last - first; |
188 | 2.45M | clear(); |
189 | 2.45M | if (capacity() < n) { |
190 | 119k | change_capacity(n); |
191 | 119k | } |
192 | 2.45M | _size += n; |
193 | 2.45M | fill(item_ptr(0), first, last); |
194 | 2.45M | } void prevector<36u, unsigned char, unsigned int, int>::assign<prevector<36u, unsigned char, unsigned int, int>::const_iterator>(prevector<36u, unsigned char, unsigned int, int>::const_iterator, prevector<36u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 186 | 1.83M | void assign(InputIterator first, InputIterator last) { | 187 | 1.83M | size_type n = last - first; | 188 | 1.83M | clear(); | 189 | 1.83M | if (capacity() < n) { | 190 | 119k | change_capacity(n); | 191 | 119k | } | 192 | 1.83M | _size += n; | 193 | 1.83M | fill(item_ptr(0), first, last); | 194 | 1.83M | } |
void prevector<16u, unsigned char, unsigned int, int>::assign<prevector<16u, unsigned char, unsigned int, int>::const_iterator>(prevector<16u, unsigned char, unsigned int, int>::const_iterator, prevector<16u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 186 | 34.6k | void assign(InputIterator first, InputIterator last) { | 187 | 34.6k | size_type n = last - first; | 188 | 34.6k | clear(); | 189 | 34.6k | if (capacity() < n) { | 190 | 35 | change_capacity(n); | 191 | 35 | } | 192 | 34.6k | _size += n; | 193 | 34.6k | fill(item_ptr(0), first, last); | 194 | 34.6k | } |
void prevector<8u, int, unsigned int, int>::assign<prevector<8u, int, unsigned int, int>::const_iterator>(prevector<8u, int, unsigned int, int>::const_iterator, prevector<8u, int, unsigned int, int>::const_iterator) Line | Count | Source | 186 | 8.17k | void assign(InputIterator first, InputIterator last) { | 187 | 8.17k | size_type n = last - first; | 188 | 8.17k | clear(); | 189 | 8.17k | if (capacity() < n) { | 190 | 578 | change_capacity(n); | 191 | 578 | } | 192 | 8.17k | _size += n; | 193 | 8.17k | fill(item_ptr(0), first, last); | 194 | 8.17k | } |
void prevector<16u, unsigned char, unsigned int, int>::assign<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>) Line | Count | Source | 186 | 9.95k | void assign(InputIterator first, InputIterator last) { | 187 | 9.95k | size_type n = last - first; | 188 | 9.95k | clear(); | 189 | 9.95k | if (capacity() < n) { | 190 | 61 | change_capacity(n); | 191 | 61 | } | 192 | 9.95k | _size += n; | 193 | 9.95k | fill(item_ptr(0), first, last); | 194 | 9.95k | } |
void prevector<16u, unsigned char, unsigned int, int>::assign<unsigned char*>(unsigned char*, unsigned char*) Line | Count | Source | 186 | 10 | void assign(InputIterator first, InputIterator last) { | 187 | 10 | size_type n = last - first; | 188 | 10 | clear(); | 189 | 10 | if (capacity() < n) { | 190 | 0 | change_capacity(n); | 191 | 0 | } | 192 | 10 | _size += n; | 193 | 10 | fill(item_ptr(0), first, last); | 194 | 10 | } |
void prevector<16u, unsigned char, unsigned int, int>::assign<__gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>>(__gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>) Line | Count | Source | 186 | 41 | void assign(InputIterator first, InputIterator last) { | 187 | 41 | size_type n = last - first; | 188 | 41 | clear(); | 189 | 41 | if (capacity() < n) { | 190 | 40 | change_capacity(n); | 191 | 40 | } | 192 | 41 | _size += n; | 193 | 41 | fill(item_ptr(0), first, last); | 194 | 41 | } |
void prevector<16u, unsigned char, unsigned int, int>::assign<unsigned char const*>(unsigned char const*, unsigned char const*) Line | Count | Source | 186 | 572k | void assign(InputIterator first, InputIterator last) { | 187 | 572k | size_type n = last - first; | 188 | 572k | clear(); | 189 | 572k | if (capacity() < n) { | 190 | 0 | change_capacity(n); | 191 | 0 | } | 192 | 572k | _size += n; | 193 | 572k | fill(item_ptr(0), first, last); | 194 | 572k | } |
|
195 | | |
196 | 79.7M | prevector() = default; prevector<36u, unsigned char, unsigned int, int>::prevector() Line | Count | Source | 196 | 79.2M | prevector() = default; |
prevector<33u, unsigned char, unsigned int, int>::prevector() Line | Count | Source | 196 | 479k | prevector() = default; |
prevector<8u, int, unsigned int, int>::prevector() Line | Count | Source | 196 | 128 | prevector() = default; |
prevector<4u, Network, unsigned int, int>::prevector() Line | Count | Source | 196 | 20 | prevector() = default; |
|
197 | | |
198 | | explicit prevector(size_type n) { |
199 | | resize(n); |
200 | | } |
201 | | |
202 | 2.46M | explicit prevector(size_type n, const T& val) { |
203 | 2.46M | change_capacity(n); |
204 | 2.46M | _size += n; |
205 | 2.46M | fill(item_ptr(0), n, val); |
206 | 2.46M | } prevector<33u, unsigned char, unsigned int, int>::prevector(unsigned int, unsigned char const&) Line | Count | Source | 202 | 86.6k | explicit prevector(size_type n, const T& val) { | 203 | 86.6k | change_capacity(n); | 204 | 86.6k | _size += n; | 205 | 86.6k | fill(item_ptr(0), n, val); | 206 | 86.6k | } |
prevector<16u, unsigned char, unsigned int, int>::prevector(unsigned int, unsigned char const&) Line | Count | Source | 202 | 2.38M | explicit prevector(size_type n, const T& val) { | 203 | 2.38M | change_capacity(n); | 204 | 2.38M | _size += n; | 205 | 2.38M | fill(item_ptr(0), n, val); | 206 | 2.38M | } |
|
207 | | |
208 | | template <std::input_iterator InputIterator> |
209 | 1.13M | prevector(InputIterator first, InputIterator last) { |
210 | 1.13M | size_type n = last - first; |
211 | 1.13M | change_capacity(n); |
212 | 1.13M | _size += n; |
213 | 1.13M | fill(item_ptr(0), first, last); |
214 | 1.13M | } prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>>(__gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>) Line | Count | Source | 209 | 37.0k | prevector(InputIterator first, InputIterator last) { | 210 | 37.0k | size_type n = last - first; | 211 | 37.0k | change_capacity(n); | 212 | 37.0k | _size += n; | 213 | 37.0k | fill(item_ptr(0), first, last); | 214 | 37.0k | } |
prevector<33u, unsigned char, unsigned int, int>::prevector<unsigned char*>(unsigned char*, unsigned char*) Line | Count | Source | 209 | 1 | prevector(InputIterator first, InputIterator last) { | 210 | 1 | size_type n = last - first; | 211 | 1 | change_capacity(n); | 212 | 1 | _size += n; | 213 | 1 | fill(item_ptr(0), first, last); | 214 | 1 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<unsigned char const*>(unsigned char const*, unsigned char const*) Line | Count | Source | 209 | 13 | prevector(InputIterator first, InputIterator last) { | 210 | 13 | size_type n = last - first; | 211 | 13 | change_capacity(n); | 212 | 13 | _size += n; | 213 | 13 | fill(item_ptr(0), first, last); | 214 | 13 | } |
prevector<8u, int, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int>>>>(__gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int>>>, __gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int>>>) Line | Count | Source | 209 | 267k | prevector(InputIterator first, InputIterator last) { | 210 | 267k | size_type n = last - first; | 211 | 267k | change_capacity(n); | 212 | 267k | _size += n; | 213 | 267k | fill(item_ptr(0), first, last); | 214 | 267k | } |
prevector<8u, int, unsigned int, int>::prevector<prevector<8u, int, unsigned int, int>::iterator>(prevector<8u, int, unsigned int, int>::iterator, prevector<8u, int, unsigned int, int>::iterator) Line | Count | Source | 209 | 267k | prevector(InputIterator first, InputIterator last) { | 210 | 267k | size_type n = last - first; | 211 | 267k | change_capacity(n); | 212 | 267k | _size += n; | 213 | 267k | fill(item_ptr(0), first, last); | 214 | 267k | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>) Line | Count | Source | 209 | 6.84k | prevector(InputIterator first, InputIterator last) { | 210 | 6.84k | size_type n = last - first; | 211 | 6.84k | change_capacity(n); | 212 | 6.84k | _size += n; | 213 | 6.84k | fill(item_ptr(0), first, last); | 214 | 6.84k | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::vector<unsigned char, std::allocator<unsigned char>>>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::vector<unsigned char, std::allocator<unsigned char>>>, __gnu_cxx::__normal_iterator<unsigned char const*, std::vector<unsigned char, std::allocator<unsigned char>>>) Line | Count | Source | 209 | 193k | prevector(InputIterator first, InputIterator last) { | 210 | 193k | size_type n = last - first; | 211 | 193k | change_capacity(n); | 212 | 193k | _size += n; | 213 | 193k | fill(item_ptr(0), first, last); | 214 | 193k | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 4ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 4ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 4ul>::__iter_tag>) Line | Count | Source | 209 | 7 | prevector(InputIterator first, InputIterator last) { | 210 | 7 | size_type n = last - first; | 211 | 7 | change_capacity(n); | 212 | 7 | _size += n; | 213 | 7 | fill(item_ptr(0), first, last); | 214 | 7 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 8ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 8ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 8ul>::__iter_tag>) Line | Count | Source | 209 | 4 | prevector(InputIterator first, InputIterator last) { | 210 | 4 | size_type n = last - first; | 211 | 4 | change_capacity(n); | 212 | 4 | _size += n; | 213 | 4 | fill(item_ptr(0), first, last); | 214 | 4 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 1ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 1ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 1ul>::__iter_tag>) Line | Count | Source | 209 | 6 | prevector(InputIterator first, InputIterator last) { | 210 | 6 | size_type n = last - first; | 211 | 6 | change_capacity(n); | 212 | 6 | _size += n; | 213 | 6 | fill(item_ptr(0), first, last); | 214 | 6 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 5ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 5ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 5ul>::__iter_tag>) Line | Count | Source | 209 | 2 | prevector(InputIterator first, InputIterator last) { | 210 | 2 | size_type n = last - first; | 211 | 2 | change_capacity(n); | 212 | 2 | _size += n; | 213 | 2 | fill(item_ptr(0), first, last); | 214 | 2 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 3ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 3ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 3ul>::__iter_tag>) Line | Count | Source | 209 | 7 | prevector(InputIterator first, InputIterator last) { | 210 | 7 | size_type n = last - first; | 211 | 7 | change_capacity(n); | 212 | 7 | _size += n; | 213 | 7 | fill(item_ptr(0), first, last); | 214 | 7 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 7ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 7ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 7ul>::__iter_tag>) Line | Count | Source | 209 | 2 | prevector(InputIterator first, InputIterator last) { | 210 | 2 | size_type n = last - first; | 211 | 2 | change_capacity(n); | 212 | 2 | _size += n; | 213 | 2 | fill(item_ptr(0), first, last); | 214 | 2 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 25ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 25ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 25ul>::__iter_tag>) Line | Count | Source | 209 | 2 | prevector(InputIterator first, InputIterator last) { | 210 | 2 | size_type n = last - first; | 211 | 2 | change_capacity(n); | 212 | 2 | _size += n; | 213 | 2 | fill(item_ptr(0), first, last); | 214 | 2 | } |
prevector<36u, unsigned char, unsigned int, int>::prevector<prevector<36u, unsigned char, unsigned int, int>::const_iterator>(prevector<36u, unsigned char, unsigned int, int>::const_iterator, prevector<36u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 209 | 367k | prevector(InputIterator first, InputIterator last) { | 210 | 367k | size_type n = last - first; | 211 | 367k | change_capacity(n); | 212 | 367k | _size += n; | 213 | 367k | fill(item_ptr(0), first, last); | 214 | 367k | } |
prevector<35u, unsigned char, unsigned int, int>::prevector<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>>(__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>) Line | Count | Source | 209 | 190 | prevector(InputIterator first, InputIterator last) { | 210 | 190 | size_type n = last - first; | 211 | 190 | change_capacity(n); | 212 | 190 | _size += n; | 213 | 190 | fill(item_ptr(0), first, last); | 214 | 190 | } |
|
215 | | |
216 | 47.1M | prevector(const prevector<N, T, Size, Diff>& other) { |
217 | 47.1M | size_type n = other.size(); |
218 | 47.1M | change_capacity(n); |
219 | 47.1M | _size += n; |
220 | 47.1M | fill(item_ptr(0), other.begin(), other.end()); |
221 | 47.1M | } prevector<16u, unsigned char, unsigned int, int>::prevector(prevector<16u, unsigned char, unsigned int, int> const&) Line | Count | Source | 216 | 3.02M | prevector(const prevector<N, T, Size, Diff>& other) { | 217 | 3.02M | size_type n = other.size(); | 218 | 3.02M | change_capacity(n); | 219 | 3.02M | _size += n; | 220 | 3.02M | fill(item_ptr(0), other.begin(), other.end()); | 221 | 3.02M | } |
prevector<36u, unsigned char, unsigned int, int>::prevector(prevector<36u, unsigned char, unsigned int, int> const&) Line | Count | Source | 216 | 44.1M | prevector(const prevector<N, T, Size, Diff>& other) { | 217 | 44.1M | size_type n = other.size(); | 218 | 44.1M | change_capacity(n); | 219 | 44.1M | _size += n; | 220 | 44.1M | fill(item_ptr(0), other.begin(), other.end()); | 221 | 44.1M | } |
|
222 | | |
223 | | prevector(prevector<N, T, Size, Diff>&& other) noexcept |
224 | 16.6M | : _union(std::move(other._union)), _size(other._size) |
225 | 16.6M | { |
226 | 16.6M | other._size = 0; |
227 | 16.6M | } prevector<16u, unsigned char, unsigned int, int>::prevector(prevector<16u, unsigned char, unsigned int, int>&&) Line | Count | Source | 224 | 547k | : _union(std::move(other._union)), _size(other._size) | 225 | 547k | { | 226 | 547k | other._size = 0; | 227 | 547k | } |
prevector<36u, unsigned char, unsigned int, int>::prevector(prevector<36u, unsigned char, unsigned int, int>&&) Line | Count | Source | 224 | 16.1M | : _union(std::move(other._union)), _size(other._size) | 225 | 16.1M | { | 226 | 16.1M | other._size = 0; | 227 | 16.1M | } |
|
228 | | |
229 | 1.88M | prevector& operator=(const prevector<N, T, Size, Diff>& other) { |
230 | 1.88M | if (&other == this) { |
231 | 12.8k | return *this; |
232 | 12.8k | } |
233 | 1.87M | assign(other.begin(), other.end()); |
234 | 1.87M | return *this; |
235 | 1.88M | } prevector<36u, unsigned char, unsigned int, int>::operator=(prevector<36u, unsigned char, unsigned int, int> const&) Line | Count | Source | 229 | 1.84M | prevector& operator=(const prevector<N, T, Size, Diff>& other) { | 230 | 1.84M | if (&other == this) { | 231 | 12.8k | return *this; | 232 | 12.8k | } | 233 | 1.83M | assign(other.begin(), other.end()); | 234 | 1.83M | return *this; | 235 | 1.84M | } |
prevector<16u, unsigned char, unsigned int, int>::operator=(prevector<16u, unsigned char, unsigned int, int> const&) Line | Count | Source | 229 | 34.6k | prevector& operator=(const prevector<N, T, Size, Diff>& other) { | 230 | 34.6k | if (&other == this) { | 231 | 2 | return *this; | 232 | 2 | } | 233 | 34.6k | assign(other.begin(), other.end()); | 234 | 34.6k | return *this; | 235 | 34.6k | } |
prevector<8u, int, unsigned int, int>::operator=(prevector<8u, int, unsigned int, int> const&) Line | Count | Source | 229 | 8.17k | prevector& operator=(const prevector<N, T, Size, Diff>& other) { | 230 | 8.17k | if (&other == this) { | 231 | 0 | return *this; | 232 | 0 | } | 233 | 8.17k | assign(other.begin(), other.end()); | 234 | 8.17k | return *this; | 235 | 8.17k | } |
|
236 | | |
237 | 30.4M | prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept { |
238 | 30.4M | if (!is_direct()) { |
239 | 23.7k | free(_union.indirect_contents.indirect); |
240 | 23.7k | } |
241 | 30.4M | _union = std::move(other._union); |
242 | 30.4M | _size = other._size; |
243 | 30.4M | other._size = 0; |
244 | 30.4M | return *this; |
245 | 30.4M | } prevector<16u, unsigned char, unsigned int, int>::operator=(prevector<16u, unsigned char, unsigned int, int>&&) Line | Count | Source | 237 | 605k | prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept { | 238 | 605k | if (!is_direct()) { | 239 | 8 | free(_union.indirect_contents.indirect); | 240 | 8 | } | 241 | 605k | _union = std::move(other._union); | 242 | 605k | _size = other._size; | 243 | 605k | other._size = 0; | 244 | 605k | return *this; | 245 | 605k | } |
prevector<36u, unsigned char, unsigned int, int>::operator=(prevector<36u, unsigned char, unsigned int, int>&&) Line | Count | Source | 237 | 29.8M | prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept { | 238 | 29.8M | if (!is_direct()) { | 239 | 21.2k | free(_union.indirect_contents.indirect); | 240 | 21.2k | } | 241 | 29.8M | _union = std::move(other._union); | 242 | 29.8M | _size = other._size; | 243 | 29.8M | other._size = 0; | 244 | 29.8M | return *this; | 245 | 29.8M | } |
prevector<8u, int, unsigned int, int>::operator=(prevector<8u, int, unsigned int, int>&&) Line | Count | Source | 237 | 4.12k | prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept { | 238 | 4.12k | if (!is_direct()) { | 239 | 2.52k | free(_union.indirect_contents.indirect); | 240 | 2.52k | } | 241 | 4.12k | _union = std::move(other._union); | 242 | 4.12k | _size = other._size; | 243 | 4.12k | other._size = 0; | 244 | 4.12k | return *this; | 245 | 4.12k | } |
|
246 | | |
247 | 1.93G | size_type size() const { |
248 | 1.93G | return is_direct() ? _size : _size - N - 1; |
249 | 1.93G | } prevector<36u, unsigned char, unsigned int, int>::size() const Line | Count | Source | 247 | 1.90G | size_type size() const { | 248 | 1.90G | return is_direct() ? _size : _size - N - 1; | 249 | 1.90G | } |
prevector<16u, unsigned char, unsigned int, int>::size() const Line | Count | Source | 247 | 15.9M | size_type size() const { | 248 | 15.9M | return is_direct() ? _size : _size - N - 1; | 249 | 15.9M | } |
prevector<33u, unsigned char, unsigned int, int>::size() const Line | Count | Source | 247 | 342k | size_type size() const { | 248 | 342k | return is_direct() ? _size : _size - N - 1; | 249 | 342k | } |
prevector<8u, int, unsigned int, int>::size() const Line | Count | Source | 247 | 7.10M | size_type size() const { | 248 | 7.10M | return is_direct() ? _size : _size - N - 1; | 249 | 7.10M | } |
prevector<4u, Network, unsigned int, int>::size() const Line | Count | Source | 247 | 188 | size_type size() const { | 248 | 188 | return is_direct() ? _size : _size - N - 1; | 249 | 188 | } |
prevector<35u, unsigned char, unsigned int, int>::size() const Line | Count | Source | 247 | 1.33k | size_type size() const { | 248 | 1.33k | return is_direct() ? _size : _size - N - 1; | 249 | 1.33k | } |
|
250 | | |
251 | 30.4M | bool empty() const { |
252 | 30.4M | return size() == 0; |
253 | 30.4M | } prevector<16u, unsigned char, unsigned int, int>::empty() const Line | Count | Source | 251 | 100k | bool empty() const { | 252 | 100k | return size() == 0; | 253 | 100k | } |
prevector<36u, unsigned char, unsigned int, int>::empty() const Line | Count | Source | 251 | 30.0M | bool empty() const { | 252 | 30.0M | return size() == 0; | 253 | 30.0M | } |
prevector<8u, int, unsigned int, int>::empty() const Line | Count | Source | 251 | 267k | bool empty() const { | 252 | 267k | return size() == 0; | 253 | 267k | } |
prevector<4u, Network, unsigned int, int>::empty() const Line | Count | Source | 251 | 20 | bool empty() const { | 252 | 20 | return size() == 0; | 253 | 20 | } |
|
254 | | |
255 | 20.2M | iterator begin() { return iterator(item_ptr(0)); }prevector<36u, unsigned char, unsigned int, int>::begin() Line | Count | Source | 255 | 15.1M | iterator begin() { return iterator(item_ptr(0)); } |
Unexecuted instantiation: prevector<16u, unsigned char, unsigned int, int>::begin() Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::begin() prevector<8u, int, unsigned int, int>::begin() Line | Count | Source | 255 | 5.10M | iterator begin() { return iterator(item_ptr(0)); } |
prevector<35u, unsigned char, unsigned int, int>::begin() Line | Count | Source | 255 | 380 | iterator begin() { return iterator(item_ptr(0)); } |
|
256 | 135M | const_iterator begin() const { return const_iterator(item_ptr(0)); }prevector<36u, unsigned char, unsigned int, int>::begin() const Line | Count | Source | 256 | 126M | const_iterator begin() const { return const_iterator(item_ptr(0)); } |
prevector<16u, unsigned char, unsigned int, int>::begin() const Line | Count | Source | 256 | 7.55M | const_iterator begin() const { return const_iterator(item_ptr(0)); } |
prevector<8u, int, unsigned int, int>::begin() const Line | Count | Source | 256 | 1.88M | const_iterator begin() const { return const_iterator(item_ptr(0)); } |
|
257 | 39.5M | iterator end() { return iterator(item_ptr(size())); }prevector<36u, unsigned char, unsigned int, int>::end() Line | Count | Source | 257 | 35.2M | iterator end() { return iterator(item_ptr(size())); } |
prevector<16u, unsigned char, unsigned int, int>::end() Line | Count | Source | 257 | 1.31M | iterator end() { return iterator(item_ptr(size())); } |
Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::end() prevector<8u, int, unsigned int, int>::end() Line | Count | Source | 257 | 2.96M | iterator end() { return iterator(item_ptr(size())); } |
prevector<35u, unsigned char, unsigned int, int>::end() Line | Count | Source | 257 | 380 | iterator end() { return iterator(item_ptr(size())); } |
|
258 | 1.41G | const_iterator end() const { return const_iterator(item_ptr(size())); }prevector<36u, unsigned char, unsigned int, int>::end() const Line | Count | Source | 258 | 1.41G | const_iterator end() const { return const_iterator(item_ptr(size())); } |
prevector<16u, unsigned char, unsigned int, int>::end() const Line | Count | Source | 258 | 3.52M | const_iterator end() const { return const_iterator(item_ptr(size())); } |
prevector<8u, int, unsigned int, int>::end() const Line | Count | Source | 258 | 1.88M | const_iterator end() const { return const_iterator(item_ptr(size())); } |
|
259 | | |
260 | 18.6M | size_t capacity() const { |
261 | 18.6M | if (is_direct()) { |
262 | 12.7M | return N; |
263 | 12.7M | } else { |
264 | 5.87M | return _union.indirect_contents.capacity; |
265 | 5.87M | } |
266 | 18.6M | } prevector<36u, unsigned char, unsigned int, int>::capacity() const Line | Count | Source | 260 | 17.8M | size_t capacity() const { | 261 | 17.8M | if (is_direct()) { | 262 | 12.0M | return N; | 263 | 12.0M | } else { | 264 | 5.82M | return _union.indirect_contents.capacity; | 265 | 5.82M | } | 266 | 17.8M | } |
prevector<16u, unsigned char, unsigned int, int>::capacity() const Line | Count | Source | 260 | 617k | size_t capacity() const { | 261 | 617k | if (is_direct()) { | 262 | 617k | return N; | 263 | 617k | } else { | 264 | 10 | return _union.indirect_contents.capacity; | 265 | 10 | } | 266 | 617k | } |
prevector<8u, int, unsigned int, int>::capacity() const Line | Count | Source | 260 | 93.1k | size_t capacity() const { | 261 | 93.1k | if (is_direct()) { | 262 | 34.5k | return N; | 263 | 58.5k | } else { | 264 | 58.5k | return _union.indirect_contents.capacity; | 265 | 58.5k | } | 266 | 93.1k | } |
prevector<4u, Network, unsigned int, int>::capacity() const Line | Count | Source | 260 | 74 | size_t capacity() const { | 261 | 74 | if (is_direct()) { | 262 | 74 | return N; | 263 | 74 | } else { | 264 | 0 | return _union.indirect_contents.capacity; | 265 | 0 | } | 266 | 74 | } |
prevector<33u, unsigned char, unsigned int, int>::capacity() const Line | Count | Source | 260 | 127k | size_t capacity() const { | 261 | 127k | if (is_direct()) { | 262 | 127k | return N; | 263 | 127k | } else { | 264 | 0 | return _union.indirect_contents.capacity; | 265 | 0 | } | 266 | 127k | } |
prevector<35u, unsigned char, unsigned int, int>::capacity() const Line | Count | Source | 260 | 380 | size_t capacity() const { | 261 | 380 | if (is_direct()) { | 262 | 380 | return N; | 263 | 380 | } else { | 264 | 0 | return _union.indirect_contents.capacity; | 265 | 0 | } | 266 | 380 | } |
|
267 | | |
268 | 10.5M | T& operator[](size_type pos) { |
269 | 10.5M | return *item_ptr(pos); |
270 | 10.5M | } prevector<36u, unsigned char, unsigned int, int>::operator[](unsigned int) Line | Count | Source | 268 | 1.87M | T& operator[](size_type pos) { | 269 | 1.87M | return *item_ptr(pos); | 270 | 1.87M | } |
prevector<33u, unsigned char, unsigned int, int>::operator[](unsigned int) Line | Count | Source | 268 | 255k | T& operator[](size_type pos) { | 269 | 255k | return *item_ptr(pos); | 270 | 255k | } |
prevector<8u, int, unsigned int, int>::operator[](unsigned int) Line | Count | Source | 268 | 8.39M | T& operator[](size_type pos) { | 269 | 8.39M | return *item_ptr(pos); | 270 | 8.39M | } |
prevector<4u, Network, unsigned int, int>::operator[](unsigned int) Line | Count | Source | 268 | 20 | T& operator[](size_type pos) { | 269 | 20 | return *item_ptr(pos); | 270 | 20 | } |
prevector<16u, unsigned char, unsigned int, int>::operator[](unsigned int) Line | Count | Source | 268 | 5.00k | T& operator[](size_type pos) { | 269 | 5.00k | return *item_ptr(pos); | 270 | 5.00k | } |
|
271 | | |
272 | 19.9M | const T& operator[](size_type pos) const { |
273 | 19.9M | return *item_ptr(pos); |
274 | 19.9M | } prevector<16u, unsigned char, unsigned int, int>::operator[](unsigned int) const Line | Count | Source | 272 | 8.50M | const T& operator[](size_type pos) const { | 273 | 8.50M | return *item_ptr(pos); | 274 | 8.50M | } |
prevector<36u, unsigned char, unsigned int, int>::operator[](unsigned int) const Line | Count | Source | 272 | 11.4M | const T& operator[](size_type pos) const { | 273 | 11.4M | return *item_ptr(pos); | 274 | 11.4M | } |
|
275 | | |
276 | 77.5M | void resize(size_type new_size) { |
277 | 77.5M | size_type cur_size = size(); |
278 | 77.5M | if (cur_size == new_size) { |
279 | 66.1M | return; |
280 | 66.1M | } |
281 | 11.3M | if (cur_size > new_size) { |
282 | 10.8M | erase(item_ptr(new_size), end()); |
283 | 10.8M | return; |
284 | 10.8M | } |
285 | 512k | if (new_size > capacity()) { |
286 | 77.2k | change_capacity(new_size); |
287 | 77.2k | } |
288 | 512k | ptrdiff_t increase = new_size - cur_size; |
289 | 512k | fill(item_ptr(cur_size), increase); |
290 | 512k | _size += increase; |
291 | 512k | } prevector<36u, unsigned char, unsigned int, int>::resize(unsigned int) Line | Count | Source | 276 | 76.7M | void resize(size_type new_size) { | 277 | 76.7M | size_type cur_size = size(); | 278 | 76.7M | if (cur_size == new_size) { | 279 | 66.1M | return; | 280 | 66.1M | } | 281 | 10.5M | if (cur_size > new_size) { | 282 | 10.2M | erase(item_ptr(new_size), end()); | 283 | 10.2M | return; | 284 | 10.2M | } | 285 | 378k | if (new_size > capacity()) { | 286 | 76.6k | change_capacity(new_size); | 287 | 76.6k | } | 288 | 378k | ptrdiff_t increase = new_size - cur_size; | 289 | 378k | fill(item_ptr(cur_size), increase); | 290 | 378k | _size += increase; | 291 | 378k | } |
prevector<16u, unsigned char, unsigned int, int>::resize(unsigned int) Line | Count | Source | 276 | 658k | void resize(size_type new_size) { | 277 | 658k | size_type cur_size = size(); | 278 | 658k | if (cur_size == new_size) { | 279 | 101 | return; | 280 | 101 | } | 281 | 658k | if (cur_size > new_size) { | 282 | 658k | erase(item_ptr(new_size), end()); | 283 | 658k | return; | 284 | 658k | } | 285 | 284 | if (new_size > capacity()) { | 286 | 282 | change_capacity(new_size); | 287 | 282 | } | 288 | 284 | ptrdiff_t increase = new_size - cur_size; | 289 | 284 | fill(item_ptr(cur_size), increase); | 290 | 284 | _size += increase; | 291 | 284 | } |
prevector<8u, int, unsigned int, int>::resize(unsigned int) Line | Count | Source | 276 | 29.2k | void resize(size_type new_size) { | 277 | 29.2k | size_type cur_size = size(); | 278 | 29.2k | if (cur_size == new_size) { | 279 | 10.4k | return; | 280 | 10.4k | } | 281 | 18.7k | if (cur_size > new_size) { | 282 | 12.2k | erase(item_ptr(new_size), end()); | 283 | 12.2k | return; | 284 | 12.2k | } | 285 | 6.58k | if (new_size > capacity()) { | 286 | 293 | change_capacity(new_size); | 287 | 293 | } | 288 | 6.58k | ptrdiff_t increase = new_size - cur_size; | 289 | 6.58k | fill(item_ptr(cur_size), increase); | 290 | 6.58k | _size += increase; | 291 | 6.58k | } |
prevector<33u, unsigned char, unsigned int, int>::resize(unsigned int) Line | Count | Source | 276 | 127k | void resize(size_type new_size) { | 277 | 127k | size_type cur_size = size(); | 278 | 127k | if (cur_size == new_size) { | 279 | 0 | return; | 280 | 0 | } | 281 | 127k | if (cur_size > new_size) { | 282 | 0 | erase(item_ptr(new_size), end()); | 283 | 0 | return; | 284 | 0 | } | 285 | 127k | if (new_size > capacity()) { | 286 | 0 | change_capacity(new_size); | 287 | 0 | } | 288 | 127k | ptrdiff_t increase = new_size - cur_size; | 289 | 127k | fill(item_ptr(cur_size), increase); | 290 | 127k | _size += increase; | 291 | 127k | } |
|
292 | | |
293 | 4.05k | void reserve(size_type new_capacity) { |
294 | 4.05k | if (new_capacity > capacity()) { |
295 | 1.77k | change_capacity(new_capacity); |
296 | 1.77k | } |
297 | 4.05k | } |
298 | | |
299 | 73.1M | void shrink_to_fit() { |
300 | 73.1M | change_capacity(size()); |
301 | 73.1M | } prevector<36u, unsigned char, unsigned int, int>::shrink_to_fit() Line | Count | Source | 299 | 73.1M | void shrink_to_fit() { | 300 | 73.1M | change_capacity(size()); | 301 | 73.1M | } |
prevector<8u, int, unsigned int, int>::shrink_to_fit() Line | Count | Source | 299 | 2.04k | void shrink_to_fit() { | 300 | 2.04k | change_capacity(size()); | 301 | 2.04k | } |
|
302 | | |
303 | 76.9M | void clear() { |
304 | 76.9M | resize(0); |
305 | 76.9M | } prevector<36u, unsigned char, unsigned int, int>::clear() Line | Count | Source | 303 | 76.3M | void clear() { | 304 | 76.3M | resize(0); | 305 | 76.3M | } |
prevector<16u, unsigned char, unsigned int, int>::clear() Line | Count | Source | 303 | 616k | void clear() { | 304 | 616k | resize(0); | 305 | 616k | } |
prevector<8u, int, unsigned int, int>::clear() Line | Count | Source | 303 | 12.7k | void clear() { | 304 | 12.7k | resize(0); | 305 | 12.7k | } |
|
306 | | |
307 | 8.99M | iterator insert(iterator pos, const T& value) { |
308 | 8.99M | size_type p = pos - begin(); |
309 | 8.99M | size_type new_size = size() + 1; |
310 | 8.99M | if (capacity() < new_size) { |
311 | 8.05k | change_capacity(new_size + (new_size >> 1)); |
312 | 8.05k | } |
313 | 8.99M | T* ptr = item_ptr(p); |
314 | 8.99M | T* dst = ptr + 1; |
315 | 8.99M | memmove(dst, ptr, (size() - p) * sizeof(T)); |
316 | 8.99M | _size++; |
317 | 8.99M | new(static_cast<void*>(ptr)) T(value); |
318 | 8.99M | return iterator(ptr); |
319 | 8.99M | } prevector<36u, unsigned char, unsigned int, int>::insert(prevector<36u, unsigned char, unsigned int, int>::iterator, unsigned char const&) Line | Count | Source | 307 | 8.96M | iterator insert(iterator pos, const T& value) { | 308 | 8.96M | size_type p = pos - begin(); | 309 | 8.96M | size_type new_size = size() + 1; | 310 | 8.96M | if (capacity() < new_size) { | 311 | 6.65k | change_capacity(new_size + (new_size >> 1)); | 312 | 6.65k | } | 313 | 8.96M | T* ptr = item_ptr(p); | 314 | 8.96M | T* dst = ptr + 1; | 315 | 8.96M | memmove(dst, ptr, (size() - p) * sizeof(T)); | 316 | 8.96M | _size++; | 317 | 8.96M | new(static_cast<void*>(ptr)) T(value); | 318 | 8.96M | return iterator(ptr); | 319 | 8.96M | } |
prevector<8u, int, unsigned int, int>::insert(prevector<8u, int, unsigned int, int>::iterator, int const&) Line | Count | Source | 307 | 32.9k | iterator insert(iterator pos, const T& value) { | 308 | 32.9k | size_type p = pos - begin(); | 309 | 32.9k | size_type new_size = size() + 1; | 310 | 32.9k | if (capacity() < new_size) { | 311 | 1.39k | change_capacity(new_size + (new_size >> 1)); | 312 | 1.39k | } | 313 | 32.9k | T* ptr = item_ptr(p); | 314 | 32.9k | T* dst = ptr + 1; | 315 | 32.9k | memmove(dst, ptr, (size() - p) * sizeof(T)); | 316 | 32.9k | _size++; | 317 | 32.9k | new(static_cast<void*>(ptr)) T(value); | 318 | 32.9k | return iterator(ptr); | 319 | 32.9k | } |
|
320 | | |
321 | 16.4k | void insert(iterator pos, size_type count, const T& value) { |
322 | 16.4k | size_type p = pos - begin(); |
323 | 16.4k | size_type new_size = size() + count; |
324 | 16.4k | if (capacity() < new_size) { |
325 | 770 | change_capacity(new_size + (new_size >> 1)); |
326 | 770 | } |
327 | 16.4k | T* ptr = item_ptr(p); |
328 | 16.4k | T* dst = ptr + count; |
329 | 16.4k | memmove(dst, ptr, (size() - p) * sizeof(T)); |
330 | 16.4k | _size += count; |
331 | 16.4k | fill(item_ptr(p), count, value); |
332 | 16.4k | } prevector<8u, int, unsigned int, int>::insert(prevector<8u, int, unsigned int, int>::iterator, unsigned int, int const&) Line | Count | Source | 321 | 16.4k | void insert(iterator pos, size_type count, const T& value) { | 322 | 16.4k | size_type p = pos - begin(); | 323 | 16.4k | size_type new_size = size() + count; | 324 | 16.4k | if (capacity() < new_size) { | 325 | 763 | change_capacity(new_size + (new_size >> 1)); | 326 | 763 | } | 327 | 16.4k | T* ptr = item_ptr(p); | 328 | 16.4k | T* dst = ptr + count; | 329 | 16.4k | memmove(dst, ptr, (size() - p) * sizeof(T)); | 330 | 16.4k | _size += count; | 331 | 16.4k | fill(item_ptr(p), count, value); | 332 | 16.4k | } |
prevector<36u, unsigned char, unsigned int, int>::insert(prevector<36u, unsigned char, unsigned int, int>::iterator, unsigned int, unsigned char const&) Line | Count | Source | 321 | 7 | void insert(iterator pos, size_type count, const T& value) { | 322 | 7 | size_type p = pos - begin(); | 323 | 7 | size_type new_size = size() + count; | 324 | 7 | if (capacity() < new_size) { | 325 | 7 | change_capacity(new_size + (new_size >> 1)); | 326 | 7 | } | 327 | 7 | T* ptr = item_ptr(p); | 328 | 7 | T* dst = ptr + count; | 329 | 7 | memmove(dst, ptr, (size() - p) * sizeof(T)); | 330 | 7 | _size += count; | 331 | 7 | fill(item_ptr(p), count, value); | 332 | 7 | } |
|
333 | | |
334 | | template <std::input_iterator InputIterator> |
335 | 5.47M | void insert(iterator pos, InputIterator first, InputIterator last) { |
336 | 5.47M | size_type p = pos - begin(); |
337 | 5.47M | difference_type count = last - first; |
338 | 5.47M | size_type new_size = size() + count; |
339 | 5.47M | if (capacity() < new_size) { |
340 | 369k | change_capacity(new_size + (new_size >> 1)); |
341 | 369k | } |
342 | 5.47M | T* ptr = item_ptr(p); |
343 | 5.47M | T* dst = ptr + count; |
344 | 5.47M | memmove(dst, ptr, (size() - p) * sizeof(T)); |
345 | 5.47M | _size += count; |
346 | 5.47M | fill(ptr, first, last); |
347 | 5.47M | } void prevector<36u, unsigned char, unsigned int, int>::insert<unsigned char const*>(prevector<36u, unsigned char, unsigned int, int>::iterator, unsigned char const*, unsigned char const*) Line | Count | Source | 335 | 380 | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 380 | size_type p = pos - begin(); | 337 | 380 | difference_type count = last - first; | 338 | 380 | size_type new_size = size() + count; | 339 | 380 | if (capacity() < new_size) { | 340 | 0 | change_capacity(new_size + (new_size >> 1)); | 341 | 0 | } | 342 | 380 | T* ptr = item_ptr(p); | 343 | 380 | T* dst = ptr + count; | 344 | 380 | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 380 | _size += count; | 346 | 380 | fill(ptr, first, last); | 347 | 380 | } |
void prevector<36u, unsigned char, unsigned int, int>::insert<__gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>>(prevector<36u, unsigned char, unsigned int, int>::iterator, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>, __gnu_cxx::__normal_iterator<unsigned char const*, std::span<unsigned char const, 18446744073709551615ul>::__iter_tag>) Line | Count | Source | 335 | 2.68M | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 2.68M | size_type p = pos - begin(); | 337 | 2.68M | difference_type count = last - first; | 338 | 2.68M | size_type new_size = size() + count; | 339 | 2.68M | if (capacity() < new_size) { | 340 | 223k | change_capacity(new_size + (new_size >> 1)); | 341 | 223k | } | 342 | 2.68M | T* ptr = item_ptr(p); | 343 | 2.68M | T* dst = ptr + count; | 344 | 2.68M | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 2.68M | _size += count; | 346 | 2.68M | fill(ptr, first, last); | 347 | 2.68M | } |
void prevector<36u, unsigned char, unsigned int, int>::insert<prevector<36u, unsigned char, unsigned int, int>::iterator>(prevector<36u, unsigned char, unsigned int, int>::iterator, prevector<36u, unsigned char, unsigned int, int>::iterator, prevector<36u, unsigned char, unsigned int, int>::iterator) Line | Count | Source | 335 | 22.7k | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 22.7k | size_type p = pos - begin(); | 337 | 22.7k | difference_type count = last - first; | 338 | 22.7k | size_type new_size = size() + count; | 339 | 22.7k | if (capacity() < new_size) { | 340 | 17.0k | change_capacity(new_size + (new_size >> 1)); | 341 | 17.0k | } | 342 | 22.7k | T* ptr = item_ptr(p); | 343 | 22.7k | T* dst = ptr + count; | 344 | 22.7k | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 22.7k | _size += count; | 346 | 22.7k | fill(ptr, first, last); | 347 | 22.7k | } |
void prevector<8u, int, unsigned int, int>::insert<int*>(prevector<8u, int, unsigned int, int>::iterator, int*, int*) Line | Count | Source | 335 | 4.24k | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 4.24k | size_type p = pos - begin(); | 337 | 4.24k | difference_type count = last - first; | 338 | 4.24k | size_type new_size = size() + count; | 339 | 4.24k | if (capacity() < new_size) { | 340 | 338 | change_capacity(new_size + (new_size >> 1)); | 341 | 338 | } | 342 | 4.24k | T* ptr = item_ptr(p); | 343 | 4.24k | T* dst = ptr + count; | 344 | 4.24k | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 4.24k | _size += count; | 346 | 4.24k | fill(ptr, first, last); | 347 | 4.24k | } |
void prevector<36u, unsigned char, unsigned int, int>::insert<__gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>>(prevector<36u, unsigned char, unsigned int, int>::iterator, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>, __gnu_cxx::__normal_iterator<unsigned char*, std::vector<unsigned char, std::allocator<unsigned char>>>) Line | Count | Source | 335 | 2.74k | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 2.74k | size_type p = pos - begin(); | 337 | 2.74k | difference_type count = last - first; | 338 | 2.74k | size_type new_size = size() + count; | 339 | 2.74k | if (capacity() < new_size) { | 340 | 238 | change_capacity(new_size + (new_size >> 1)); | 341 | 238 | } | 342 | 2.74k | T* ptr = item_ptr(p); | 343 | 2.74k | T* dst = ptr + count; | 344 | 2.74k | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 2.74k | _size += count; | 346 | 2.74k | fill(ptr, first, last); | 347 | 2.74k | } |
void prevector<36u, unsigned char, unsigned int, int>::insert<prevector<36u, unsigned char, unsigned int, int>::const_iterator>(prevector<36u, unsigned char, unsigned int, int>::iterator, prevector<36u, unsigned char, unsigned int, int>::const_iterator, prevector<36u, unsigned char, unsigned int, int>::const_iterator) Line | Count | Source | 335 | 2.75M | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 2.75M | size_type p = pos - begin(); | 337 | 2.75M | difference_type count = last - first; | 338 | 2.75M | size_type new_size = size() + count; | 339 | 2.75M | if (capacity() < new_size) { | 340 | 128k | change_capacity(new_size + (new_size >> 1)); | 341 | 128k | } | 342 | 2.75M | T* ptr = item_ptr(p); | 343 | 2.75M | T* dst = ptr + count; | 344 | 2.75M | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 2.75M | _size += count; | 346 | 2.75M | fill(ptr, first, last); | 347 | 2.75M | } |
void prevector<35u, unsigned char, unsigned int, int>::insert<unsigned char*>(prevector<35u, unsigned char, unsigned int, int>::iterator, unsigned char*, unsigned char*) Line | Count | Source | 335 | 190 | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 190 | size_type p = pos - begin(); | 337 | 190 | difference_type count = last - first; | 338 | 190 | size_type new_size = size() + count; | 339 | 190 | if (capacity() < new_size) { | 340 | 0 | change_capacity(new_size + (new_size >> 1)); | 341 | 0 | } | 342 | 190 | T* ptr = item_ptr(p); | 343 | 190 | T* dst = ptr + count; | 344 | 190 | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 190 | _size += count; | 346 | 190 | fill(ptr, first, last); | 347 | 190 | } |
void prevector<35u, unsigned char, unsigned int, int>::insert<unsigned char const*>(prevector<35u, unsigned char, unsigned int, int>::iterator, unsigned char const*, unsigned char const*) Line | Count | Source | 335 | 190 | void insert(iterator pos, InputIterator first, InputIterator last) { | 336 | 190 | size_type p = pos - begin(); | 337 | 190 | difference_type count = last - first; | 338 | 190 | size_type new_size = size() + count; | 339 | 190 | if (capacity() < new_size) { | 340 | 0 | change_capacity(new_size + (new_size >> 1)); | 341 | 0 | } | 342 | 190 | T* ptr = item_ptr(p); | 343 | 190 | T* dst = ptr + count; | 344 | 190 | memmove(dst, ptr, (size() - p) * sizeof(T)); | 345 | 190 | _size += count; | 346 | 190 | fill(ptr, first, last); | 347 | 190 | } |
|
348 | | |
349 | 981k | inline void resize_uninitialized(size_type new_size) { |
350 | | // resize_uninitialized changes the size of the prevector but does not initialize it. |
351 | | // If size < new_size, the added elements must be initialized explicitly. |
352 | 981k | if (capacity() < new_size) { |
353 | 216k | change_capacity(new_size); |
354 | 216k | _size += new_size - size(); |
355 | 216k | return; |
356 | 216k | } |
357 | 764k | if (new_size < size()) { |
358 | 3.20k | erase(item_ptr(new_size), end()); |
359 | 761k | } else { |
360 | 761k | _size += new_size - size(); |
361 | 761k | } |
362 | 764k | } prevector<36u, unsigned char, unsigned int, int>::resize_uninitialized(unsigned int) Line | Count | Source | 349 | 972k | inline void resize_uninitialized(size_type new_size) { | 350 | | // resize_uninitialized changes the size of the prevector but does not initialize it. | 351 | | // If size < new_size, the added elements must be initialized explicitly. | 352 | 972k | if (capacity() < new_size) { | 353 | 215k | change_capacity(new_size); | 354 | 215k | _size += new_size - size(); | 355 | 215k | return; | 356 | 215k | } | 357 | 757k | if (new_size < size()) { | 358 | 0 | erase(item_ptr(new_size), end()); | 359 | 757k | } else { | 360 | 757k | _size += new_size - size(); | 361 | 757k | } | 362 | 757k | } |
prevector<8u, int, unsigned int, int>::resize_uninitialized(unsigned int) Line | Count | Source | 349 | 8.06k | inline void resize_uninitialized(size_type new_size) { | 350 | | // resize_uninitialized changes the size of the prevector but does not initialize it. | 351 | | // If size < new_size, the added elements must be initialized explicitly. | 352 | 8.06k | if (capacity() < new_size) { | 353 | 1.17k | change_capacity(new_size); | 354 | 1.17k | _size += new_size - size(); | 355 | 1.17k | return; | 356 | 1.17k | } | 357 | 6.89k | if (new_size < size()) { | 358 | 3.20k | erase(item_ptr(new_size), end()); | 359 | 3.69k | } else { | 360 | 3.69k | _size += new_size - size(); | 361 | 3.69k | } | 362 | 6.89k | } |
|
363 | | |
364 | 27.6k | iterator erase(iterator pos) { |
365 | 27.6k | return erase(pos, pos + 1); |
366 | 27.6k | } |
367 | | |
368 | 10.9M | iterator erase(iterator first, iterator last) { |
369 | | // Erase is not allowed to the change the object's capacity. That means |
370 | | // that when starting with an indirectly allocated prevector with |
371 | | // size and capacity > N, the result may be a still indirectly allocated |
372 | | // prevector with size <= N and capacity > N. A shrink_to_fit() call is |
373 | | // necessary to switch to the (more efficient) directly allocated |
374 | | // representation (with capacity N and size <= N). |
375 | 10.9M | iterator p = first; |
376 | 10.9M | char* endp = (char*)&(*end()); |
377 | 10.9M | _size -= last - p; |
378 | 10.9M | memmove(&(*first), &(*last), endp - ((char*)(&(*last)))); |
379 | 10.9M | return first; |
380 | 10.9M | } prevector<36u, unsigned char, unsigned int, int>::erase(prevector<36u, unsigned char, unsigned int, int>::iterator, prevector<36u, unsigned char, unsigned int, int>::iterator) Line | Count | Source | 368 | 10.2M | iterator erase(iterator first, iterator last) { | 369 | | // Erase is not allowed to the change the object's capacity. That means | 370 | | // that when starting with an indirectly allocated prevector with | 371 | | // size and capacity > N, the result may be a still indirectly allocated | 372 | | // prevector with size <= N and capacity > N. A shrink_to_fit() call is | 373 | | // necessary to switch to the (more efficient) directly allocated | 374 | | // representation (with capacity N and size <= N). | 375 | 10.2M | iterator p = first; | 376 | 10.2M | char* endp = (char*)&(*end()); | 377 | 10.2M | _size -= last - p; | 378 | 10.2M | memmove(&(*first), &(*last), endp - ((char*)(&(*last)))); | 379 | 10.2M | return first; | 380 | 10.2M | } |
prevector<16u, unsigned char, unsigned int, int>::erase(prevector<16u, unsigned char, unsigned int, int>::iterator, prevector<16u, unsigned char, unsigned int, int>::iterator) Line | Count | Source | 368 | 658k | iterator erase(iterator first, iterator last) { | 369 | | // Erase is not allowed to the change the object's capacity. That means | 370 | | // that when starting with an indirectly allocated prevector with | 371 | | // size and capacity > N, the result may be a still indirectly allocated | 372 | | // prevector with size <= N and capacity > N. A shrink_to_fit() call is | 373 | | // necessary to switch to the (more efficient) directly allocated | 374 | | // representation (with capacity N and size <= N). | 375 | 658k | iterator p = first; | 376 | 658k | char* endp = (char*)&(*end()); | 377 | 658k | _size -= last - p; | 378 | 658k | memmove(&(*first), &(*last), endp - ((char*)(&(*last)))); | 379 | 658k | return first; | 380 | 658k | } |
prevector<8u, int, unsigned int, int>::erase(prevector<8u, int, unsigned int, int>::iterator, prevector<8u, int, unsigned int, int>::iterator) Line | Count | Source | 368 | 70.2k | iterator erase(iterator first, iterator last) { | 369 | | // Erase is not allowed to the change the object's capacity. That means | 370 | | // that when starting with an indirectly allocated prevector with | 371 | | // size and capacity > N, the result may be a still indirectly allocated | 372 | | // prevector with size <= N and capacity > N. A shrink_to_fit() call is | 373 | | // necessary to switch to the (more efficient) directly allocated | 374 | | // representation (with capacity N and size <= N). | 375 | 70.2k | iterator p = first; | 376 | 70.2k | char* endp = (char*)&(*end()); | 377 | 70.2k | _size -= last - p; | 378 | 70.2k | memmove(&(*first), &(*last), endp - ((char*)(&(*last)))); | 379 | 70.2k | return first; | 380 | 70.2k | } |
Unexecuted instantiation: prevector<33u, unsigned char, unsigned int, int>::erase(prevector<33u, unsigned char, unsigned int, int>::iterator, prevector<33u, unsigned char, unsigned int, int>::iterator) |
381 | | |
382 | | template<typename... Args> |
383 | 80.4k | void emplace_back(Args&&... args) { |
384 | 80.4k | size_type new_size = size() + 1; |
385 | 80.4k | if (capacity() < new_size) { |
386 | 13.2k | change_capacity(new_size + (new_size >> 1)); |
387 | 13.2k | } |
388 | 80.4k | new(item_ptr(size())) T(std::forward<Args>(args)...); |
389 | 80.4k | _size++; |
390 | 80.4k | } void prevector<36u, unsigned char, unsigned int, int>::emplace_back<unsigned char const&>(unsigned char const&) Line | Count | Source | 383 | 72.0k | void emplace_back(Args&&... args) { | 384 | 72.0k | size_type new_size = size() + 1; | 385 | 72.0k | if (capacity() < new_size) { | 386 | 13.0k | change_capacity(new_size + (new_size >> 1)); | 387 | 13.0k | } | 388 | 72.0k | new(item_ptr(size())) T(std::forward<Args>(args)...); | 389 | 72.0k | _size++; | 390 | 72.0k | } |
void prevector<8u, int, unsigned int, int>::emplace_back<int const&>(int const&) Line | Count | Source | 383 | 8.27k | void emplace_back(Args&&... args) { | 384 | 8.27k | size_type new_size = size() + 1; | 385 | 8.27k | if (capacity() < new_size) { | 386 | 234 | change_capacity(new_size + (new_size >> 1)); | 387 | 234 | } | 388 | 8.27k | new(item_ptr(size())) T(std::forward<Args>(args)...); | 389 | 8.27k | _size++; | 390 | 8.27k | } |
void prevector<4u, Network, unsigned int, int>::emplace_back<Network const&>(Network const&) Line | Count | Source | 383 | 74 | void emplace_back(Args&&... args) { | 384 | 74 | size_type new_size = size() + 1; | 385 | 74 | if (capacity() < new_size) { | 386 | 0 | change_capacity(new_size + (new_size >> 1)); | 387 | 0 | } | 388 | 74 | new(item_ptr(size())) T(std::forward<Args>(args)...); | 389 | 74 | _size++; | 390 | 74 | } |
|
391 | | |
392 | 80.4k | void push_back(const T& value) { |
393 | 80.4k | emplace_back(value); |
394 | 80.4k | } prevector<36u, unsigned char, unsigned int, int>::push_back(unsigned char const&) Line | Count | Source | 392 | 72.0k | void push_back(const T& value) { | 393 | 72.0k | emplace_back(value); | 394 | 72.0k | } |
prevector<8u, int, unsigned int, int>::push_back(int const&) Line | Count | Source | 392 | 8.27k | void push_back(const T& value) { | 393 | 8.27k | emplace_back(value); | 394 | 8.27k | } |
prevector<4u, Network, unsigned int, int>::push_back(Network const&) Line | Count | Source | 392 | 74 | void push_back(const T& value) { | 393 | 74 | emplace_back(value); | 394 | 74 | } |
|
395 | | |
396 | 6.70k | void pop_back() { |
397 | 6.70k | erase(end() - 1, end()); |
398 | 6.70k | } |
399 | | |
400 | | T& front() { |
401 | | return *item_ptr(0); |
402 | | } |
403 | | |
404 | | const T& front() const { |
405 | | return *item_ptr(0); |
406 | | } |
407 | | |
408 | | T& back() { |
409 | | return *item_ptr(size() - 1); |
410 | | } |
411 | | |
412 | 27.6k | const T& back() const { |
413 | 27.6k | return *item_ptr(size() - 1); |
414 | 27.6k | } |
415 | | |
416 | | void swap(prevector<N, T, Size, Diff>& other) noexcept |
417 | 16.4k | { |
418 | 16.4k | std::swap(_union, other._union); |
419 | 16.4k | std::swap(_size, other._size); |
420 | 16.4k | } |
421 | | |
422 | 147M | ~prevector() { |
423 | 147M | if (!is_direct()) { |
424 | 2.25M | free(_union.indirect_contents.indirect); |
425 | 2.25M | _union.indirect_contents.indirect = nullptr; |
426 | 2.25M | } |
427 | 147M | } prevector<16u, unsigned char, unsigned int, int>::~prevector() Line | Count | Source | 422 | 5.93M | ~prevector() { | 423 | 5.93M | if (!is_direct()) { | 424 | 1.98k | free(_union.indirect_contents.indirect); | 425 | 1.98k | _union.indirect_contents.indirect = nullptr; | 426 | 1.98k | } | 427 | 5.93M | } |
prevector<36u, unsigned char, unsigned int, int>::~prevector() Line | Count | Source | 422 | 140M | ~prevector() { | 423 | 140M | if (!is_direct()) { | 424 | 2.05M | free(_union.indirect_contents.indirect); | 425 | 2.05M | _union.indirect_contents.indirect = nullptr; | 426 | 2.05M | } | 427 | 140M | } |
prevector<33u, unsigned char, unsigned int, int>::~prevector() Line | Count | Source | 422 | 565k | ~prevector() { | 423 | 565k | if (!is_direct()) { | 424 | 0 | free(_union.indirect_contents.indirect); | 425 | 0 | _union.indirect_contents.indirect = nullptr; | 426 | 0 | } | 427 | 565k | } |
prevector<8u, int, unsigned int, int>::~prevector() Line | Count | Source | 422 | 535k | ~prevector() { | 423 | 535k | if (!is_direct()) { | 424 | 197k | free(_union.indirect_contents.indirect); | 425 | 197k | _union.indirect_contents.indirect = nullptr; | 426 | 197k | } | 427 | 535k | } |
prevector<4u, Network, unsigned int, int>::~prevector() Line | Count | Source | 422 | 20 | ~prevector() { | 423 | 20 | if (!is_direct()) { | 424 | 0 | free(_union.indirect_contents.indirect); | 425 | 0 | _union.indirect_contents.indirect = nullptr; | 426 | 0 | } | 427 | 20 | } |
prevector<35u, unsigned char, unsigned int, int>::~prevector() Line | Count | Source | 422 | 190 | ~prevector() { | 423 | 190 | if (!is_direct()) { | 424 | 0 | free(_union.indirect_contents.indirect); | 425 | 0 | _union.indirect_contents.indirect = nullptr; | 426 | 0 | } | 427 | 190 | } |
|
428 | | |
429 | 6.54M | constexpr bool operator==(const prevector& other) const { |
430 | 6.54M | return std::ranges::equal(*this, other); |
431 | 6.54M | } prevector<36u, unsigned char, unsigned int, int>::operator==(prevector<36u, unsigned char, unsigned int, int> const&) const Line | Count | Source | 429 | 5.78M | constexpr bool operator==(const prevector& other) const { | 430 | 5.78M | return std::ranges::equal(*this, other); | 431 | 5.78M | } |
prevector<8u, int, unsigned int, int>::operator==(prevector<8u, int, unsigned int, int> const&) const Line | Count | Source | 429 | 535k | constexpr bool operator==(const prevector& other) const { | 430 | 535k | return std::ranges::equal(*this, other); | 431 | 535k | } |
prevector<16u, unsigned char, unsigned int, int>::operator==(prevector<16u, unsigned char, unsigned int, int> const&) const Line | Count | Source | 429 | 217k | constexpr bool operator==(const prevector& other) const { | 430 | 217k | return std::ranges::equal(*this, other); | 431 | 217k | } |
|
432 | | |
433 | 21.4M | bool operator<(const prevector<N, T, Size, Diff>& other) const { |
434 | 21.4M | if (size() < other.size()) { |
435 | 790k | return true; |
436 | 790k | } |
437 | 20.6M | if (size() > other.size()) { |
438 | 285k | return false; |
439 | 285k | } |
440 | 20.4M | const_iterator b1 = begin(); |
441 | 20.4M | const_iterator b2 = other.begin(); |
442 | 20.4M | const_iterator e1 = end(); |
443 | 133M | while (b1 != e1) { |
444 | 130M | if ((*b1) < (*b2)) { |
445 | 9.99M | return true; |
446 | 9.99M | } |
447 | 120M | if ((*b2) < (*b1)) { |
448 | 7.66M | return false; |
449 | 7.66M | } |
450 | 112M | ++b1; |
451 | 112M | ++b2; |
452 | 112M | } |
453 | 2.75M | return false; |
454 | 20.4M | } prevector<36u, unsigned char, unsigned int, int>::operator<(prevector<36u, unsigned char, unsigned int, int> const&) const Line | Count | Source | 433 | 21.4M | bool operator<(const prevector<N, T, Size, Diff>& other) const { | 434 | 21.4M | if (size() < other.size()) { | 435 | 790k | return true; | 436 | 790k | } | 437 | 20.6M | if (size() > other.size()) { | 438 | 285k | return false; | 439 | 285k | } | 440 | 20.3M | const_iterator b1 = begin(); | 441 | 20.3M | const_iterator b2 = other.begin(); | 442 | 20.3M | const_iterator e1 = end(); | 443 | 132M | while (b1 != e1) { | 444 | 130M | if ((*b1) < (*b2)) { | 445 | 9.99M | return true; | 446 | 9.99M | } | 447 | 120M | if ((*b2) < (*b1)) { | 448 | 7.66M | return false; | 449 | 7.66M | } | 450 | 112M | ++b1; | 451 | 112M | ++b2; | 452 | 112M | } | 453 | 2.72M | return false; | 454 | 20.3M | } |
prevector<16u, unsigned char, unsigned int, int>::operator<(prevector<16u, unsigned char, unsigned int, int> const&) const Line | Count | Source | 433 | 26.6k | bool operator<(const prevector<N, T, Size, Diff>& other) const { | 434 | 26.6k | if (size() < other.size()) { | 435 | 0 | return true; | 436 | 0 | } | 437 | 26.6k | if (size() > other.size()) { | 438 | 0 | return false; | 439 | 0 | } | 440 | 26.6k | const_iterator b1 = begin(); | 441 | 26.6k | const_iterator b2 = other.begin(); | 442 | 26.6k | const_iterator e1 = end(); | 443 | 133k | while (b1 != e1) { | 444 | 107k | if ((*b1) < (*b2)) { | 445 | 330 | return true; | 446 | 330 | } | 447 | 106k | if ((*b2) < (*b1)) { | 448 | 108 | return false; | 449 | 108 | } | 450 | 106k | ++b1; | 451 | 106k | ++b2; | 452 | 106k | } | 453 | 26.1k | return false; | 454 | 26.6k | } |
|
455 | | |
456 | 39.5M | size_t allocated_memory() const { |
457 | 39.5M | if (is_direct()) { |
458 | 38.6M | return 0; |
459 | 38.6M | } else { |
460 | 878k | return ((size_t)(sizeof(T))) * _union.indirect_contents.capacity; |
461 | 878k | } |
462 | 39.5M | } |
463 | | |
464 | 552k | value_type* data() { |
465 | 552k | return item_ptr(0); |
466 | 552k | } prevector<16u, unsigned char, unsigned int, int>::data() Line | Count | Source | 464 | 41.8k | value_type* data() { | 465 | 41.8k | return item_ptr(0); | 466 | 41.8k | } |
prevector<33u, unsigned char, unsigned int, int>::data() Line | Count | Source | 464 | 214k | value_type* data() { | 465 | 214k | return item_ptr(0); | 466 | 214k | } |
prevector<36u, unsigned char, unsigned int, int>::data() Line | Count | Source | 464 | 296k | value_type* data() { | 465 | 296k | return item_ptr(0); | 466 | 296k | } |
prevector<35u, unsigned char, unsigned int, int>::data() Line | Count | Source | 464 | 190 | value_type* data() { | 465 | 190 | return item_ptr(0); | 466 | 190 | } |
|
467 | | |
468 | 30.9M | const value_type* data() const { |
469 | 30.9M | return item_ptr(0); |
470 | 30.9M | } prevector<16u, unsigned char, unsigned int, int>::data() const Line | Count | Source | 468 | 2.70M | const value_type* data() const { | 469 | 2.70M | return item_ptr(0); | 470 | 2.70M | } |
prevector<36u, unsigned char, unsigned int, int>::data() const Line | Count | Source | 468 | 28.1M | const value_type* data() const { | 469 | 28.1M | return item_ptr(0); | 470 | 28.1M | } |
prevector<33u, unsigned char, unsigned int, int>::data() const Line | Count | Source | 468 | 86.6k | const value_type* data() const { | 469 | 86.6k | return item_ptr(0); | 470 | 86.6k | } |
|
471 | | }; |
472 | | |
473 | | #endif // BITCOIN_PREVECTOR_H |