Stack< Allocator > Class Template Reference

Stack&lt; Allocator &gt; Class Template Reference#

Composable Kernel: internal::Stack< Allocator > Class Template Reference
internal::Stack< Allocator > Class Template Reference

A type-unsafe stack for storing different types of data. More...

#include <stack.h>

Public Member Functions

 Stack (Allocator *allocator, size_t stackCapacity)
 ~Stack ()
void Swap (Stack &rhs) RAPIDJSON_NOEXCEPT
void Clear ()
void ShrinkToFit ()
template<typename T>
RAPIDJSON_FORCEINLINE void Reserve (size_t count=1)
template<typename T>
RAPIDJSON_FORCEINLINE T * Push (size_t count=1)
template<typename T>
RAPIDJSON_FORCEINLINE T * PushUnsafe (size_t count=1)
template<typename T>
T * Pop (size_t count)
template<typename T>
T * Top ()
template<typename T>
const T * Top () const
template<typename T>
T * End ()
template<typename T>
const T * End () const
template<typename T>
T * Bottom ()
template<typename T>
const T * Bottom () const
bool HasAllocator () const
AllocatorGetAllocator ()
bool Empty () const
size_t GetSize () const
size_t GetCapacity () const

Detailed Description

template<typename Allocator>
class internal::Stack< Allocator >

A type-unsafe stack for storing different types of data.

Template Parameters
AllocatorAllocator for allocating stack memory.

Constructor & Destructor Documentation

◆ Stack()

template<typename Allocator>
internal::Stack< Allocator >::Stack ( Allocator * allocator,
size_t stackCapacity )
inline

◆ ~Stack()

template<typename Allocator>
internal::Stack< Allocator >::~Stack ( )
inline

Member Function Documentation

◆ Bottom() [1/2]

template<typename Allocator>
template<typename T>
T * internal::Stack< Allocator >::Bottom ( )
inline

◆ Bottom() [2/2]

template<typename Allocator>
template<typename T>
const T * internal::Stack< Allocator >::Bottom ( ) const
inline

◆ Clear()

template<typename Allocator>
void internal::Stack< Allocator >::Clear ( )
inline

◆ Empty()

template<typename Allocator>
bool internal::Stack< Allocator >::Empty ( ) const
inline

◆ End() [1/2]

template<typename Allocator>
template<typename T>
T * internal::Stack< Allocator >::End ( )
inline

◆ End() [2/2]

template<typename Allocator>
template<typename T>
const T * internal::Stack< Allocator >::End ( ) const
inline

◆ GetAllocator()

template<typename Allocator>
Allocator & internal::Stack< Allocator >::GetAllocator ( )
inline

◆ GetCapacity()

template<typename Allocator>
size_t internal::Stack< Allocator >::GetCapacity ( ) const
inline

◆ GetSize()

template<typename Allocator>
size_t internal::Stack< Allocator >::GetSize ( ) const
inline

◆ HasAllocator()

template<typename Allocator>
bool internal::Stack< Allocator >::HasAllocator ( ) const
inline

◆ Pop()

template<typename Allocator>
template<typename T>
T * internal::Stack< Allocator >::Pop ( size_t count)
inline

◆ Push()

template<typename Allocator>
template<typename T>
RAPIDJSON_FORCEINLINE T * internal::Stack< Allocator >::Push ( size_t count = 1)
inline

◆ PushUnsafe()

template<typename Allocator>
template<typename T>
RAPIDJSON_FORCEINLINE T * internal::Stack< Allocator >::PushUnsafe ( size_t count = 1)
inline

◆ Reserve()

template<typename Allocator>
template<typename T>
RAPIDJSON_FORCEINLINE void internal::Stack< Allocator >::Reserve ( size_t count = 1)
inline

◆ ShrinkToFit()

template<typename Allocator>
void internal::Stack< Allocator >::ShrinkToFit ( )
inline

◆ Swap()

template<typename Allocator>
void internal::Stack< Allocator >::Swap ( Stack< Allocator > & rhs)
inline

◆ Top() [1/2]

template<typename Allocator>
template<typename T>
T * internal::Stack< Allocator >::Top ( )
inline

◆ Top() [2/2]

template<typename Allocator>
template<typename T>
const T * internal::Stack< Allocator >::Top ( ) const
inline

The documentation for this class was generated from the following file: