![]() |
BSHA3
0.17.99
P2P Blockchain, based on Bitcoin
|
Implements a drop-in replacement for std::vector<T> which stores up to N elements directly (without heap allocation). More...
#include <prevector.h>
Classes | |
| class | const_iterator |
| class | const_reverse_iterator |
| union | direct_or_indirect |
| class | iterator |
| class | reverse_iterator |
Public Types | |
| typedef Size | size_type |
| typedef Diff | difference_type |
| typedef T | value_type |
| typedef value_type & | reference |
| typedef const value_type & | const_reference |
| typedef value_type * | pointer |
| typedef const value_type * | const_pointer |
Public Member Functions | |
| void | assign (size_type n, const T &val) |
| template<typename InputIterator > | |
| void | assign (InputIterator first, InputIterator last) |
| prevector () | |
| prevector (size_type n) | |
| prevector (size_type n, const T &val) | |
| template<typename InputIterator > | |
| prevector (InputIterator first, InputIterator last) | |
| prevector (const prevector< N, T, Size, Diff > &other) | |
| prevector (prevector< N, T, Size, Diff > &&other) | |
| prevector & | operator= (const prevector< N, T, Size, Diff > &other) |
| prevector & | operator= (prevector< N, T, Size, Diff > &&other) |
| size_type | size () const |
| bool | empty () const |
| iterator | begin () |
| const_iterator | begin () const |
| iterator | end () |
| const_iterator | end () const |
| reverse_iterator | rbegin () |
| const_reverse_iterator | rbegin () const |
| reverse_iterator | rend () |
| const_reverse_iterator | rend () const |
| size_t | capacity () const |
| T & | operator[] (size_type pos) |
| const T & | operator[] (size_type pos) const |
| void | resize (size_type new_size) |
| void | reserve (size_type new_capacity) |
| void | shrink_to_fit () |
| void | clear () |
| iterator | insert (iterator pos, const T &value) |
| void | insert (iterator pos, size_type count, const T &value) |
| template<typename InputIterator > | |
| void | insert (iterator pos, InputIterator first, InputIterator last) |
| iterator | erase (iterator pos) |
| iterator | erase (iterator first, iterator last) |
| void | push_back (const T &value) |
| void | pop_back () |
| T & | front () |
| const T & | front () const |
| T & | back () |
| const T & | back () const |
| void | swap (prevector< N, T, Size, Diff > &other) |
| ~prevector () | |
| bool | operator== (const prevector< N, T, Size, Diff > &other) const |
| bool | operator!= (const prevector< N, T, Size, Diff > &other) const |
| bool | operator< (const prevector< N, T, Size, Diff > &other) const |
| size_t | allocated_memory () const |
| value_type * | data () |
| const value_type * | data () const |
Private Member Functions | |
| T * | direct_ptr (difference_type pos) |
| const T * | direct_ptr (difference_type pos) const |
| T * | indirect_ptr (difference_type pos) |
| const T * | indirect_ptr (difference_type pos) const |
| bool | is_direct () const |
| void | change_capacity (size_type new_capacity) |
| T * | item_ptr (difference_type pos) |
| const T * | item_ptr (difference_type pos) const |
| void | fill (T *dst, ptrdiff_t count) |
| void | fill (T *dst, ptrdiff_t count, const T &value) |
| template<typename InputIterator > | |
| void | fill (T *dst, InputIterator first, InputIterator last) |
Private Attributes | |
| size_type | _size |
| union prevector::direct_or_indirect | _union |
Implements a drop-in replacement for std::vector<T> which stores up to N elements directly (without heap allocation).
The types Size and Diff are used to store element counts, and can be any unsigned + signed type.
Storage layout is either:
The data type T must be movable by memmove/realloc(). Once we switch to C++, move constructors can be used instead.
Definition at line 39 of file prevector.h.
| typedef const value_type* prevector< N, T, Size, Diff >::const_pointer |
Definition at line 47 of file prevector.h.
| typedef const value_type& prevector< N, T, Size, Diff >::const_reference |
Definition at line 45 of file prevector.h.
| typedef Diff prevector< N, T, Size, Diff >::difference_type |
Definition at line 42 of file prevector.h.
| typedef value_type* prevector< N, T, Size, Diff >::pointer |
Definition at line 46 of file prevector.h.
| typedef value_type& prevector< N, T, Size, Diff >::reference |
Definition at line 44 of file prevector.h.
| typedef Size prevector< N, T, Size, Diff >::size_type |
Definition at line 41 of file prevector.h.
| typedef T prevector< N, T, Size, Diff >::value_type |
Definition at line 43 of file prevector.h.
|
inline |
Definition at line 249 of file prevector.h.
|
inline |
|
inline |
Definition at line 229 of file prevector.h.
|
inline |
|
inline |
|
inline |
|
inline |
Definition at line 301 of file prevector.h.
|
inline |
|
inline |
Definition at line 311 of file prevector.h.
|
inlineprivate |
Definition at line 166 of file prevector.h.
|
inline |
Definition at line 354 of file prevector.h.
|
inline |
Definition at line 519 of file prevector.h.
|
inline |
|
inlineprivate |
|
inlineprivate |
Definition at line 161 of file prevector.h.
|
inline |
Definition at line 297 of file prevector.h.
|
inline |
Definition at line 303 of file prevector.h.
|
inline |
|
inlineprivate |
|
inlineprivate |
Definition at line 213 of file prevector.h.
|
inlineprivate |
Definition at line 220 of file prevector.h.
|
inline |
|
inline |
|
inlineprivate |
|
inlineprivate |
Definition at line 163 of file prevector.h.
|
inline |
Definition at line 358 of file prevector.h.
|
inline |
Definition at line 371 of file prevector.h.
|
inlineprivate |
|
inlineprivate |
Definition at line 197 of file prevector.h.
|
inlineprivate |
|
inline |
Definition at line 484 of file prevector.h.
|
inline |
|
inline |
Definition at line 423 of file prevector.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Definition at line 344 of file prevector.h.
|
inline |
Definition at line 327 of file prevector.h.
|
inline |
Definition at line 350 of file prevector.h.
|
inline |
Definition at line 293 of file prevector.h.
|
private |
Definition at line 151 of file prevector.h.
|
private |
1.8.14