Allocate and hold a VTK object.
More...
#include <vtkNew.h>
|
| vtkNew () |
| Create a new T on construction. More...
|
|
T * | operator-> () const noexcept |
| Enable pointer-like dereference syntax. More...
|
|
T & | operator* () const noexcept |
| Dereference the pointer and return a reference to the contained object. More...
|
|
|
| vtkNew (vtkNew &&o) noexcept |
| Move the object into the constructed vtkNew wrapper, stealing its reference. More...
|
|
template<typename U > |
| vtkNew (vtkNew< U > &&o) noexcept |
| Move the object into the constructed vtkNew wrapper, stealing its reference. More...
|
|
|
| ~vtkNew () |
| Deletes reference to instance of T. More...
|
|
void | Reset () |
| Deletes reference to instance of T. More...
|
|
|
T * | GetPointer () const noexcept |
| Get a raw pointer to the contained object. More...
|
|
T * | Get () const noexcept |
| Get a raw pointer to the contained object. More...
|
|
| operator T* () const noexcept |
| Get a raw pointer to the contained object. More...
|
|
template<class T>
class vtkNew< T >
Allocate and hold a VTK object.
vtkNew is a class template that on construction allocates and initializes an instance of its template argument using T::New(). It assumes ownership of one reference during its lifetime, and calls T->Delete() on destruction.
Automatic casting to raw pointer is available for convenience, but users of this method should ensure that they do not return this pointer if the vtkNew will go out of scope without incrementing its reference count.
vtkNew is a drop in replacement for vtkSmartPointer, for example,
renWin->AddRenderer(ren);
iren->SetRenderWindow(renWin);
- See also
- vtkSmartPointer vtkWeakPointer
- Online Examples:
Definition at line 164 of file vtkNew.h.
◆ vtkNew() [1/3]
Create a new T on construction.
Definition at line 197 of file vtkNew.h.
◆ vtkNew() [2/3]
Move the object into the constructed vtkNew wrapper, stealing its reference.
The argument is reset to nullptr.
Definition at line 208 of file vtkNew.h.
◆ vtkNew() [3/3]
template<class T >
template<typename U >
Move the object into the constructed vtkNew wrapper, stealing its reference.
The argument is reset to nullptr.
Definition at line 215 of file vtkNew.h.
◆ ~vtkNew()
Deletes reference to instance of T.
Definition at line 228 of file vtkNew.h.
◆ Reset()
Deletes reference to instance of T.
Definition at line 230 of file vtkNew.h.
◆ operator->()
template<class T >
T * vtkNew< T >::operator-> |
( |
| ) |
const |
|
inlinenoexcept |
Enable pointer-like dereference syntax.
Returns a pointer to the contained object.
Definition at line 245 of file vtkNew.h.
◆ GetPointer()
template<class T >
T * vtkNew< T >::GetPointer |
( |
| ) |
const |
|
inlinenoexcept |
Get a raw pointer to the contained object.
When using this function be careful that the reference count does not drop to 0 when using the pointer returned. This will happen when the vtkNew object goes out of scope for example.
Definition at line 254 of file vtkNew.h.
◆ Get()
template<class T >
T * vtkNew< T >::Get |
( |
| ) |
const |
|
inlinenoexcept |
Get a raw pointer to the contained object.
When using this function be careful that the reference count does not drop to 0 when using the pointer returned. This will happen when the vtkNew object goes out of scope for example.
Definition at line 255 of file vtkNew.h.
◆ operator T*()
template<class T >
vtkNew< T >::operator T* |
( |
| ) |
const |
|
inlinenoexcept |
Get a raw pointer to the contained object.
When using this function be careful that the reference count does not drop to 0 when using the pointer returned. This will happen when the vtkNew object goes out of scope for example.
Definition at line 256 of file vtkNew.h.
◆ operator*()
template<class T >
T & vtkNew< T >::operator* |
( |
| ) |
const |
|
inlinenoexcept |
Dereference the pointer and return a reference to the contained object.
When using this function be careful that the reference count does not drop to 0 when using the pointer returned. This will happen when the vtkNew object goes out of scope for example.
Definition at line 264 of file vtkNew.h.
◆ vtkNew
template<class T >
template<typename U >
◆ vtkSmartPointer
template<class T >
template<typename U >
◆ vtkWeakPointer
template<class T >
template<typename U >
The documentation for this class was generated from the following files: