|  | 
|  | SortListModel (SortListModel && src) noexcept | 
|  | 
| SortListModel & | operator= (SortListModel && src) noexcept | 
|  | 
|  | ~SortListModel () noexcept override | 
|  | 
| GtkSortListModel * | gobj () | 
|  | Provides access to the underlying C GObject. 
 | 
|  | 
| const GtkSortListModel * | gobj () const | 
|  | Provides access to the underlying C GObject. 
 | 
|  | 
| GtkSortListModel * | gobj_copy () | 
|  | Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. 
 | 
|  | 
| void | set_sorter (const Glib::RefPtr< Sorter > & sorter) | 
|  | Sets a new sorter on self. 
 | 
|  | 
| Glib::RefPtr< Sorter > | get_sorter () | 
|  | Gets the sorter that is used to sort self. 
 | 
|  | 
| Glib::RefPtr< const Sorter > | get_sorter () const | 
|  | Gets the sorter that is used to sort self. 
 | 
|  | 
| void | set_section_sorter (const Glib::RefPtr< Sorter > & sorter) | 
|  | Sets a new section sorter on self. 
 | 
|  | 
| Glib::RefPtr< Sorter > | get_section_sorter () | 
|  | Gets the section sorter that is used to sort items of self into sections. 
 | 
|  | 
| Glib::RefPtr< const Sorter > | get_section_sorter () const | 
|  | Gets the section sorter that is used to sort items of self into sections. 
 | 
|  | 
| void | set_model (const Glib::RefPtr< Gio::ListModel > & model) | 
|  | Sets the model to be sorted. 
 | 
|  | 
| Glib::RefPtr< Gio::ListModel > | get_model () | 
|  | Gets the model currently sorted or nullptrif none.
 | 
|  | 
| Glib::RefPtr< const Gio::ListModel > | get_model () const | 
|  | Gets the model currently sorted or nullptrif none.
 | 
|  | 
| void | set_incremental (bool incremental=true) | 
|  | Sets the sort model to do an incremental sort. 
 | 
|  | 
| bool | get_incremental () const | 
|  | Returns whether incremental sorting is enabled. 
 | 
|  | 
| guint | get_pending () const | 
|  | Estimates progress of an ongoing sorting operation. 
 | 
|  | 
| Glib::PropertyProxy< bool > | property_incremental () | 
|  | If the model should sort items incrementally. 
 | 
|  | 
| Glib::PropertyProxy_ReadOnly< bool > | property_incremental () const | 
|  | If the model should sort items incrementally. 
 | 
|  | 
| Glib::PropertyProxy_ReadOnly< GType > | property_item_type () const | 
|  | The type of items. 
 | 
|  | 
| Glib::PropertyProxy< Glib::RefPtr< Gio::ListModel > > | property_model () | 
|  | The model being sorted. 
 | 
|  | 
| Glib::PropertyProxy_ReadOnly< Glib::RefPtr< Gio::ListModel > > | property_model () const | 
|  | The model being sorted. 
 | 
|  | 
| Glib::PropertyProxy_ReadOnly< unsigned int > | property_n_items () const | 
|  | The number of items. 
 | 
|  | 
| Glib::PropertyProxy_ReadOnly< guint > | property_pending () const | 
|  | Estimate of unsorted items remaining. 
 | 
|  | 
| Glib::PropertyProxy< Glib::RefPtr< Sorter > > | property_sorter () | 
|  | The sorter for this model. 
 | 
|  | 
| Glib::PropertyProxy_ReadOnly< Glib::RefPtr< Sorter > > | property_sorter () const | 
|  | The sorter for this model. 
 | 
|  | 
| Glib::PropertyProxy< Glib::RefPtr< Sorter > > | property_section_sorter () | 
|  | The section sorter for this model, if one is set. 
 | 
|  | 
| Glib::PropertyProxy_ReadOnly< Glib::RefPtr< Sorter > > | property_section_sorter () const | 
|  | The section sorter for this model, if one is set. 
 | 
