Coverage Report

Created: 2026-05-06 07:53

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/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
85.1M
        iterator(T* ptr_) : ptr(ptr_) {}
prevector<36u, unsigned char, unsigned int, int>::iterator::iterator(unsigned char*)
Line
Count
Source
60
68.2M
        iterator(T* ptr_) : ptr(ptr_) {}
prevector<16u, unsigned char, unsigned int, int>::iterator::iterator(unsigned char*)
Line
Count
Source
60
1.96M
        iterator(T* ptr_) : ptr(ptr_) {}
prevector<8u, int, unsigned int, int>::iterator::iterator(int*)
Line
Count
Source
60
14.8M
        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
708
        iterator(T* ptr_) : ptr(ptr_) {}
61
141M
        T& operator*() const { return *ptr; }
prevector<36u, unsigned char, unsigned int, int>::iterator::operator*() const
Line
Count
Source
61
126M
        T& operator*() const { return *ptr; }
prevector<16u, unsigned char, unsigned int, int>::iterator::operator*() const
Line
Count
Source
61
3.93M
        T& operator*() const { return *ptr; }
prevector<8u, int, unsigned int, int>::iterator::operator*() const
Line
Count
Source
61
11.7M
        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
708
        T& operator*() const { return *ptr; }
62
35.2k
        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.2k
        T* operator->() const { return ptr; }
Unexecuted instantiation: prevector<35u, unsigned char, unsigned int, int>::iterator::operator->() const
63
2.12M
        T& operator[](size_type pos) const { return ptr[pos]; }
64
41.9M
        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.25M
        iterator& operator++() { ptr++; return *this; }
65
4.25M
        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.3M
        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.3M
        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
656k
        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
354
        difference_type friend operator-(iterator a, iterator b) { return (&(*a) - &(*b)); }
69
4.40M
        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.13M
        iterator operator-(size_type n) const { return iterator(ptr - n); }
73
        iterator& operator-=(size_type n) { ptr -= n; return *this; }
74
45.0M
        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
7.18M
        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.57G
        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.56G
        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
738k
        const_iterator(iterator x) : ptr(&(*x)) {}
89
17.7G
        const T& operator*() const { return *ptr; }
prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator*() const
Line
Count
Source
89
17.7G
        const T& operator*() const { return *ptr; }
prevector<16u, unsigned char, unsigned int, int>::const_iterator::operator*() const
Line
Count
Source
89
19.0M
        const T& operator*() const { return *ptr; }
prevector<8u, int, unsigned int, int>::const_iterator::operator*() const
Line
Count
Source
89
17.1M
        const T& operator*() const { return *ptr; }
90
3.85M
        const T* operator->() const { return ptr; }
prevector<16u, unsigned char, unsigned int, int>::const_iterator::operator->() const
Line
Count
Source
90
479
        const T* operator->() const { return ptr; }
prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator->() const
Line
Count
Source
90
3.85M
        const T* operator->() const { return ptr; }
91
179k
        const T& operator[](size_type pos) const { return ptr[pos]; }
92
15.9G
        const_iterator& operator++() { ptr++; return *this; }
prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator++()
Line
Count
Source
92
15.9G
        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.8M
        const_iterator& operator++() { ptr++; return *this; }
93
4.25M
        const_iterator& operator--() { ptr--; return *this; }
prevector<8u, int, unsigned int, int>::const_iterator::operator--()
Line
Count
Source
93
4.25M
        const_iterator& operator--() { ptr--; return *this; }
Unexecuted instantiation: prevector<36u, unsigned char, unsigned int, int>::const_iterator::operator--()
94
686M
        const_iterator operator++(int) { const_iterator copy(*this); ++(*this); return copy; }
95
        const_iterator operator--(int) { const_iterator copy(*this); --(*this); return copy; }
96
736M
        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
734M
        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.03M
        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.2G
        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.2G
        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
12.0M
        bool operator==(const_iterator x) const { return ptr == x.ptr; }
103
1.36G
        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.36G
        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
115M
    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
103M
    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.02M
    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
682k
    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.85M
    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
104
    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.41k
    T* direct_ptr(difference_type pos) { return reinterpret_cast<T*>(_union.direct) + pos; }
123
276M
    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
252M
    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.55M
    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
87.5k
    const T* direct_ptr(difference_type pos) const { return reinterpret_cast<const T*>(_union.direct) + pos; }
124
35.3M
    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.30k
    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.9M
    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.34G
    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.34G
    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.66k
    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.20M
    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.05G
    bool is_direct() const { return _size <= N; }
prevector<36u, unsigned char, unsigned int, int>::is_direct() const
Line
Count
Source
126
3.96G
    bool is_direct() const { return _size <= N; }
prevector<16u, unsigned char, unsigned int, int>::is_direct() const
Line
Count
Source
126
58.7M
    bool is_direct() const { return _size <= N; }
prevector<33u, unsigned char, unsigned int, int>::is_direct() const
Line
Count
Source
126
1.88M
    bool is_direct() const { return _size <= N; }
prevector<8u, int, unsigned int, int>::is_direct() const
Line
Count
Source
126
29.6M
    bool is_direct() const { return _size <= N; }
prevector<4u, Network, unsigned int, int>::is_direct() const
Line
Count
Source
126
416
    bool is_direct() const { return _size <= N; }
prevector<35u, unsigned char, unsigned int, int>::is_direct() const
Line
Count
Source
126
3.36k
    bool is_direct() const { return _size <= N; }
127
128
119M
    void change_capacity(size_type new_capacity) {
129
119M
        if (new_capacity <= N) {
130
117M
            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
117M
        } else {
139
2.40M
            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.31M
            } else {
147
2.31M
                char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity));
148
2.31M
                assert(new_indirect);
149
2.31M
                T* src = direct_ptr(0);
150
2.31M
                T* dst = reinterpret_cast<T*>(new_indirect);
151
2.31M
                memcpy(dst, src, size() * sizeof(T));
152
2.31M
                _union.indirect_contents.indirect = new_indirect;
153
2.31M
                _union.indirect_contents.capacity = new_capacity;
154
2.31M
                _size += N + 1;
155
2.31M
            }
156
2.40M
        }
157
119M
    }
prevector<36u, unsigned char, unsigned int, int>::change_capacity(unsigned int)
Line
Count
Source
128
113M
    void change_capacity(size_type new_capacity) {
129
113M
        if (new_capacity <= N) {
130
111M
            if (!is_direct()) {
131
44.1k
                T* indirect = indirect_ptr(0);
132
44.1k
                T* src = indirect;
133
44.1k
                T* dst = direct_ptr(0);
134
44.1k
                memcpy(dst, src, size() * sizeof(T));
135
44.1k
                free(indirect);
136
44.1k
                _size -= N + 1;
137
44.1k
            }
138
111M
        } else {
139
2.18M
            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.6k
                _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity));
