This is all the stuff common to all SmallVectors.
More...
#include </home/runner/work/allwpilib/allwpilib/wpiutil/src/main/native/thirdparty/llvm/include/wpi/SmallVector.h>
|
| SmallVectorBase ()=delete |
|
| SmallVectorBase (void *FirstEl, size_t TotalCapacity) |
|
void * | mallocForGrow (size_t MinSize, size_t TSize, size_t &NewCapacity) |
| This is a helper for grow() that's out of line to reduce code duplication. More...
|
|
void | grow_pod (void *FirstEl, size_t MinSize, size_t TSize) |
| This is an implementation of the grow() method which only works on POD-like data types and is out of line to reduce code duplication. More...
|
|
void | set_size (size_t N) |
| Set the array size to N , which the current array must have enough capacity for. More...
|
|
This is all the stuff common to all SmallVectors.
The template parameter specifies the type which should be used to hold the Size and Capacity of the SmallVector, so it can be adjusted. Using 32 bit size is desirable to shrink the size of the SmallVector. Using 64 bit size is desirable for cases like SmallVector<char>, where a 32 bit size would limit the vector to ~4GB. SmallVectors are used for buffering bitcode output - which can exceed 4GB.
◆ SmallVectorBase() [1/2]
wpi::SmallVectorBase::SmallVectorBase |
( |
| ) |
|
|
protecteddelete |
◆ SmallVectorBase() [2/2]
wpi::SmallVectorBase::SmallVectorBase |
( |
void * |
FirstEl, |
|
|
size_t |
TotalCapacity |
|
) |
| |
|
inlineprotected |
◆ capacity()
size_t wpi::SmallVectorBase::capacity |
( |
| ) |
const |
|
inline |
◆ empty()
◆ grow_pod()
void wpi::SmallVectorBase::grow_pod |
( |
void * |
FirstEl, |
|
|
size_t |
MinSize, |
|
|
size_t |
TSize |
|
) |
| |
|
protected |
This is an implementation of the grow() method which only works on POD-like data types and is out of line to reduce code duplication.
This function will report a fatal error if it cannot increase capacity.
◆ mallocForGrow()
void * wpi::SmallVectorBase::mallocForGrow |
( |
size_t |
MinSize, |
|
|
size_t |
TSize, |
|
|
size_t & |
NewCapacity |
|
) |
| |
|
protected |
This is a helper for grow() that's out of line to reduce code duplication.
This function will report a fatal error if it can't grow at least to MinSize
.
◆ set_size()
void wpi::SmallVectorBase::set_size |
( |
size_t |
N | ) |
|
|
inlineprotected |
Set the array size to N
, which the current array must have enough capacity for.
This does not construct or destroy any elements in the vector.
◆ size()
size_t wpi::SmallVectorBase::size |
( |
| ) |
const |
|
inline |
◆ SizeTypeMax()
static constexpr size_t wpi::SmallVectorBase::SizeTypeMax |
( |
| ) |
|
|
inlinestaticconstexprprotected |
The maximum value of the Size_T used.
◆ BeginX
void* wpi::SmallVectorBase::BeginX |
|
protected |
◆ Capacity
unsigned wpi::SmallVectorBase::Capacity |
|
protected |
◆ Size
unsigned wpi::SmallVectorBase::Size = 0 |
|
protected |
The documentation for this class was generated from the following file:
- /home/runner/work/allwpilib/allwpilib/wpiutil/src/main/native/thirdparty/llvm/include/wpi/SmallVector.h