Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
QArrayDataPointer< T > Struct Template Reference

#include <qarraydatapointer.h>

Inheritance diagram for QArrayDataPointer< T >:
Collaboration diagram for QArrayDataPointer< T >:

Public Types

enum  { pass_parameter_by_value }
typedef std::conditional< pass_parameter_by_value, T, constT & >::type parameter_type

Public Member Functions

Q_NODISCARD_CTOR constexpr QArrayDataPointer () noexcept
Q_NODISCARD_CTOR QArrayDataPointer (const QArrayDataPointer &other) noexcept
Q_NODISCARD_CTOR constexpr QArrayDataPointer (Data *header, T *adata, qsizetype n=0) noexcept
Q_NODISCARD_CTOR QArrayDataPointer (std::pair< QTypedArrayData< T > *, T * > adata, qsizetype n=0) noexcept
Q_NODISCARD_CTOR QArrayDataPointer (qsizetype alloc, qsizetype n=0, QArrayData::AllocationOption option=QArrayData::KeepSize)
QArrayDataPointeroperator= (const QArrayDataPointer &other) noexcept
Q_NODISCARD_CTOR QArrayDataPointer (QArrayDataPointer &&other) noexcept
DataOpsoperator* () noexcept
DataOpsoperator-> () noexcept
const DataOpsoperator* () const noexcept
const DataOpsoperator-> () const noexcept
 ~QArrayDataPointer ()
constexpr bool isNull () const noexcept
T * data () noexcept
const T * data () const noexcept
T * begin () noexcept
T * end () noexcept
const T * begin () const noexcept
const T * end () const noexcept
const T * constBegin () const noexcept
const T * constEnd () const noexcept
void swap (QArrayDataPointer &other) noexcept
void clear () noexcept(std::is_nothrow_destructible< T >::value)
void detach (QArrayDataPointer *old=nullptr)
template<typename X>
QArrayDataPointer< Xreinterpreted () &&
void detachAndGrow (QArrayData::GrowthPosition where, qsizetype n, const T **data, QArrayDataPointer *old)
Q_NEVER_INLINE void reallocateAndGrow (QArrayData::GrowthPosition where, qsizetype n, QArrayDataPointer *old=nullptr)
bool tryReadjustFreeSpace (QArrayData::GrowthPosition pos, qsizetype n, const T **data=nullptr)
void relocate (qsizetype offset, const T **data=nullptr)
template<typename InputIterator, typename Projection = q20::identity>
void assign (InputIterator first, InputIterator last, Projection proj={})
QArrayDataPointer sliced (qsizetype pos, qsizetype n) const &
QArrayDataPointer sliced (qsizetype pos, qsizetype n) &&
void appendInitialize (qsizetype newSize)
qsizetype allocatedCapacity () noexcept
qsizetype constAllocatedCapacity () const noexcept
void ref () noexcept
bool deref () noexcept
bool isMutable () const noexcept
bool isShared () const noexcept
bool isSharedWith (const QArrayDataPointer &other) const noexcept
bool needsDetach () const noexcept
qsizetype detachCapacity (qsizetype newSize) const noexcept
const Data::ArrayOptions flags () const noexcept
void setFlag (typename Data::ArrayOptions f) noexcept
void clearFlag (typename Data::ArrayOptions f) noexcept
Datad_ptr () noexcept
void setBegin (T *begin) noexcept
qsizetype freeSpaceAtBegin () const noexcept
qsizetype freeSpaceAtEnd () const noexcept

Static Public Member Functions

static Q_NODISCARD_CTOR QArrayDataPointer fromRawData (const T *rawData, qsizetype length) noexcept
static QArrayDataPointer allocateGrow (const QArrayDataPointer &from, qsizetype n, QArrayData::GrowthPosition position)

Public Attributes

Datad
T * ptr
qsizetype size

Friends

bool operator== (const QArrayDataPointer &lhs, const QArrayDataPointer &rhs) noexcept
bool operator!= (const QArrayDataPointer &lhs, const QArrayDataPointer &rhs) noexcept

Detailed Description

template<class T>
struct QArrayDataPointer< T >

Definition at line 16 of file qarraydatapointer.h.

Member Typedef Documentation

◆ parameter_type

template<class T>
typedef std::conditional<pass_parameter_by_value,T,constT&>::type QArrayDataPointer< T >::parameter_type

Definition at line 28 of file qarraydatapointer.h.

Member Enumeration Documentation

◆ anonymous enum

template<class T>
anonymous enum
Enumerator
pass_parameter_by_value 