144
78.6k
                assert(_union.indirect_contents.indirect);
145
78.6k
                _union.indirect_contents.capacity = new_capacity;
146
2.10M
            } else {
147
2.10M
                char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity));
148
2.10M
                assert(new_indirect);
149
2.10M
                T* src = direct_ptr(0);
150
2.10M
                T* dst = reinterpret_cast<T*>(new_indirect);
151
2.10M
                memcpy(dst, src, size() * sizeof(T));
152
2.10M
                _union.indirect_contents.indirect = new_indirect;
153
2.10M
                _union.indirect_contents.capacity = new_capacity;
154
2.10M
                _size += N + 1;
155
2.10M
            }
156
2.18M
        }
157
113M
    }
prevector<16u, unsigned char, unsigned int, int>::change_capacity(unsigned int)
Line
Count
Source
128
5.39M
    void change_capacity(size_type new_capacity) {
129
5.39M
        if (new_capacity <= N) {
130
5.39M
            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.39M
        } else {
139
1.97k
            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.97k
            } else {
147
1.97k
                char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity));
148
1.97k
                assert(new_indirect);
149
1.97k
                T* src = direct_ptr(0);
150
1.97k
                T* dst = reinterpret_cast<T*>(new_indirect);
151
1.97k
                memcpy(dst, src, size() * sizeof(T));
152
1.97k
                _union.indirect_contents.indirect = new_indirect;
153
1.97k
                _union.indirect_contents.capacity = new_capacity;
154
1.97k
                _size += N + 1;
155
1.97k
            }
156
1.97k
        }
157
5.39M
    }
prevector<33u, unsigned char, unsigned int, int>::change_capacity(unsigned int)
Line
Count
Source
128
87.5k
    void change_capacity(size_type new_capacity) {
129
87.5k
        if (new_capacity <= N) {
130
87.5k
            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
87.5k
        } 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
87.5k
    }
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
330k
            if (!is_direct()) {
131
591
                T* indirect = indirect_ptr(0);
132
591
                T* src = indirect;
133
591
                T* dst = direct_ptr(0);
134
591
                memcpy(dst, src, size() * sizeof(T));
135
591
                free(indirect);
136
591
                _size -= N + 1;
137
591
            }
138
330k
        } else {
139
213k
            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.32k
                _union.indirect_contents.indirect = static_cast<char*>(realloc(_union.indirect_contents.indirect, ((size_t)sizeof(T)) * new_capacity));
144
4.32k
                assert(_union.indirect_contents.indirect);
145
4.32k
                _union.indirect_contents.capacity = new_capacity;
146
209k
            } else {
147
209k
                char* new_indirect = static_cast<char*>(malloc(((size_t)sizeof(T)) * new_capacity));
148
209k
                assert(new_indirect);
149
209k
                T* src = direct_ptr(0);
150
209k
                T* dst = reinterpret_cast<T*>(new_indirect);
151
209k
                memcpy(dst, src, size() * sizeof(T));
152
209k
                _union.indirect_contents.indirect = new_indirect;
153
209k
                _union.indirect_contents.capacity = new_capacity;
154
209k
                _size += N + 1;
155
209k
            }
156
213k
        }
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
177
    void change_capacity(size_type new_capacity) {
129
177
        if (new_capacity <= N) {
130
177
            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
177
        } 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
177
    }
158
159
148M
    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
121M
    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.02M
    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
682k
    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.5M
    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
104
    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.41k
    T* item_ptr(difference_type pos) { return is_direct() ? direct_ptr(pos) : indirect_ptr(pos); }
160
1.62G
    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.59G
    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
87.5k
    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
531k
    void fill(T* dst, ptrdiff_t count, const T& value = T{}) {
163
531k
        std::fill_n(dst, count, value);
164
531k
    }
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.37M
    void fill(T* dst, ptrdiff_t count, const T& value = T{}) {
163
2.37M
        std::fill_n(dst, count, value);
164
2.37M
    }
prevector<8u, int, unsigned int, int>::fill(int*, long, int const&)
Line
Count
Source
162
23.1k
    void fill(T* dst, ptrdiff_t count, const T& value = T{}) {
163
23.1k
        std::fill_n(dst, count, value);
164
23.1k
    }
165
166
    template <std::input_iterator InputIterator>
167
55.0M
    void fill(T* dst, InputIterator first, InputIterator last) {
168
15.2G
        while (first != last) {
169
15.1G
            new(static_cast<void*>(dst)) T(*first);
170
15.1G
            ++dst;
171
15.1G
            ++first;
172
15.1G
        }
173
55.0M
    }
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
87.4M
        while (first != last) {
169
84.7M
            new(static_cast<void*>(dst)) T(*first);
170
84.7M
            ++dst;
171
84.7M
            ++first;
172
84.7M
        }
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.4M
            new(static_cast<void*>(dst)) T(*first);
170
12.4M
            ++dst;
171
12.4M
            ++first;
172
12.4M
        }
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
47.9M
    void fill(T* dst, InputIterator first, InputIterator last) {
168
15.0G
        while (first != last) {
169
14.9G
            new(static_cast<void*>(dst)) T(*first);
170
14.9G
            ++dst;
171
14.9G
            ++first;
172
14.9G
        }
173
47.9M
    }
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.62M
        while (first != last) {
169
1.58M
            new(static_cast<void*>(dst)) T(*first);
170
1.58M
            ++dst;
171
1.58M
            ++first;
172
1.58M
        }
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.39M
        while (first != last) {
169
2.12M
            new(static_cast<void*>(dst)) T(*first);
170
2.12M
            ++dst;
171
2.12M
            ++first;
172
2.12M
        }
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.39M
        while (first != last) {
169
2.12M
            new(static_cast<void*>(dst)) T(*first);
170
2.12M
            ++dst;
171
2.12M
            ++first;
172
2.12M
        }
173
267k
    }
void prevector<8u, int, unsigned int, int>::fill<int*>(int*, int*, int*)
Line
Count
Source
167
4.00k
    void fill(T* dst, InputIterator first, InputIterator last) {
168
13.9k
        while (first != last) {
169
9.98k
            new(static_cast<void*>(dst)) T(*first);
170
9.98k
            ++dst;
171
9.98k
            ++first;
172
9.98k
        }
173
4.00k
    }
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.14k
    void fill(T* dst, InputIterator first, InputIterator last) {
168
55.6k
        while (first != last) {
169
47.4k
            new(static_cast<void*>(dst)) T(*first);
170
47.4k
            ++dst;
171
47.4k
            ++first;
172
47.4k
        }
173
8.14k
    }
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
191k
    void fill(T* dst, InputIterator first, InputIterator last) {
168
29.4M
        while (first != last) {
169
29.2M
            new(static_cast<void*>(dst)) T(*first);
170
29.2M
            ++dst;
171
29.2M
            ++first;
172
29.2M
        }
173
191k
    }
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
571k
    void fill(T* dst, InputIterator first, InputIterator last) {
168
2.85M
        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
571k
    }
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
177
    void fill(T* dst, InputIterator first, InputIterator last) {
168
5.84k
        while (first != last) {
169
5.66k
            new(static_cast<void*>(dst)) T(*first);
170
5.66k
            ++dst;
171
5.66k
            ++first;
172
5.66k
        }
173
177
    }
void prevector<35u, unsigned char, unsigned int, int>::fill<unsigned char*>(unsigned char*, unsigned char*, unsigned char*)
Line
Count
Source
167
177
    void fill(T* dst, InputIterator first, InputIterator last) {
168
531
        while (first != last) {
169
354
            new(static_cast<void*>(dst)) T(*first);
170
354
            ++dst;
171
354
            ++first;
172
354
        }
173
177
    }
void prevector<35u, unsigned char, unsigned int, int>::fill<unsigned char const*>(unsigned char*, unsigned char const*, unsigned char const*)
Line
Count
Source
167
177
    void fill(T* dst, InputIterator first, InputIterator last) {
168
354
        while (first != last) {
169
177
            new(static_cast<void*>(dst)) T(*first);
170
177
            ++dst;
171
177
            ++first;
172
177
        }
173
177
    }
174
175
public:
176
144k
    void assign(size_type n, const T& val) {
177
144k
        clear();
178
144k
        if (capacity() < n) {
179
94.3k
            change_capacity(n);
180
94.3k
        }
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
256
    void assign(size_type n, const T& val) {
177
256
        clear();
178
256
        if (capacity() < n) {
179
115
            change_capacity(n);
180
115
        }
181
256
        _size += n;
182
256
        fill(item_ptr(0), n, val);
183
256
    }
184
185
    template <std::input_iterator InputIterator>
186
2.42M
    void assign(InputIterator first, InputIterator last) {
187
2.42M
        size_type n = last - first;
188
2.42M
        clear();
189
2.42M
        if (capacity() < n) {
190
119k
            change_capacity(n);
191
119k
        }
192
2.42M
        _size += n;
193
2.42M
        fill(item_ptr(0), first, last);
194
2.42M
    }
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.80M
    void assign(InputIterator first, InputIterator last) {
187
1.80M
        size_type n = last - first;
188
1.80M
        clear();
189
1.80M
        if (capacity() < n) {
190
119k
            change_capacity(n);
191
119k
        }
192
1.80M
        _size += n;
193
1.80M
        fill(item_ptr(0), first, last);
194
1.80M
    }
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
33.1k
    void assign(InputIterator first, InputIterator last) {
187
33.1k
        size_type n = last - first;
188
33.1k
        clear();
189
33.1k
        if (capacity() < n) {
190
35
            change_capacity(n);
191
35
        }
192
33.1k
        _size += n;
193
33.1k
        fill(item_ptr(0), first, last);
194
33.1k
    }
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.14k
    void assign(InputIterator first, InputIterator last) {
187
8.14k
        size_type n = last - first;
188
8.14k
        clear();
189
8.14k
        if (capacity() < n) {
190
621
            change_capacity(n);
191
621
        }
192
8.14k
        _size += n;
193
8.14k
        fill(item_ptr(0), first, last);
194
8.14k
    }
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
571k
    void assign(InputIterator first, InputIterator last) {
187
571k
        size_type n = last - first;
188
571k
        clear();
189
571k
        if (capacity() < n) {
190
0
            change_capacity(n);
191
0
        }
192
571k
        _size += n;
193
571k
        fill(item_ptr(0), first, last);
194
571k
    }
195
196
76.1M
    prevector() = default;
prevector<36u, unsigned char, unsigned int, int>::prevector()
Line
Count
Source
196
75.6M
    prevector() = default;
prevector<33u, unsigned char, unsigned int, int>::prevector()
Line
Count
Source
196
475k
    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
22
    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
87.5k
    explicit prevector(size_type n, const T& val) {
203
87.5k
        change_capacity(n);
204
87.5k
        _size += n;
205
87.5k
        fill(item_ptr(0), n, val);
206
87.5k
    }
prevector<16u, unsigned char, unsigned int, int>::prevector(unsigned int, unsigned char const&)
Line
Count
Source
202
2.37M
    explicit prevector(size_type n, const T& val) {
203
2.37M
        change_capacity(n);
204
2.37M
        _size += n;
205
2.37M
        fill(item_ptr(0), n, val);
206
2.37M
    }
207
208
    template <std::input_iterator InputIterator>
209
1.14M
    prevector(InputIterator first, InputIterator last) {
210
1.14M
        size_type n = last - first;
211
1.14M
        change_capacity(n);
212
1.14M
        _size += n;
213
1.14M
        fill(item_ptr(0), first, last);
214
1.14M
    }
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
36.9k
    prevector(InputIterator first, InputIterator last) {
210
36.9k
        size_type n = last - first;
211
36.9k
        change_capacity(n);
212
36.9k
        _size += n;
213
36.9k
        fill(item_ptr(0), first, last);
214
36.9k
    }
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.87k
    prevector(InputIterator first, InputIterator last) {
210
6.87k
        size_type n = last - first;
211
6.87k
        change_capacity(n);
212
6.87k
        _size += n;
213
6.87k
        fill(item_ptr(0), first, last);
214
6.87k
    }
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
191k
    prevector(InputIterator first, InputIterator last) {
210
191k
        size_type n = last - first;
211
191k
        change_capacity(n);
212
191k
        _size += n;
213
191k
        fill(item_ptr(0), first, last);
214
191k
    }
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
372k
    prevector(InputIterator first, InputIterator last) {
210
372k
        size_type n = last - first;
211
372k
        change_capacity(n);
212
372k
        _size += n;
213
372k
        fill(item_ptr(0), first, last);
214
372k
    }
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
177
    prevector(InputIterator first, InputIterator last) {
210
177
        size_type n = last - first;
211
177
        change_capacity(n);
212
177
        _size += n;
213
177
        fill(item_ptr(0), first, last);
214
177
    }
215
216
46.0M
    prevector(const prevector<N, T, Size, Diff>& other) {
217
46.0M
        size_type n = other.size();
218
46.0M
        change_capacity(n);
219
46.0M
        _size += n;
220
46.0M
        fill(item_ptr(0), other.begin(),  other.end());
221
46.0M
    }
prevector<16u, unsigned char, unsigned int, int>::prevector(prevector<16u, unsigned char, unsigned int, int> const&)
Line
Count
Source
216
3.01M
    prevector(const prevector<N, T, Size, Diff>& other) {
217
3.01M
        size_type n = other.size();
218
3.01M
        change_capacity(n);
219
3.01M
        _size += n;
220
3.01M
        fill(item_ptr(0), other.begin(),  other.end());
221
3.01M
    }
prevector<36u, unsigned char, unsigned int, int>::prevector(prevector<36u, unsigned char, unsigned int, int> const&)
Line
Count
Source
216
43.0M
    prevector(const prevector<N, T, Size, Diff>& other) {
217
43.0M
        size_type n = other.size();
218
43.0M
        change_capacity(n);
219
43.0M
        _size += n;
220
43.0M
        fill(item_ptr(0), other.begin(),  other.end());
221
43.0M
    }
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
546k
        : _union(std::move(other._union)), _size(other._size)
225
546k
    {
226
546k
        other._size = 0;
227
546k
    }
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.85M
    prevector& operator=(const prevector<N, T, Size, Diff>& other) {
230
1.85M
        if (&other == this) {
231
12.9k
            return *this;
232
12.9k
        }
233
1.84M
        assign(other.begin(), other.end());
234
1.84M
        return *this;
235
1.85M
    }
prevector<36u, unsigned char, unsigned int, int>::operator=(prevector<36u, unsigned char, unsigned int, int> const&)
Line
Count
Source
229
1.81M
    prevector& operator=(const prevector<N, T, Size, Diff>& other) {
230
1.81M
        if (&other == this) {
231
12.9k
            return *this;
232
12.9k
        }
233
1.80M
        assign(other.begin(), other.end());
234
1.80M
        return *this;
235
1.81M
    }
prevector<16u, unsigned char, unsigned int, int>::operator=(prevector<16u, unsigned char, unsigned int, int> const&)
Line
Count
Source
229
33.1k
    prevector& operator=(const prevector<N, T, Size, Diff>& other) {
230
33.1k
        if (&other == this) {
231
2
            return *this;
232
2
        }
233
33.1k
        assign(other.begin(), other.end());
234
33.1k
        return *this;
235
33.1k
    }
prevector<8u, int, unsigned int, int>::operator=(prevector<8u, int, unsigned int, int> const&)
Line
Count
Source
229
8.14k
    prevector& operator=(const prevector<N, T, Size, Diff>& other) {
230
8.14k
        if (&other == this) {
231
0
            return *this;
232
0
        }
233
8.14k
        assign(other.begin(), other.end());
234
8.14k
        return *this;
235
8.14k
    }
236
237
29.3M
    prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept {
238
29.3M
        if (!is_direct()) {
239
24.6k
            free(_union.indirect_contents.indirect);
240
24.6k
        }
241
29.3M
        _union = std::move(other._union);
242
29.3M
        _size = other._size;
243
29.3M
        other._size = 0;
244
29.3M
        return *this;
245
29.3M
    }
prevector<16u, unsigned char, unsigned int, int>::operator=(prevector<16u, unsigned char, unsigned int, int>&&)
Line
Count
Source
237
604k
    prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept {
238
604k
        if (!is_direct()) {
239
8
            free(_union.indirect_contents.indirect);
240
8
        }
241
604k
        _union = std::move(other._union);
242
604k
        _size = other._size;
243
604k
        other._size = 0;
244
604k
        return *this;
245
604k
    }
prevector<36u, unsigned char, unsigned int, int>::operator=(prevector<36u, unsigned char, unsigned int, int>&&)
Line
Count
Source
237
28.7M
    prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept {
238
28.7M
        if (!is_direct()) {
239
22.1k
            free(_union.indirect_contents.indirect);
240
22.1k
        }
241
28.7M
        _union = std::move(other._union);
242
28.7M
        _size = other._size;
243
28.7M
        other._size = 0;
244
28.7M
        return *this;
245
28.7M
    }
prevector<8u, int, unsigned int, int>::operator=(prevector<8u, int, unsigned int, int>&&)
Line
Count
Source
237
4.01k
    prevector& operator=(prevector<N, T, Size, Diff>&& other) noexcept {
238
4.01k
        if (!is_direct()) {
239
2.49k
            free(_union.indirect_contents.indirect);
240
2.49k
        }
241
4.01k
        _union = std::move(other._union);
242
4.01k
        _size = other._size;
243
4.01k
        other._size = 0;
244
4.01k
        return *this;
245
4.01k
    }
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.91G
    size_type size() const {
248
1.91G
        return is_direct() ? _size : _size - N - 1;
249
1.91G
    }
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
341k
    size_type size() const {
248
341k
        return is_direct() ? _size : _size - N - 1;
249
341k
    }
prevector<8u, int, unsigned int, int>::size() const
Line
Count
Source
247
7.18M
    size_type size() const {
248
7.18M
        return is_direct() ? _size : _size - N - 1;
249
7.18M
    }
prevector<4u, Network, unsigned int, int>::size() const
Line
Count
Source
247
208
    size_type size() const {
248
208
        return is_direct() ? _size : _size - N - 1;
249
208
    }
prevector<35u, unsigned char, unsigned int, int>::size() const
Line
Count
Source
247
1.23k
    size_type size() const {
248
1.23k
        return is_direct() ? _size : _size - N - 1;
249
1.23k
    }
250
251
30.2M
    bool empty() const {
252
30.2M
        return size() == 0;
253
30.2M
    }
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
29.8M
    bool empty() const {
252
29.8M
        return size() == 0;
253
29.8M
    }
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
22
    bool empty() const {
252
22
        return size() == 0;
253
22
    }
254
255
20.3M
    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.23M
    iterator begin() { return iterator(item_ptr(0)); }
prevector<35u, unsigned char, unsigned int, int>::begin()
Line
Count
Source
255
354
    iterator begin() { return iterator(item_ptr(0)); }
256
133M
    const_iterator begin() const { return const_iterator(item_ptr(0)); }
prevector<36u, unsigned char, unsigned int, int>::begin() const
Line
Count
Source
256
124M
    const_iterator begin() const { return const_iterator(item_ptr(0)); }
prevector<16u, unsigned char, unsigned int, int>::begin() const
Line
Count
Source
256
7.54M
    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
38.7M
    iterator end() { return iterator(item_ptr(size())); }
prevector<36u, unsigned char, unsigned int, int>::end()
Line
Count
Source
257
34.4M
    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
3.03M
    iterator end() { return iterator(item_ptr(size())); }
prevector<35u, unsigned char, unsigned int, int>::end()
Line
Count
Source
257
354
    iterator end() { return iterator(item_ptr(size())); }
258
1.43G
    const_iterator end() const { return const_iterator(item_ptr(size())); }
prevector<36u, unsigned char, unsigned int, int>::end() const
Line
Count
Source
258
1.43G
    const_iterator end() const { return const_iterator(item_ptr(size())); }
prevector<16u, unsigned char, unsigned int, int>::end() const
Line
Count
Source
258
3.51M
    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
11.9M
            return N;
263
11.9M
        } else {
264
5.81M
            return _union.indirect_contents.capacity;
265
5.81M
        }
266
17.8M
    }
prevector<16u, unsigned char, unsigned int, int>::capacity() const
Line
Count
Source
260
615k
    size_t capacity() const {
261
615k
        if (is_direct()) {
262
615k
            return N;
263
615k
        } else {
264
10
            return _union.indirect_contents.capacity;
265
10
        }
266
615k
    }
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
33.4k
            return N;
263
59.6k
        } else {
264
59.6k
            return _union.indirect_contents.capacity;
265
59.6k
        }
266
93.1k
    }
prevector<4u, Network, unsigned int, int>::capacity() const
Line
Count
Source
260
82
    size_t capacity() const {
261
82
        if (is_direct()) {
262
82
            return N;
263
82
        } else {
264
0
            return _union.indirect_contents.capacity;
265
0
        }
266
82
    }
prevector<33u, unsigned char, unsigned int, int>::capacity() const
Line
Count
Source
260
126k
    size_t capacity() const {
261
126k
        if (is_direct()) {
262
126k
            return N;
263
126k
        } else {
264
0
            return _union.indirect_contents.capacity;
265
0
        }
266
126k
    }
prevector<35u, unsigned char, unsigned int, int>::capacity() const
Line
Count
Source
260
354
    size_t capacity() const {
261
354
        if (is_direct()) {
262
354
            return N;
263
354
        } else {
264
0
            return _union.indirect_contents.capacity;
265
0
        }
266
354
    }
267
268
10.7M
    T& operator[](size_type pos) {
269
10.7M
        return *item_ptr(pos);
270
10.7M
    }
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
253k
    T& operator[](size_type pos) {
269
253k
        return *item_ptr(pos);
270
253k
    }
prevector<8u, int, unsigned int, int>::operator[](unsigned int)
Line
Count
Source
268
8.65M
    T& operator[](size_type pos) {
269
8.65M
        return *item_ptr(pos);
270
8.65M
    }
prevector<4u, Network, unsigned int, int>::operator[](unsigned int)
Line
Count
Source
268
22
    T& operator[](size_type pos) {
269
22
        return *item_ptr(pos);
270
22
    }
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.6M
    const T& operator[](size_type pos) const {
273
19.6M
        return *item_ptr(pos);
274
19.6M
    }
prevector<16u, unsigned char, unsigned int, int>::operator[](unsigned int) const
Line
Count
Source
272
8.49M
    const T& operator[](size_type pos) const {
273
8.49M
        return *item_ptr(pos);
274
8.49M
    }
prevector<36u, unsigned char, unsigned int, int>::operator[](unsigned int) const
Line
Count
Source
272
11.1M
    const T& operator[](size_type pos) const {
273
11.1M
        return *item_ptr(pos);
274
11.1M
    }
275
276
73.5M
    void resize(size_type new_size) {
277
73.5M
        size_type cur_size = size();
278
73.5M
        if (cur_size == new_size) {
279
62.5M
            return;
280
62.5M
        }
281
10.9M
        if (cur_size > new_size) {
282
10.4M
            erase(item_ptr(new_size), end());
283
10.4M
            return;
284
10.4M
        }
285
521k
        if (new_size > capacity()) {
286
80.2k
            change_capacity(new_size);
287
80.2k
        }
288
521k
        ptrdiff_t increase = new_size - cur_size;
289
521k
        fill(item_ptr(cur_size), increase);
290
521k
        _size += increase;
291
521k
    }
prevector<36u, unsigned char, unsigned int, int>::resize(unsigned int)
Line
Count
Source
276
72.7M
    void resize(size_type new_size) {
277
72.7M
        size_type cur_size = size();
278
72.7M
        if (cur_size == new_size) {
279
62.5M
            return;
280
62.5M
        }
281
10.1M
        if (cur_size > new_size) {
282
9.76M
            erase(item_ptr(new_size), end());
283
9.76M
            return;
284
9.76M
        }
285
387k
        if (new_size > capacity()) {
286
79.6k
            change_capacity(new_size);
287
79.6k
        }
288
387k
        ptrdiff_t increase = new_size - cur_size;
289
387k
        fill(item_ptr(cur_size), increase);
290
387k
        _size += increase;
291
387k
    }
prevector<16u, unsigned char, unsigned int, int>::resize(unsigned int)
Line
Count
Source
276
656k
    void resize(size_type new_size) {
277
656k
        size_type cur_size = size();
278
656k
        if (cur_size == new_size) {
279
103
            return;
280
103
        }
281
656k
        if (cur_size > new_size) {
282
656k
            erase(item_ptr(new_size), end());
283
656k
            return;
284
656k
        }
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
28.9k
    void resize(size_type new_size) {
277
28.9k
        size_type cur_size = size();
278
28.9k
        if (cur_size == new_size) {
279
10.0k
            return;
280
10.0k
        }
281
18.8k
        if (cur_size > new_size) {
282
12.3k
            erase(item_ptr(new_size), end());
283
12.3k
            return;
284
12.3k
        }
285
6.51k
        if (new_size > capacity()) {
286
294
            change_capacity(new_size);
287
294
        }
288
6.51k
        ptrdiff_t increase = new_size - cur_size;
289
6.51k
        fill(item_ptr(cur_size), increase);
290
6.51k
        _size += increase;
291
6.51k
    }
prevector<33u, unsigned char, unsigned int, int>::resize(unsigned int)
Line
Count
Source
276
126k
    void resize(size_type new_size) {
277
126k
        size_type cur_size = size();
278
126k
        if (cur_size == new_size) {
279
0
            return;
280
0
        }
281
126k
        if (cur_size > new_size) {
282
0
            erase(item_ptr(new_size), end());
283
0
            return;
284
0
        }
285
126k
        if (new_size > capacity()) {
286
0
            change_capacity(new_size);
287
0
        }
288
126k
        ptrdiff_t increase = new_size - cur_size;
289
126k
        fill(item_ptr(cur_size), increase);
290
126k
        _size += increase;
291
126k
    }
292
293
4.10k
    void reserve(size_type new_capacity) {
294
4.10k
        if (new_capacity > capacity()) {
295
1.79k
            change_capacity(new_capacity);
296
1.79k
        }
297
4.10k
    }
298
299
69.2M
    void shrink_to_fit() {
300
69.2M
        change_capacity(size());
301
69.2M
    }
prevector<36u, unsigned char, unsigned int, int>::shrink_to_fit()
Line
Count
Source
299
69.1M
    void shrink_to_fit() {
300
69.1M
        change_capacity(size());
301
69.1M
    }
prevector<8u, int, unsigned int, int>::shrink_to_fit()
Line
Count
Source
299
2.06k
    void shrink_to_fit() {
300
2.06k
        change_capacity(size());
301
2.06k
    }
302
303
72.9M
    void clear() {
304
72.9M
        resize(0);
305
72.9M
    }
prevector<36u, unsigned char, unsigned int, int>::clear()
Line
Count
Source
303
72.3M
    void clear() {
304
72.3M
        resize(0);
305
72.3M
    }
prevector<16u, unsigned char, unsigned int, int>::clear()
Line
Count
Source
303
614k
    void clear() {
304
614k
        resize(0);
305
614k
    }
prevector<8u, int, unsigned int, int>::clear()
Line
Count
Source
303
12.5k
    void clear() {
304
12.5k
        resize(0);
305
12.5k
    }
306
307
9.00M
    iterator insert(iterator pos, const T& value) {
308
9.00M
        size_type p = pos - begin();
309
9.00M
        size_type new_size = size() + 1;
310
9.00M
        if (capacity() < new_size) {
311
8.07k
            change_capacity(new_size + (new_size >> 1));
312
8.07k
        }
313
9.00M
        T* ptr = item_ptr(p);
314
9.00M
        T* dst = ptr + 1;
315
9.00M
        memmove(dst, ptr, (size() - p) * sizeof(T));
316
9.00M
        _size++;
317
9.00M
        new(static_cast<void*>(ptr)) T(value);
318
9.00M
        return iterator(ptr);
319
9.00M
    }
prevector<36u, unsigned char, unsigned int, int>::insert(prevector<36u, unsigned char, unsigned int, int>::iterator, unsigned char const&)
Line
Count
Source
307
8.97M
    iterator insert(iterator pos, const T& value) {
308
8.97M
        size_type p = pos - begin();
309
8.97M
        size_type new_size = size() + 1;
310
8.97M
        if (capacity() < new_size) {
311
6.65k
            change_capacity(new_size + (new_size >> 1));
312
6.65k
        }
313
8.97M
        T* ptr = item_ptr(p);
314
8.97M
        T* dst = ptr + 1;
315
8.97M
        memmove(dst, ptr, (size() - p) * sizeof(T));
316
8.97M
        _size++;
317
8.97M
        new(static_cast<void*>(ptr)) T(value);
318
8.97M
        return iterator(ptr);
319
8.97M
    }
prevector<8u, int, unsigned int, int>::insert(prevector<8u, int, unsigned int, int>::iterator, int const&)
Line
Count
Source
307
33.1k
    iterator insert(iterator pos, const T& value) {
308
33.1k
        size_type p = pos - begin();
309
33.1k
        size_type new_size = size() + 1;
310
33.1k
        if (capacity() < new_size) {
311
1.41k
            change_capacity(new_size + (new_size >> 1));
312
1.41k
        }
313
33.1k
        T* ptr = item_ptr(p);
314
33.1k
        T* dst = ptr + 1;
315
33.1k
        memmove(dst, ptr, (size() - p) * sizeof(T));
316
33.1k
        _size++;
317
33.1k
        new(static_cast<void*>(ptr)) T(value);
318
33.1k
        return iterator(ptr);
319
33.1k
    }
320
321
16.3k
    void insert(iterator pos, size_type count, const T& value) {
322
16.3k
        size_type p = pos - begin();
323
16.3k
        size_type new_size = size() + count;
324
16.3k
        if (capacity() < new_size) {
325
820
            change_capacity(new_size + (new_size >> 1));
326
820
        }
327
16.3k
        T* ptr = item_ptr(p);
328
16.3k
        T* dst = ptr + count;
329
16.3k
        memmove(dst, ptr, (size() - p) * sizeof(T));
330
16.3k
        _size += count;
331
16.3k
        fill(item_ptr(p), count, value);
332
16.3k
    }
prevector<8u, int, unsigned int, int>::insert(prevector<8u, int, unsigned int, int>::iterator, unsigned int, int const&)
Line
Count
Source
321
16.3k
    void insert(iterator pos, size_type count, const T& value) {
322
16.3k
        size_type p = pos - begin();
323
16.3k
        size_type new_size = size() + count;
324
16.3k
        if (capacity() < new_size) {
325
813
            change_capacity(new_size + (new_size >> 1));
326
813
        }
327
16.3k
        T* ptr = item_ptr(p);
328
16.3k
        T* dst = ptr + count;
329
16.3k
        memmove(dst, ptr, (size() - p) * sizeof(T));
330
16.3k
        _size += count;
331
16.3k
        fill(item_ptr(p), count, value);
332
16.3k
    }
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
368k
            change_capacity(new_size + (new_size >> 1));
341
368k
        }
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.00k
    void insert(iterator pos, InputIterator first, InputIterator last) {
336
4.00k
        size_type p = pos - begin();
337
4.00k
        difference_type count = last - first;
338
4.00k
        size_type new_size = size() + count;
339
4.00k
        if (capacity() < new_size) {
340
292
            change_capacity(new_size + (new_size >> 1));
341
292
        }
342
4.00k
        T* ptr = item_ptr(p);
343
4.00k
        T* dst = ptr + count;
344
4.00k
        memmove(dst, ptr, (size() - p) * sizeof(T));
345
4.00k
        _size += count;
346
4.00k
        fill(ptr, first, last);
347
4.00k
    }
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
127k
            change_capacity(new_size + (new_size >> 1));
