Ocean
|
This class implements an accessor providing direct access to std::shared_ptr<T> elements returned as const T* pointers. More...
#include <Accessor.h>
Public Types | |
using | SharedPointer = std::shared_ptr< T > |
Definition of the shared pointer object. | |
using | SharedPointers = std::vector< SharedPointer > |
Definition of a vector holding the shared pointer objects. | |
Public Types inherited from Ocean::ConstAccessor< T, TKey > | |
typedef T | Type |
Definition of the element type of this accessor. | |
typedef TKey | KeyType |
Definition of the key (or e.g., index) type of this accessor. | |
Public Member Functions | |
SharedPointerConstArrayAccessor ()=default | |
Creates a new empty accessor. | |
SharedPointerConstArrayAccessor (SharedPointerConstArrayAccessor< T > &&accessor)=default | |
Move constructor. | |
SharedPointerConstArrayAccessor (const SharedPointer *elements, const size_t size) | |
Creates a new accessor object. | |
SharedPointerConstArrayAccessor (const SharedPointers &elements) | |
Creates a new accessor object. | |
virtual size_t | size () const |
Returns the number of accessible elements of this accessor object. | |
virtual const T *const & | operator[] (const size_t &index) const |
Returns one element of this accessor object. | |
SharedPointerConstArrayAccessor< T > & | operator= (SharedPointerConstArrayAccessor< T > &&accessor)=default |
Move operator. | |
Public Member Functions inherited from Ocean::ConstIndexedAccessor< const T * > | |
virtual bool | canAccess (const size_t &index) const |
Returns whether this accessor has a specific element. | |
virtual bool | firstElement (const T * &element, size_t &index) const |
Returns the first element of this accessor. | |
virtual bool | nextElement (const size_t &previousIndex, const T * &nextElement, size_t &nextIndex) const |
Returns the next element which follows a given key of the previous element. | |
Public Member Functions inherited from Ocean::ConstAccessor< T, TKey > | |
virtual const T * | data () const |
Returns a pointer to the elements of this accessor if the data exists within one memory block without gaps. | |
virtual bool | canAccess (const TKey &key) const =0 |
Returns whether this accessor has a specific element. | |
virtual bool | firstElement (T &element, TKey &key) const =0 |
Returns the first element of this accessor. | |
virtual bool | nextElement (const TKey &previousKey, T &nextElement, TKey &nextKey) const =0 |
Returns the next element which follows a given key of the previous element. | |
virtual const T & | operator[] (const TKey &key) const =0 |
Returns one element of this accessor object by a given key. | |
Public Member Functions inherited from Ocean::Accessor | |
virtual | ~Accessor ()=default |
Default destructor. | |
bool | isEmpty () const |
Returns whether this accessor provides no elements. | |
Protected Attributes | |
std::vector< const T * > | elements_ |
The pointers to the actual elements wrapped in the shared pointers. | |
Additional Inherited Members | |
Static Public Member Functions inherited from Ocean::Accessor | |
template<typename TAccessor > | |
static std::vector< typename TAccessor::Type > | accessor2elements (const TAccessor &accessor) |
Returns all elements of a given accessor (as a block). | |
template<typename TAccessor > | |
static std::unordered_map< typename TAccessor::KeyType, typename TAccessor::Type > | accessor2map (const TAccessor &accessor) |
Returns all elements of a given accessor as a map with key and elements. | |
template<typename TAccessor , typename TIndex > | |
static std::vector< typename TAccessor::Type > | accessor2subsetElements (const TAccessor &accessor, const std::vector< TIndex > &subset) |
Returns a subset of all elements of a given accessor (as a block). | |
Protected Member Functions inherited from Ocean::ConstIndexedAccessor< const T * > | |
ConstIndexedAccessor ()=default | |
Creates a new indexed-based accessor object. | |
Protected Member Functions inherited from Ocean::ConstAccessor< T, TKey > | |
ConstAccessor ()=default | |
Protected default constructor. | |
Protected Member Functions inherited from Ocean::Accessor | |
Accessor ()=default | |
Protected default constructor. | |
Accessor (const Accessor &accessor)=default | |
Protected copy constructor. | |
Accessor & | operator= (const Accessor &accessor)=delete |
Deleted assign operator. | |
This class implements an accessor providing direct access to std::shared_ptr<T> elements returned as const T* pointers.
An instance of this accessor does not copy the elements, thus the caller has to ensure that the actual elements exist as long as the instance of the accessor exists.
This class is mainly a helper class to avoid extracting pointer from a shared_ptr objects and using a normal ConstArrayAccessor
.
The application of the this class is demonstrated in the following code example:
T | The data type of the shared_ptr's element_type |
using Ocean::SharedPointerConstArrayAccessor< T >::SharedPointer = std::shared_ptr<T> |
Definition of the shared pointer object.
using Ocean::SharedPointerConstArrayAccessor< T >::SharedPointers = std::vector<SharedPointer> |
Definition of a vector holding the shared pointer objects.
|
default |
Creates a new empty accessor.
|
default |
Move constructor.
accessor | Accessor to be moved |
|
inline |
Creates a new accessor object.
Beware: The given elements are not copied, they must not be deleted before the accessor is disposed.
elements | The elements that can be accessed, may be nullptr if size is equal 0 |
size | The number of elements that can be accessed, may be 0 if elements is nullptr |
|
inlineexplicit |
Creates a new accessor object.
Beware: The given elements are not copied, they must not be deleted before the accessor is disposed.
elements | A vector holding all elements |
|
default |
|
virtual |
Returns one element of this accessor object.
Implements Ocean::ConstIndexedAccessor< const T * >.
|
virtual |
Returns the number of accessible elements of this accessor object.
Implements Ocean::Accessor.
|
protected |
The pointers to the actual elements wrapped in the shared pointers.