Definition at line 23 of file qarraydatapointer.h.

Constructor & Destructor Documentation

◆ QArrayDataPointer() [1/6]

template<class T>
Q_NODISCARD_CTOR constexpr QArrayDataPointer< T >::QArrayDataPointer ( )
inlineconstexprnoexcept

Definition at line 31 of file qarraydatapointer.h.

◆ QArrayDataPointer() [2/6]

template<class T>
Q_NODISCARD_CTOR QArrayDataPointer< T >::QArrayDataPointer ( const QArrayDataPointer< T > & other)
inlinenoexcept

Definition at line 37 of file qarraydatapointer.h.

◆ QArrayDataPointer() [3/6]

template<class T>
Q_NODISCARD_CTOR constexpr QArrayDataPointer< T >::QArrayDataPointer ( Data * header,
T * adata,
qsizetype n = 0 )
inlineconstexprnoexcept

Definition at line 44 of file qarraydatapointer.h.

◆ QArrayDataPointer() [4/6]

template<class T>
Q_NODISCARD_CTOR QArrayDataPointer< T >::QArrayDataPointer ( std::pair< QTypedArrayData< T > *, T * > adata,
qsizetype n = 0 )
inlineexplicitnoexcept

Definition at line 50 of file qarraydatapointer.h.

◆ QArrayDataPointer() [5/6]

Definition at line 56 of file qarraydatapointer.h.

◆ QArrayDataPointer() [6/6]

template<class T>
Q_NODISCARD_CTOR QArrayDataPointer< T >::QArrayDataPointer ( QArrayDataPointer< T > && other)
inlinenoexcept

Definition at line 77 of file qarraydatapointer.h.

◆ ~QArrayDataPointer()

template<class T>
QArrayDataPointer< T >::~QArrayDataPointer ( )
inline

Definition at line 106 of file qarraydatapointer.h.

Member Function Documentation

◆ allocatedCapacity()

template<class T>
qsizetype QArrayDataPointer< T >::allocatedCapacity ( )
inlinenoexcept

Definition at line 449 of file qarraydatapointer.h.

◆ allocateGrow()

template<class T>
QArrayDataPointer QArrayDataPointer< T >::allocateGrow ( const QArrayDataPointer< T > & from,
qsizetype n,
QArrayData::GrowthPosition position )
inlinestatic

Definition at line 480 of file qarraydatapointer.h.

◆ appendInitialize()

template<class T>
void QArrayDataPointer< T >::appendInitialize ( qsizetype newSize)
inline

Definition at line 435 of file qarraydatapointer.h.

◆ assign()

template<class T>
template<typename InputIterator, typename Projection = q20::identity>
void QArrayDataPointer< T >::assign ( InputIterator first,
InputIterator last,
Projection proj = {} )
inline

Definition at line 324 of file qarraydatapointer.h.

◆ begin() [1/2]

template<class T>
const T * QArrayDataPointer< T >::begin ( ) const
inlinenoexcept

Definition at line 124 of file qarraydatapointer.h.

◆ begin() [2/2]

template<class T>
T * QArrayDataPointer< T >::begin ( )
inlinenoexcept

Definition at line 122 of file qarraydatapointer.h.

◆ clear()

template<class T>
void QArrayDataPointer< T >::clear ( )
inlinenoexcept

Definition at line 136 of file qarraydatapointer.h.

◆ clearFlag()

template<class T>
void QArrayDataPointer< T >::clearFlag ( typename Data::ArrayOptions f)
inlinenoexcept

Definition at line 460 of file qarraydatapointer.h.

◆ constAllocatedCapacity()

template<class T>
qsizetype QArrayDataPointer< T >::constAllocatedCapacity ( ) const
inlinenoexcept

Definition at line 450 of file qarraydatapointer.h.

◆ constBegin()

template<class T>
const T * QArrayDataPointer< T >::constBegin ( ) const
inlinenoexcept

Definition at line 126 of file qarraydatapointer.h.

◆ constEnd()

template<class T>
const T * QArrayDataPointer< T >::constEnd ( ) const
inlinenoexcept

Definition at line 127 of file qarraydatapointer.h.

◆ d_ptr()

template<class T>
Data * QArrayDataPointer< T >::d_ptr ( )
inlinenoexcept

Definition at line 462 of file qarraydatapointer.h.

◆ data() [1/2]

template<class T>
const T * QArrayDataPointer< T >::data ( ) const
inlinenoexcept

Definition at line 120 of file qarraydatapointer.h.

◆ data() [2/2]