341
127k
        }
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
177
    void insert(iterator pos, InputIterator first, InputIterator last) {
336
177
        size_type p = pos - begin();
337
177
        difference_type count = last - first;
338
177
        size_type new_size = size() + count;
339
177
        if (capacity() < new_size) {
340
0
            change_capacity(new_size + (new_size >> 1));
341
0
        }
342
177
        T* ptr = item_ptr(p);
343
177
        T* dst = ptr + count;
344
177
        memmove(dst, ptr, (size() - p) * sizeof(T));
345
177
        _size += count;
346
177
        fill(ptr, first, last);
347
177
    }
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
177
    void insert(iterator pos, InputIterator first, InputIterator last) {
336
177
        size_type p = pos - begin();
337
177
        difference_type count = last - first;
338
177
        size_type new_size = size() + count;
339
177
        if (capacity() < new_size) {
340
0
            change_capacity(new_size + (new_size >> 1));
341
0
        }
342
177
        T* ptr = item_ptr(p);
343
177
        T* dst = ptr + count;
344
177
        memmove(dst, ptr, (size() - p) * sizeof(T));
345
177
        _size += count;
346
177
        fill(ptr, first, last);
347
177
    }
348
349
978k
    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
978k
        if (capacity() < new_size) {
353
219k
            change_capacity(new_size);
354
219k
            _size += new_size - size();
355
219k
            return;
356
219k
        }
357
759k
        if (new_size < size()) {
358
3.23k
            erase(item_ptr(new_size), end());
359
756k
        } else {
360
756k
            _size += new_size - size();
361
756k
        }
362
759k
    }
prevector<36u, unsigned char, unsigned int, int>::resize_uninitialized(unsigned int)
Line
Count
Source
349
970k
    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
970k
        if (capacity() < new_size) {
353
217k
            change_capacity(new_size);
354
217k
            _size += new_size - size();
355
217k
            return;
356
217k
        }
357
752k
        if (new_size < size()) {
358
0
            erase(item_ptr(new_size), end());
359
752k
        } else {
360
752k
            _size += new_size - size();
361
752k
        }
362
752k
    }
prevector<8u, int, unsigned int, int>::resize_uninitialized(unsigned int)
Line
Count
Source
349
8.30k
    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.30k
        if (capacity() < new_size) {
353
1.19k
            change_capacity(new_size);
354
1.19k
            _size += new_size - size();
355
1.19k
            return;
356
1.19k
        }
357
7.11k
        if (new_size < size()) {
358
3.23k
            erase(item_ptr(new_size), end());
359
3.87k
        } else {
360
3.87k
            _size += new_size - size();
361
3.87k
        }
362
7.11k
    }
363
364
27.9k
    iterator erase(iterator pos) {
365
27.9k
        return erase(pos, pos + 1);
366
27.9k
    }
367
368
10.4M
    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.4M
        iterator p = first;
376
10.4M
        char* endp = (char*)&(*end());
377
10.4M
        _size -= last - p;
378
10.4M
        memmove(&(*first), &(*last), endp - ((char*)(&(*last))));
379
10.4M
        return first;
380
10.4M
    }
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
9.76M
    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
9.76M
        iterator p = first;
376
9.76M
        char* endp = (char*)&(*end());
377
9.76M
        _size -= last - p;
378
9.76M
        memmove(&(*first), &(*last), endp - ((char*)(&(*last))));
379
9.76M
        return first;
380
9.76M
    }
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
656k
    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
656k
        iterator p = first;
376
656k
        char* endp = (char*)&(*end());
377
656k
        _size -= last - p;
378
656k
        memmove(&(*first), &(*last), endp - ((char*)(&(*last))));
379
656k
        return first;
380
656k
    }
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.4k
    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.4k
        iterator p = first;
376
70.4k
        char* endp = (char*)&(*end());
377
70.4k
        _size -= last - p;
378
70.4k
        memmove(&(*first), &(*last), endp - ((char*)(&(*last))));
379
70.4k
        return first;
380
70.4k
    }
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.2k
    void emplace_back(Args&&... args) {
384
80.2k
        size_type new_size = size() + 1;
385
80.2k
        if (capacity() < new_size) {
386
13.2k
            change_capacity(new_size + (new_size >> 1));
387
13.2k
        }
388
80.2k
        new(item_ptr(size())) T(std::forward<Args>(args)...);
389
80.2k
        _size++;
390
80.2k
    }
void prevector<36u, unsigned char, unsigned int, int>::emplace_back<unsigned char const&>(unsigned char const&)
Line
Count
Source
383
71.9k
    void emplace_back(Args&&... args) {
384
71.9k
        size_type new_size = size() + 1;
385
71.9k
        if (capacity() < new_size) {
386
13.0k
            change_capacity(new_size + (new_size >> 1));
387
13.0k
        }
388
71.9k
        new(item_ptr(size())) T(std::forward<Args>(args)...);
389
71.9k
        _size++;
390
71.9k
    }
void prevector<8u, int, unsigned int, int>::emplace_back<int const&>(int const&)
Line
Count
Source
383
8.24k
    void emplace_back(Args&&... args) {
384
8.24k
        size_type new_size = size() + 1;
385
8.24k
        if (capacity() < new_size) {
386
218
            change_capacity(new_size + (new_size >> 1));
387
218
        }
388
8.24k
        new(item_ptr(size())) T(std::forward<Args>(args)...);
389
8.24k
        _size++;
390
8.24k
    }
void prevector<4u, Network, unsigned int, int>::emplace_back<Network const&>(Network const&)
Line
Count
Source
383
82
    void emplace_back(Args&&... args) {
384
82
        size_type new_size = size() + 1;
385
82
        if (capacity() < new_size) {
386
0
            change_capacity(new_size + (new_size >> 1));
387
0
        }
388
82
        new(item_ptr(size())) T(std::forward<Args>(args)...);
389
82
        _size++;
390
82
    }
391
392
80.2k
    void push_back(const T& value) {
393
80.2k
        emplace_back(value);
394
80.2k
    }
prevector<36u, unsigned char, unsigned int, int>::push_back(unsigned char const&)
Line
Count
Source
392
71.9k
    void push_back(const T& value) {
393
71.9k
        emplace_back(value);
394
71.9k
    }
prevector<8u, int, unsigned int, int>::push_back(int const&)
Line
Count
Source
392
8.24k
    void push_back(const T& value) {
393
8.24k
        emplace_back(value);
394
8.24k
    }
prevector<4u, Network, unsigned int, int>::push_back(Network const&)
Line
Count
Source
392
82
    void push_back(const T& value) {
393
82
        emplace_back(value);
394
82
    }
395
396
6.75k
    void pop_back() {
397
6.75k
        erase(end() - 1, end());
398
6.75k
    }
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.7k
    const T& back() const {
413
27.7k
        return *item_ptr(size() - 1);
414
27.7k
    }
415
416
    void swap(prevector<N, T, Size, Diff>& other) noexcept
417
16.2k
    {
418
16.2k
        std::swap(_union, other._union);
419
16.2k
        std::swap(_size, other._size);
420
16.2k
    }
421
422
142M
    ~prevector() {
423
142M
        if (!is_direct()) {
424
2.24M
            free(_union.indirect_contents.indirect);
425
2.24M
            _union.indirect_contents.indirect = nullptr;
426
2.24M
        }
427
142M
    }
prevector<16u, unsigned char, unsigned int, int>::~prevector()
Line
Count
Source
422
5.92M
    ~prevector() {
423
5.92M
        if (!is_direct()) {
424
1.96k
            free(_union.indirect_contents.indirect);
425
1.96k
            _union.indirect_contents.indirect = nullptr;
426
1.96k
        }
427
5.92M
    }
prevector<36u, unsigned char, unsigned int, int>::~prevector()
Line
Count
Source
422
135M
    ~prevector() {
423
135M
        if (!is_direct()) {
424
2.03M
            free(_union.indirect_contents.indirect);
425
2.03M
            _union.indirect_contents.indirect = nullptr;
426
2.03M
        }
427
135M
    }
prevector<33u, unsigned char, unsigned int, int>::~prevector()
Line
Count
Source
422
563k
    ~prevector() {
423
563k
        if (!is_direct()) {
424
0
            free(_union.indirect_contents.indirect);
425
0
            _union.indirect_contents.indirect = nullptr;
426
0
        }
427
563k
    }
prevector<8u, int, unsigned int, int>::~prevector()
Line
Count
Source
422
535k
    ~prevector() {
423
535k
        if (!is_direct()) {
424
206k
            free(_union.indirect_contents.indirect);
425
206k
            _union.indirect_contents.indirect = nullptr;
426
206k
        }
427
535k
    }
prevector<4u, Network, unsigned int, int>::~prevector()
Line
Count
Source
422
22
    ~prevector() {
423
22
        if (!is_direct()) {
424
0
            free(_union.indirect_contents.indirect);
425
0
            _union.indirect_contents.indirect = nullptr;
426
0
        }
427
22
    }
prevector<35u, unsigned char, unsigned int, int>::~prevector()
Line
Count
Source
422
177
    ~prevector() {
423
177
        if (!is_direct()) {
424
0
            free(_union.indirect_contents.indirect);
425
0
            _union.indirect_contents.indirect = nullptr;
426
0
        }
427
177
    }
428
429
6.51M
    constexpr bool operator==(const prevector& other) const {
430
6.51M
        return std::ranges::equal(*this, other);
431
6.51M
    }
prevector<36u, unsigned char, unsigned int, int>::operator==(prevector<36u, unsigned char, unsigned int, int> const&) const
Line
Count
Source
429
5.75M
    constexpr bool operator==(const prevector& other) const {
430
5.75M
        return std::ranges::equal(*this, other);
431
5.75M
    }
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
791k
            return true;
436
791k
        }
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
129M
            if ((*b1) < (*b2)) {
445
10.0M
                return true;
446
10.0M
            }
447
119M
            if ((*b2) < (*b1)) {
448
7.55M
                return false;
449
7.55M
            }
450
112M
            ++b1;
451
112M
            ++b2;
452
112M
        }
453
2.73M
        return false;
454
20.3M
    }
prevector<36u, unsigned char, unsigned int, int>::operator<(prevector<36u, unsigned char, unsigned int, int> const&) const
Line
Count
Source
433
21.3M
    bool operator<(const prevector<N, T, Size, Diff>& other) const {
434
21.3M
        if (size() < other.size()) {
435
791k
            return true;
436
791k
        }
437
20.5M
        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
129M
            if ((*b1) < (*b2)) {
445
10.0M
                return true;
446
10.0M
            }
447
119M
            if ((*b2) < (*b1)) {
448
7.55M
                return false;
449
7.55M
            }
450
112M
            ++b1;
451
112M
            ++b2;
452
112M
        }
453
2.71M
        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
25.9k
    bool operator<(const prevector<N, T, Size, Diff>& other) const {
434
25.9k
        if (size() < other.size()) {
435
0
            return true;
436
0
        }
437
25.9k
        if (size() > other.size()) {
438
0
            return false;
439
0
        }
440
25.9k
        const_iterator b1 = begin();
441
25.9k
        const_iterator b2 = other.begin();
442
25.9k
        const_iterator e1 = end();
443
130k
        while (b1 != e1) {
444
104k
            if ((*b1) < (*b2)) {
445
266
                return true;
446
266
            }
447
104k
            if ((*b2) < (*b1)) {
448
102
                return false;
449
102
            }
450
104k
            ++b1;
451
104k
            ++b2;
452
104k
        }
453
25.5k
        return false;
454
25.9k
    }
455
456
37.8M
    size_t allocated_memory() const {
457
37.8M
        if (is_direct()) {
458
37.0M
            return 0;
459
37.0M
        } else {
460
798k
            return ((size_t)(sizeof(T))) * _union.indirect_contents.capacity;
461
798k
        }
462
37.8M
    }
463
464
555k
    value_type* data() {
465
555k
        return item_ptr(0);
466
555k
    }
prevector<16u, unsigned char, unsigned int, int>::data()
Line
Count
Source
464
42.0k
    value_type* data() {
465
42.0k
        return item_ptr(0);
466
42.0k
    }
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
299k
    value_type* data() {
465
299k
        return item_ptr(0);
466
299k
    }
prevector<35u, unsigned char, unsigned int, int>::data()
Line
Count
Source
464
177
    value_type* data() {
465
177
        return item_ptr(0);
466
177
    }
467
468
30.7M
    const value_type* data() const {
469
30.7M
        return item_ptr(0);
470
30.7M
    }
prevector<16u, unsigned char, unsigned int, int>::data() const
Line
Count
Source
468
2.69M
    const value_type* data() const {
469
2.69M
        return item_ptr(0);
470
2.69M
    }
prevector<36u, unsigned char, unsigned int, int>::data() const
Line
Count
Source
468
27.9M
    const value_type* data() const {
469
27.9M
        return item_ptr(0);
470
27.9M
    }
prevector<33u, unsigned char, unsigned int, int>::data() const
Line
Count
Source
468
87.5k
    const value_type* data() const {
469
87.5k
        return item_ptr(0);
470
87.5k
    }
471
};
472
473
#endif // BITCOIN_PREVECTOR_H