| glibmm 2.29.10 | 
A keeper class for GList. More...
#include <glibmm/vectorutils.h>
| Public Types | |
| typedef Tr::CppType | CppType | 
| typedef Tr::CType | CType | 
| Public Member Functions | |
| GListKeeper (const GList* glist, Glib::OwnershipType ownership) | |
| Constructs an GListKeeper holding glist. | |
| GListKeeper (const GListKeeper& keeper) | |
| ~GListKeeper () | |
| GList* | data () const | 
| Gets data the keeper holds. | |
A keeper class for GList.
Primarily used by C++ wrappers like gtkmm.
Its main purpose is to free its data when they are not needed. What will be destroyed depends on passed ownership upon construction.
The most common usage of Glib::GListKeeper is getting its data when converting std::vector to a GList*:
void G::Temp::do_something(const std::vector<int>& v) { g_temp_do_something(gobj(), Glib::ListHandler<int>::vector_to_list(v).data()); }
Variables of this class are seldom defined directly - it is mostly used as a temporary variable returned by Glib::ListHandler::vector_to_list().
Note that the usage above is correct with regards to C++ standard point 12.2.3. That means that data returned by data() method is valid through whole g_temp_do_something function and is destroyed, when this function returns.
| typedef Tr::CppType Glib::Container_Helpers::GListKeeper< Tr >::CppType | 
| typedef Tr::CType Glib::Container_Helpers::GListKeeper< Tr >::CType | 
| Glib::Container_Helpers::GListKeeper< Tr >::GListKeeper | ( | const GList * | glist, | 
| Glib::OwnershipType | ownership | ||
| ) |  [inline, explicit] | 
Constructs an GListKeeper holding glist.
ownership tells what should be destroyed with keeper destruction:
| glist | - GList* to hold. | 
| ownership | - ownership definition. | 
| Glib::Container_Helpers::GListKeeper< Tr >::GListKeeper | ( | const GListKeeper< Tr >& | keeper | ) |  [inline] | 
| Glib::Container_Helpers::GListKeeper< Tr >::~GListKeeper | ( | ) | 
| GList* Glib::Container_Helpers::GListKeeper< Tr >::data | ( | ) | const  [inline] | 
Gets data the keeper holds.
Note that this data is owned by the keeper, so there is no need to free it.
 1.7.3
 1.7.3