template<class T>
T * QArrayDataPointer< T >::data ( )
inlinenoexcept

Definition at line 119 of file qarraydatapointer.h.

◆ deref()

template<class T>
bool QArrayDataPointer< T >::deref ( )
inlinenoexcept

Definition at line 452 of file qarraydatapointer.h.

◆ detach()

template<class T>
void QArrayDataPointer< T >::detach ( QArrayDataPointer< T > * old = nullptr)
inline

Definition at line 142 of file qarraydatapointer.h.

◆ detachAndGrow()

template<class T>
void QArrayDataPointer< T >::detachAndGrow ( QArrayData::GrowthPosition where,
qsizetype n,
const T ** data,
QArrayDataPointer< T > * old )
inline

Detaches this (optionally) and grows to accommodate the free space for n elements at the required side. The side is determined from pos.

data pointer can be provided when the caller knows that data points into range [this->begin(), this->end()). In case it is, *data would be updated so that it continues to point to the element it was pointing to before the data move. if data does not point into range, one can/should pass nullptr.

Similarly to data, old, pointer to a default-constructed QADP, can be provided when the caller expects to e.g. copy the data from this to itself:

qsizetype pos = getArbitraryPos();
list.insert(pos, list.begin(), list.end());
Definition qlist.h:80
ptrdiff_t qsizetype
Definition qtypes.h:183
QList< int > list
[14]

The default rule would be: data and old must either both be valid pointers, or both equal to nullptr.

Definition at line 193 of file qarraydatapointer.h.

◆ detachCapacity()

template<class T>
qsizetype QArrayDataPointer< T >::detachCapacity ( qsizetype newSize) const
inlinenoexcept

Definition at line 457 of file qarraydatapointer.h.

◆ end() [1/2]

template<class T>
const T * QArrayDataPointer< T >::end ( ) const
inlinenoexcept

Definition at line 125 of file qarraydatapointer.h.

◆ end() [2/2]

template<class T>
T * QArrayDataPointer< T >::end ( )
inlinenoexcept

Definition at line 123 of file qarraydatapointer.h.

◆ flags()

template<class T>
const Data::ArrayOptions QArrayDataPointer< T >::flags ( ) const
inlinenoexcept

Definition at line 458 of file qarraydatapointer.h.

◆ freeSpaceAtBegin()

template<class T>
qsizetype QArrayDataPointer< T >::freeSpaceAtBegin ( ) const
inlinenoexcept

Definition at line 465 of file qarraydatapointer.h.

◆ freeSpaceAtEnd()

template<class T>
qsizetype QArrayDataPointer< T >::freeSpaceAtEnd ( ) const
inlinenoexcept

Definition at line 472 of file qarraydatapointer.h.

◆ fromRawData()

template<class T>
Q_NODISCARD_CTOR QArrayDataPointer QArrayDataPointer< T >::fromRawData ( const T * rawData,
qsizetype length )
inlinestaticnoexcept

Definition at line 63 of file qarraydatapointer.h.

◆ isMutable()

template<class T>
bool QArrayDataPointer< T >::isMutable ( ) const
inlinenoexcept

Definition at line 453 of file qarraydatapointer.h.

◆ isNull()

template<class T>
bool QArrayDataPointer< T >::isNull ( ) const
inlineconstexprnoexcept

Definition at line 114 of file qarraydatapointer.h.

◆ isShared()

template<class T>
bool QArrayDataPointer< T >::isShared ( ) const
inlinenoexcept

Definition at line 454 of file qarraydatapointer.h.

◆ isSharedWith()

template<class T>
bool QArrayDataPointer< T >::isSharedWith ( const QArrayDataPointer< T > & other) const
inlinenoexcept

Definition at line 455 of file qarraydatapointer.h.

◆ needsDetach()

template<class T>
bool QArrayDataPointer< T >::needsDetach ( ) const
inlinenoexcept

Definition at line 456 of file qarraydatapointer.h.

◆ operator*() [1/2]

template<class T>
const DataOps & QArrayDataPointer< T >::operator* ( ) const
inlinenoexcept

Definition at line 96 of file qarraydatapointer.h.

◆ operator*() [2/2]

template<class T>
DataOps & QArrayDataPointer< T >::operator* ( )
inlinenoexcept

Definition at line 86 of file qarraydatapointer.h.

◆ operator->() [1/2]

template<class T>
const DataOps * QArrayDataPointer< T >::operator-> ( ) const
inlinenoexcept

Definition at line 101 of file qarraydatapointer.h.

◆ operator->() [2/2]

