c++-gtk-utils
Public Member Functions | List of all members
Cgu::ScopedHandle< T, Dealloc > Class Template Reference

This is a generic scoped class for managing the lifetime of objects allocated on freestore. More...

#include <c++-gtk-utils/shared_handle.h>

Public Member Functions

 ScopedHandle (const ScopedHandle &)=delete
 
ScopedHandleoperator= (const ScopedHandle &)=delete
 
 ScopedHandle (ScopedHandle &&sc_hand) noexcept
 
ScopedHandleoperator= (ScopedHandle &&sc_hand)
 
 ScopedHandle (T ptr=0) noexcept
 
void reset (T ptr=0)
 
release () noexcept
 
get () const noexcept
 
 operator T () const noexcept
 
 ~ScopedHandle ()
 

Detailed Description

template<class T, class Dealloc = StandardArrayDelete<T>>
class Cgu::ScopedHandle< T, Dealloc >

This is a generic scoped class for managing the lifetime of objects allocated on freestore.

See also
SharedHandle SharedLockHandle SharedHandleError
StandardArrayDelete CFree GFree GerrorFree GSliceFree GSliceFreeSize GSliceDestroy

This class deletes its object as soon as it goes out of scope. It can be viewed as a SharedHandle which cannot be copy assigned to or used as the argument to a copy constructor and therefore which cannot have a reference count of more than 1.

ScopedHandle objects can be instantiated for pointers to constant objects (such as ScopedHandle<const char*>), provided the deleter functor will take such pointers.

This library provides StandardArrayDelete, CFree, GFree, GerrorFree, GSliceFree, GSliceFreeSize and GSliceDestroy deleter functors, which can be used as the second template parameter of the ScopedHandle class. StandardArrayDelete is the default, and some typedef'ed instances of ScopedHandle for gchar (with the GFree deleter) and for GError (with the GerrorFree deleter) are provided: GcharScopedHandle and GerrorScopedHandle)

Comparison with std::unique_ptr

This class is mainly retained to retain compatibility with series 1.2 of the library, since most of the things that can be done with it can also be done using std::unique_ptr. However, this class is a little easier to use when managing objects with associated C functions (such as in glib), because it provides a type conversion operator.

From version 2.2.2, this class has a move constructor and move assignment operator. Prior to that, it could not be moved from or to.

Constructor & Destructor Documentation

◆ ScopedHandle() [1/3]

template<class T , class Dealloc = StandardArrayDelete<T>>
Cgu::ScopedHandle< T, Dealloc >::ScopedHandle ( const ScopedHandle< T, Dealloc > &  )
delete

This class cannot be copied. The copy constructor is deleted.

◆ ScopedHandle() [2/3]

template<class T , class Dealloc = StandardArrayDelete<T>>
Cgu::ScopedHandle< T, Dealloc >::ScopedHandle ( ScopedHandle< T, Dealloc > &&  sc_hand)
inlinenoexcept

The move constructor does not throw.

Parameters
sc_handThe handle to be moved.

Since 2.0.19/2.2.2

◆ ScopedHandle() [3/3]

template<class T , class Dealloc = StandardArrayDelete<T>>
Cgu::ScopedHandle< T, Dealloc >::ScopedHandle ( ptr = 0)
inlineexplicitnoexcept

This constructor does not throw.

Parameters
ptrThe object which the ScopedHandle is to manage (if any).

ScopedHandle objects can be instantiated for pointers to constant objects (such as SharedHandle<const char*>), provided the deleter functor will take such pointers.

◆ ~ScopedHandle()

template<class T , class Dealloc = StandardArrayDelete<T>>
Cgu::ScopedHandle< T, Dealloc >::~ScopedHandle ( )
inline

The destructor does not throw unless the destructor of a handled object throws - that should never happen.

Member Function Documentation

◆ get()

template<class T , class Dealloc = StandardArrayDelete<T>>
T Cgu::ScopedHandle< T, Dealloc >::get ( ) const
inlinenoexcept

This method does not throw.

Returns
A pointer to the handled object (or NULL if none is handled).

◆ operator T()

template<class T , class Dealloc = StandardArrayDelete<T>>
Cgu::ScopedHandle< T, Dealloc >::operator T ( ) const
inlinenoexcept

This method does not throw.

Returns
A pointer to the handled object (or NULL if none is handled).

◆ operator=() [1/2]

template<class T , class Dealloc = StandardArrayDelete<T>>
ScopedHandle& Cgu::ScopedHandle< T, Dealloc >::operator= ( const ScopedHandle< T, Dealloc > &  )
delete

This class cannot be copied. The copy assignment operator is deleted.

◆ operator=() [2/2]

template<class T , class Dealloc = StandardArrayDelete<T>>
ScopedHandle& Cgu::ScopedHandle< T, Dealloc >::operator= ( ScopedHandle< T, Dealloc > &&  sc_hand)
inline

The move assignment operator. It will delete the object managed prior to the move, if any. It does not throw unless the destructor of that object throws.

Parameters
sc_handThe handle to be moved.
Returns
The ScopedHandle object after move assignment.

Since 2.0.19/2.2.2

◆ release()

template<class T , class Dealloc = StandardArrayDelete<T>>
T Cgu::ScopedHandle< T, Dealloc >::release ( )
inlinenoexcept

Causes the ScopedHandle to cease to manage the handled object, but does not delete that object. This method does not throw.

Returns
A pointer to the previously handled object (or NULL if none was handled).

◆ reset()

template<class T , class Dealloc = StandardArrayDelete<T>>
void Cgu::ScopedHandle< T, Dealloc >::reset ( ptr = 0)
inline

Causes the ScopedHandle to delete its managed object (if any), and if the argument passed is not NULL, the ScopedHandle object will manage the new object passed (which must not be managed by any other ScopedHandle object). This method does not throw (assuming the destructor of a managed object does not throw).

Parameters
ptrNULL (the default), or a new unmanaged object to manage.

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