| Top |  |  |  |  | 
GtkTreeSortable is implemented by GtkListStore, GtkTreeModelSort and GtkTreeStore.
gint (*GtkTreeIterCompareFunc) (GtkTreeModel *model,GtkTreeIter *a,GtkTreeIter *b,gpointer user_data);
void
gtk_tree_sortable_sort_column_changed (GtkTreeSortable *sortable);
Emits a “sort-column-changed” signal on sortable
.
gboolean gtk_tree_sortable_get_sort_column_id (GtkTreeSortable *sortable,gint *sort_column_id,GtkSortType *order);
Fills in sort_column_id
 and order
 with the current sort column and the
order. It returns TRUE unless the sort_column_id
 is 
GTK_TREE_SORTABLE_DEFAULT_SORT_COLUMN_ID or 
GTK_TREE_SORTABLE_UNSORTED_SORT_COLUMN_ID.
| sortable | ||
| sort_column_id | The sort column id to be filled in | |
| order | The GtkSortType to be filled in | 
void gtk_tree_sortable_set_sort_column_id (GtkTreeSortable *sortable,gint sort_column_id,GtkSortType order);
Sets the current sort column to be sort_column_id
. The sortable
 will
resort itself to reflect this change, after emitting a
“sort-column-changed” signal. sort_column_id
 may either be
a regular column id, or one of the following special values:
| the default sort function will be used, if it is set | |
| no sorting will occur | 
void gtk_tree_sortable_set_sort_func (GtkTreeSortable *sortable,gint sort_column_id,GtkTreeIterCompareFunc sort_func,gpointer user_data,GDestroyNotify destroy);
Sets the comparison function used when sorting to be sort_func
. If the
current sort column id of sortable
 is the same as sort_column_id
, then 
the model will sort using this function.
void gtk_tree_sortable_set_default_sort_func (GtkTreeSortable *sortable,GtkTreeIterCompareFunc sort_func,gpointer user_data,GDestroyNotify destroy);
Sets the default comparison function used when sorting to be sort_func
.  
If the current sort column id of sortable
 is
GTK_TREE_SORTABLE_DEFAULT_SORT_COLUMN_ID, then the model will sort using 
this function.
If sort_func
 is NULL, then there will be no default comparison function.
This means that once the model  has been sorted, it can't go back to the
default state. In this case, when the current sort column id of sortable
 
is GTK_TREE_SORTABLE_DEFAULT_SORT_COLUMN_ID, the model will be unsorted.
gboolean
gtk_tree_sortable_has_default_sort_func
                               (GtkTreeSortable *sortable);
Returns TRUE if the model has a default sort function. This is used
primarily by GtkTreeViewColumns in order to determine if a model can 
go back to the default state, or not.
struct GtkTreeSortableIface {
  GTypeInterface g_iface;
  /* signals */
  void     (* sort_column_changed)   (GtkTreeSortable        *sortable);
  /* virtual table */
  gboolean (* get_sort_column_id)    (GtkTreeSortable        *sortable,
				      gint                   *sort_column_id,
				      GtkSortType            *order);
  void     (* set_sort_column_id)    (GtkTreeSortable        *sortable,
				      gint                    sort_column_id,
				      GtkSortType             order);
  void     (* set_sort_func)         (GtkTreeSortable        *sortable,
				      gint                    sort_column_id,
				      GtkTreeIterCompareFunc  func,
				      gpointer                data,
				      GDestroyNotify          destroy);
  void     (* set_default_sort_func) (GtkTreeSortable        *sortable,
				      GtkTreeIterCompareFunc  func,
				      gpointer                data,
				      GDestroyNotify          destroy);
  gboolean (* has_default_sort_func) (GtkTreeSortable        *sortable);
};
“sort-column-changed” signalvoid user_function (GtkTreeSortable *sortable, gpointer user_data)
The ::sort-column-changed signal is emitted when the sort column
or sort order of sortable
 is changed. The signal is emitted before
the contents of sortable
 are resorted.
| sortable | the object on which the signal is emitted | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last