Holds a pointer to some type of Component, which automatically becomes null if the component is deleted. More...
Public Member Functions | |
SafePointer ()=default | |
Creates a null SafePointer. | |
SafePointer (ComponentType *component) | |
Creates a SafePointer that points at the given component. | |
SafePointer (const SafePointer &other) noexcept | |
Creates a copy of another SafePointer. | |
SafePointer & | operator= (const SafePointer &other) |
Copies another pointer to this one. | |
SafePointer & | operator= (ComponentType *newComponent) |
Copies another pointer to this one. | |
ComponentType * | getComponent () const noexcept |
Returns the component that this pointer refers to, or null if the component no longer exists. | |
operator ComponentType * () const noexcept | |
Returns the component that this pointer refers to, or null if the component no longer exists. | |
ComponentType * | operator-> () const noexcept |
Returns the component that this pointer refers to, or null if the component no longer exists. | |
void | deleteAndZero () |
If the component is valid, this deletes it and sets this pointer to null. | |
bool | operator== (SafePointer other) const noexcept |
bool | operator!= (SafePointer other) const noexcept |
bool | operator== (ComponentType *component) const noexcept |
bool | operator!= (ComponentType *component) const noexcept |
Holds a pointer to some type of Component, which automatically becomes null if the component is deleted.
If you're using a component which may be deleted by another event that's outside of your control, use a SafePointer instead of a normal pointer to refer to it, and you can test whether it's null before using it to see if something has deleted it.
The ComponentType template parameter must be Component, or some subclass of Component.
You may also want to use a WeakReference<Component> object for the same purpose.
|
default |
Creates a null SafePointer.
Referenced by operator!=(), operator=(), operator=(), operator==(), and SafePointer().
Component::SafePointer< ComponentType >::SafePointer | ( | ComponentType * | component | ) |
Creates a SafePointer that points at the given component.
|
noexcept |
Creates a copy of another SafePointer.
References SafePointer().
SafePointer & Component::SafePointer< ComponentType >::operator= | ( | const SafePointer< ComponentType > & | other | ) |
Copies another pointer to this one.
References SafePointer().
SafePointer & Component::SafePointer< ComponentType >::operator= | ( | ComponentType * | newComponent | ) |
Copies another pointer to this one.
References SafePointer().
|
noexcept |
Returns the component that this pointer refers to, or null if the component no longer exists.
Referenced by operator->().
|
noexcept |
Returns the component that this pointer refers to, or null if the component no longer exists.
|
noexcept |
Returns the component that this pointer refers to, or null if the component no longer exists.
References getComponent().
void Component::SafePointer< ComponentType >::deleteAndZero | ( | ) |
If the component is valid, this deletes it and sets this pointer to null.
|
noexcept |
References SafePointer().
|
noexcept |
References operator==(), and SafePointer().
|
noexcept |
|
noexcept |