template<class T>
DataOps * QArrayDataPointer< T >::operator-> ( )
inlinenoexcept

Definition at line 91 of file qarraydatapointer.h.

◆ operator=()

template<class T>
QArrayDataPointer & QArrayDataPointer< T >::operator= ( const QArrayDataPointer< T > & other)
inlinenoexcept

Definition at line 69 of file qarraydatapointer.h.

◆ reallocateAndGrow()

template<class T>
Q_NEVER_INLINE void QArrayDataPointer< T >::reallocateAndGrow ( QArrayData::GrowthPosition where,
qsizetype n,
QArrayDataPointer< T > * old = nullptr )
inline

Reallocates to accommodate the free space for n elements at the required side. The side is determined from pos. Might also shrink when n < 0.

Definition at line 218 of file qarraydatapointer.h.

◆ ref()

template<class T>
void QArrayDataPointer< T >::ref ( )
inlinenoexcept

Definition at line 451 of file qarraydatapointer.h.

◆ reinterpreted()

template<class T>
template<typename X>
QArrayDataPointer< X > QArrayDataPointer< T >::reinterpreted ( ) &&
inline

Reinterprets the data of this QArrayDataPointer to type X. It's the caller's responsibility to ensure that the data contents are valid and properly aligned, particularly if T and X are not trivial types (i.e, don't do that). The current size is kept and the allocated capacity is updated to account for the difference in the element type's size.

This is used in QString::fromLatin1 to perform in-place conversion of QString to QByteArray.

Definition at line 159 of file qarraydatapointer.h.

◆ relocate()

template<class T>
void QArrayDataPointer< T >::relocate ( qsizetype offset,
const T ** data = nullptr )
inline

Relocates [begin(), end()) by offset and updates data if it is not nullptr and points into [begin(), end()).

Definition at line 313 of file qarraydatapointer.h.

◆ setBegin()

template<class T>
void QArrayDataPointer< T >::setBegin ( T * begin)
inlinenoexcept

Definition at line 463 of file qarraydatapointer.h.

◆ setFlag()

template<class T>
void QArrayDataPointer< T >::setFlag ( typename Data::ArrayOptions f)
inlinenoexcept

Definition at line 459 of file qarraydatapointer.h.

◆ sliced() [1/2]

template<class T>
QArrayDataPointer QArrayDataPointer< T >::sliced ( qsizetype pos,
qsizetype n ) &&
inline

Definition at line 423 of file qarraydatapointer.h.

◆ sliced() [2/2]

template<class T>
QArrayDataPointer QArrayDataPointer< T >::sliced ( qsizetype pos,
qsizetype n ) const &
inline

Definition at line 415 of file qarraydatapointer.h.

◆ swap()

template<class T>
void QArrayDataPointer< T >::swap ( QArrayDataPointer< T > & other)
inlinenoexcept

Definition at line 129 of file qarraydatapointer.h.

◆ tryReadjustFreeSpace()

template<class T>
bool QArrayDataPointer< T >::tryReadjustFreeSpace ( QArrayData::GrowthPosition pos,
qsizetype n,
const T ** data = nullptr )
inline

Attempts to relocate [begin(), end()) to accommodate the free space for n elements at the required side. The side is determined from pos.

Returns true if the internal data is moved. Returns false when there is no point in moving the data or the move is impossible. If false is returned, it is the responsibility of the caller to figure out how to accommodate the free space for n elements at pos.

This function expects that certain preconditions are met, e.g. the detach is not needed, n > 0 and so on. This is intentional to reduce the number of if-statements when the caller knows that preconditions would be satisfied.

See also
reallocateAndGrow

Definition at line 269 of file qarraydatapointer.h.

◆ operator!=

template<class T>
bool operator!= ( const QArrayDataPointer< T > & lhs,
const QArrayDataPointer< T > & rhs )
friend

Definition at line 511 of file qarraydatapointer.h.

◆ operator==

template<class T>
bool operator== ( const QArrayDataPointer< T > & lhs,
const QArrayDataPointer< T > & rhs )
friend

Definition at line 506 of file qarraydatapointer.h.

Member Data Documentation

◆ d

template<class T>
Data* QArrayDataPointer< T >::d

Definition at line 516 of file qarraydatapointer.h.

◆ ptr

template<class T>
T* QArrayDataPointer< T >::ptr

Definition at line 517 of file qarraydatapointer.h.

◆ size

template<class T>
qsizetype QArrayDataPointer< T >::size

Definition at line 518 of file qarraydatapointer.h.


The documentation for this struct was generated from the following files: