UDocumentation UE5.7 10.02.2026 (Source)
API documentation for Unreal Engine 5.7
TFieldPtrAccessor< T > Class Template Reference

#include <FieldAccessor.h>

Public Member Functions

 TFieldPtrAccessor (TFunction< T *()> InGet, TFunction< void(T *)> InSet)
 
 TFieldPtrAccessor (T *InValue=nullptr)
 
 TFieldPtrAccessor (const TFieldPtrAccessor &Other)
 
TFieldPtrAccessoroperator= (const TFieldPtrAccessor &Other)=delete
 
TFieldPtrAccessoroperator= (TFieldPtrAccessor &&)=delete
 
T * operator-> () const
 
 operator bool () const
 
 operator T* () const
 
template<typename OtherT >
 operator OtherT * () const
 
bool operator! () const
 
bool operator== (const T *OtherPtr) const
 
bool operator!= (const T *OtherPtr) const
 
TFieldPtrAccessoroperator= (T *OtherPtr)
 

Detailed Description

template<typename T>
class TFieldPtrAccessor< T >

Helper to provide backward compatibility when converting a raw pointer into accessors.

The helper is trying hard to mimic's a raw pointer field functionality without breaking compatibility for existing code.

The helper's getter are all const and return a non-const pointer. This is because accessing a pointer field inside a const struct will not make that pointer const like we typically do for accessors. Since we want to mimic the behavior of a public field as much as possible, we offer that same functionality.

The helper supports being captured in a lamba as seen below and will become a const copy of the value at the capture's moment. ex: [CapturedValue = Object.OnceARawFieldBecomingAnAccessor]() { // ExtractedValue contains a copy that will not change even if the original Object.OnceARawFieldBecomingAnAccessor changes. const Class* ExtractedValue = CapturedValue; });

This helper also supports taking a nullptr in its constructor so it properly supports conditional like such ex: ExtractedValue* Val = (Condition) ? Object.OnceARawFieldBecomingAnAccessor : nullptr;

A comforming compiler is supposed to try both conversions (nullptr -> TFieldPtrAccessor and TFieldPtrAccessor -> nullptr) but MSVC without the /permissive- flag will only try to cast nullptr into a TFieldPtrAccessor, which has to succeed to avoid breaking compabitility with existing code.

For more info, please refer to https://docs.microsoft.com/en-us/cpp/build/reference/permissive-standards-conformance?view=vs-2019#ambiguous-conditional-operator-arguments

Constructor & Destructor Documentation

◆ TFieldPtrAccessor() [1/3]

template<typename T >
TFieldPtrAccessor< T >::TFieldPtrAccessor ( TFunction< T *()>  InGet,
TFunction< void(T *)>  InSet 
)
inline

◆ TFieldPtrAccessor() [2/3]

template<typename T >
TFieldPtrAccessor< T >::TFieldPtrAccessor ( T *  InValue = nullptr)
inline

◆ TFieldPtrAccessor() [3/3]

template<typename T >
TFieldPtrAccessor< T >::TFieldPtrAccessor ( const TFieldPtrAccessor< T > &  Other)
inline

Member Function Documentation

◆ operator bool()

template<typename T >
TFieldPtrAccessor< T >::operator bool ( ) const
inline

◆ operator OtherT *()

template<typename T >
template<typename OtherT >
TFieldPtrAccessor< T >::operator OtherT * ( ) const
inlineexplicit

◆ operator T*()

template<typename T >
TFieldPtrAccessor< T >::operator T* ( ) const
inline

◆ operator!()

template<typename T >
bool TFieldPtrAccessor< T >::operator! ( ) const
inline

◆ operator!=()

template<typename T >
bool TFieldPtrAccessor< T >::operator!= ( const T *  OtherPtr) const
inline

◆ operator->()

template<typename T >
T * TFieldPtrAccessor< T >::operator-> ( ) const
inline

◆ operator=() [1/3]

template<typename T >
TFieldPtrAccessor & TFieldPtrAccessor< T >::operator= ( const TFieldPtrAccessor< T > &  Other)
delete

◆ operator=() [2/3]

template<typename T >
TFieldPtrAccessor & TFieldPtrAccessor< T >::operator= ( T *  OtherPtr)
inline

◆ operator=() [3/3]

template<typename T >
TFieldPtrAccessor & TFieldPtrAccessor< T >::operator= ( TFieldPtrAccessor< T > &&  )
delete

◆ operator==()

template<typename T >
bool TFieldPtrAccessor< T >::operator== ( const T *  OtherPtr) const
inline

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