|  | 
|  | Object (const Object &)=delete | 
|  | 
| Object & | operator= (const Object &)=delete | 
|  | 
|  | Object (Object &&src) noexcept | 
|  | 
| Object & | operator= (Object &&src) noexcept | 
|  | 
| void * | get_data (const QueryQuark &key) | 
|  | 
| void | set_data (const Quark &key, void *data) | 
|  | 
| void | set_data_with_c_callback (const Quark &key, void *data, GDestroyNotify notify) | 
|  | 
| void | set_data (const Quark &key, void *data, DestroyNotify notify) | 
|  | 
| void | remove_data (const QueryQuark &quark) | 
|  | 
| void * | steal_data (const QueryQuark &quark) | 
|  | 
| Glib::RefPtr< Glib::Object > | wrap (GObject *object, bool take_copy=false) | 
|  | 
|  | ObjectBase (const ObjectBase &)=delete | 
|  | 
| ObjectBase & | operator= (const ObjectBase &)=delete | 
|  | 
| void | set_property_value (const Glib::ustring &property_name, const Glib::ValueBase &value) | 
|  | 
| void | get_property_value (const Glib::ustring &property_name, Glib::ValueBase &value) const | 
|  | 
| void | set_property (const Glib::ustring &property_name, const PropertyType &value) | 
|  | 
| void | get_property (const Glib::ustring &property_name, PropertyType &value) const | 
|  | 
| PropertyType | get_property (const Glib::ustring &property_name) const | 
|  | 
| sigc::connection | connect_property_changed (const Glib::ustring &property_name, const sigc::slot< void()> &slot) | 
|  | 
| sigc::connection | connect_property_changed (const Glib::ustring &property_name, sigc::slot< void()> &&slot) | 
|  | 
| void | freeze_notify () | 
|  | 
| void | thaw_notify () | 
|  | 
| virtual void | reference () const | 
|  | 
| virtual void | unreference () const | 
|  | 
| GObject * | gobj () | 
|  | 
| const GObject * | gobj () const | 
|  | 
| GObject * | gobj_copy () const | 
|  | 
|  | ListModel (ListModel &&src) noexcept | 
|  | 
| ListModel & | operator= (ListModel &&src) noexcept | 
|  | 
|  | ~ListModel () noexcept override | 
|  | 
| GListModel * | gobj () | 
|  | 
| const GListModel * | gobj () const | 
|  | 
| GType | get_item_type () const | 
|  | 
| guint | get_n_items () const | 
|  | 
| Glib::RefPtr< Glib::ObjectBase > | get_object (guint position) | 
|  | 
| Glib::RefPtr< const Glib::ObjectBase > | get_object (guint position) const | 
|  | 
| Glib::RefPtr< T_item > | get_typed_object (guint position) | 
|  | 
| Glib::RefPtr< const T_item > | get_typed_object (guint position) const | 
|  | 
| Glib::SignalProxy< void(guint, guint, guint)> | signal_items_changed () | 
|  | 
| Glib::RefPtr< Gio::ListModel > | wrap (GListModel *object, bool take_copy=false) | 
|  | 
|  | Interface () | 
|  | 
|  | Interface (Interface &&src) noexcept | 
|  | 
| Interface & | operator= (Interface &&src) noexcept | 
|  | 
|  | Interface (const Glib::Interface_Class &interface_class) | 
|  | 
|  | Interface (GObject *castitem) | 
|  | 
|  | ~Interface () noexcept override | 
|  | 
|  | Interface (const Interface &)=delete | 
|  | 
| Interface & | operator= (const Interface &)=delete | 
|  | 
| GObject * | gobj () | 
|  | 
| const GObject * | gobj () const | 
|  | 
A list model that sorts its items. 
Gtk::SortListModel is a list model that takes a list model and sorts its elements according to a Gtk::Sorter.
The model can be set up to do incremental sorting, so that sorting long lists doesn't block the UI. See set_incremental() for details.
Gtk::SortListModel is a generic model and because of that it cannot take advantage of any external knowledge when sorting. If you run into performance issues with Gtk::SortListModel, it is strongly recommended that you write your own sorting list model.
- See also
- Gio::ListModel, Gtk::Sorter
- Since gtkmm 3.98
      
        
          | void Gtk::SortListModel::set_incremental | ( | bool | incremental = true | ) |  | 
      
 
Sets the sort model to do an incremental sort. 
When incremental sorting is enabled, the Gtk::SortListModel will not do a complete sort immediately, but will instead queue an idle handler that incrementally sorts the items towards their correct position. This of course means that items do not instantly appear in the right place. It also means that the total sorting time is a lot slower.
When your filter blocks the UI while sorting, you might consider turning this on. Depending on your model and sorters, this may become interesting around 10,000 to 100,000 items.
By default, incremental sorting is disabled.
See get_pending() for progress information about an ongoing incremental sorting operation.
- Parameters
- 
  
    | incremental | trueto sort incrementally. |