See the file comment for details on the usage of the TrailingObjects type.
More...
#include "llvm/Support/TrailingObjects.h"
|
struct | FixedSizeStorage |
| A type where its ::with_counts template member has a ::type member suitable for use as uninitialized storage for an object with the given trailing object counts. More...
|
|
class | FixedSizeStorageOwner |
| A type that acts as the owner for an object placed into fixed storage. More...
|
|
|
template<typename... Tys> |
static constexpr std::enable_if_t< std::is_same_v< Foo< TrailingTys... >, Foo< Tys... > >, size_t > | additionalSizeToAlloc (typename trailing_objects_internal::ExtractSecondType< TrailingTys, size_t >::type... Counts) |
| Returns the size of the trailing data, if an object were allocated with the given counts (The counts are in the same order as the template arguments).
|
|
template<typename... Tys> |
static constexpr std::enable_if_t< std::is_same_v< Foo< TrailingTys... >, Foo< Tys... > >, size_t > | totalSizeToAlloc (typename trailing_objects_internal::ExtractSecondType< TrailingTys, size_t >::type... Counts) |
| Returns the total size of an object if it were allocated with the given trailing object counts.
|
|
template<typename
BaseTy, typename... TrailingTys>
class llvm::TrailingObjects< BaseTy, TrailingTys >
See the file comment for details on the usage of the TrailingObjects type.
Definition at line 212 of file TrailingObjects.h.
◆ TrailingObjects() [1/3]
template<typename
BaseTy , typename... TrailingTys>
◆ TrailingObjects() [2/3]
template<typename
BaseTy , typename... TrailingTys>
◆ TrailingObjects() [3/3]
template<typename
BaseTy , typename... TrailingTys>
◆ additionalSizeToAlloc()
template<typename
BaseTy , typename... TrailingTys>
template<typename... Tys>
Returns the size of the trailing data, if an object were allocated with the given counts (The counts are in the same order as the template arguments).
This does not include the size of the base object. The template arguments must be the same as those used in the class; they are supplied here redundantly only so that it's clear what the counts are counting in callers.
Definition at line 314 of file TrailingObjects.h.
◆ getTrailingObjects() [1/2]
template<typename
BaseTy , typename... TrailingTys>
Returns a pointer to the trailing object array of the given type (which must be one of those specified in the class template).
The array may have zero or more elements in it.
Definition at line 297 of file TrailingObjects.h.
◆ getTrailingObjects() [2/2]
template<typename
BaseTy , typename... TrailingTys>
Returns a pointer to the trailing object array of the given type (which must be one of those specified in the class template).
The array may have zero or more elements in it.
Definition at line 285 of file TrailingObjects.h.
Referenced by llvm::RecordRecTy::get().
◆ operator=() [1/2]
template<typename
BaseTy , typename... TrailingTys>
◆ operator=() [2/2]
template<typename
BaseTy , typename... TrailingTys>
◆ totalSizeToAlloc()
template<typename
BaseTy , typename... TrailingTys>
template<typename... Tys>
Returns the total size of an object if it were allocated with the given trailing object counts.
This is the same as additionalSizeToAlloc, except it does include the size of the base object.
Definition at line 326 of file TrailingObjects.h.
◆ trailing_objects_internal::TrailingObjectsImpl
template<typename
BaseTy , typename... TrailingTys>
template<int A, typename
B , typename
T , typename
P , typename... M>
The documentation for this class was generated from the following file: