diff options
author | Not Zed <NotZed@HelixCode.com> | 2000-10-04 23:51:35 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2000-10-04 23:51:35 +0800 |
commit | 58eba683f83f3b6e2ca023c34e6eae647d929409 (patch) | |
tree | b3f8feb446ef991df4a39fda25959d6b1b256294 /widgets/table/e-table-model.c | |
parent | dcb9840881ea727701ccc12b5c96545825881064 (diff) | |
download | gsoc2013-evolution-58eba683f83f3b6e2ca023c34e6eae647d929409.tar.gz gsoc2013-evolution-58eba683f83f3b6e2ca023c34e6eae647d929409.tar.zst gsoc2013-evolution-58eba683f83f3b6e2ca023c34e6eae647d929409.zip |
Changed to take into account the sort group, if the table has one.x
2000-10-04 Not Zed <NotZed@HelixCode.com>
* e-table-sorted-variable.c (etsv_add): Changed to take into
account the sort group, if the table has one.x
(etsv_insert_idle): Clear the insert count if we hit an idle loop.
(etsv_sort_idle): Reset the insert count if we perform a sort.
(etsv_add): If we are adding a lot (>ETSV_INSERT_MAX) items,
without hitting an idle loop, assume we're better off performing a
sort instead. Use another idle handler to reset the count.
2000-10-03 Not Zed <NotZed@HelixCode.com>
* e-table-sorted-variable.c (etsv_sort_by_group): Sort based on
the sort_group stuff.
* e-tree-model.c (e_tree_init): Setup the group sort info string.
(etree_destroy): And free it.
(build_sort_group): Build a string for this node.
2000-09-29 Not Zed <NotZed@HelixCode.com>
* e-cell-tree.c (e_cell_tree_get_node): Changed to take the source
model, not the tree model. The source model may be a subset, and
it needs to remap the rows for us.
(ect_draw):
(ect_event):
(ect_max_width):
(ect_print): Changed callers.
* e-table-sorted-variable.c (etsv_sort_subset):
(etsv_sort_build_subset):
(etsv_sort_free_subset): Functions to perfom grouping of sorts for
sorts that have row_sort_group returning useful info.
(etsv_sort): Use the complex sort routines if we need to.
* e-table-model.c (e_table_model_row_sort_group): Return a sort-id
for a given row.
(e_table_model_has_sort_group): Return if the sort-id provides any
useful information.
svn path=/trunk/; revision=5705
Diffstat (limited to 'widgets/table/e-table-model.c')
-rw-r--r-- | widgets/table/e-table-model.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/widgets/table/e-table-model.c b/widgets/table/e-table-model.c index d9c0c4fd38..5138fb8edd 100644 --- a/widgets/table/e-table-model.c +++ b/widgets/table/e-table-model.c @@ -91,6 +91,30 @@ e_table_model_append_row (ETableModel *e_table_model, ETableModel *source, int r ETM_CLASS (e_table_model)->append_row (e_table_model, source, row); } +const char * +e_table_model_row_sort_group(ETableModel *e_table_model, int row) +{ + g_return_val_if_fail (e_table_model != NULL, "/"); + g_return_val_if_fail (E_IS_TABLE_MODEL (e_table_model), "/"); + + if (ETM_CLASS (e_table_model)->row_sort_group) + return ETM_CLASS (e_table_model)->row_sort_group (e_table_model, row); + else + return "/"; +} + +gboolean +e_table_model_has_sort_group(ETableModel *e_table_model) +{ + g_return_val_if_fail (e_table_model != NULL, FALSE); + g_return_val_if_fail (E_IS_TABLE_MODEL (e_table_model), FALSE); + + if (ETM_CLASS (e_table_model)->has_sort_group) + return ETM_CLASS (e_table_model)->has_sort_group (e_table_model); + else + return FALSE; +} + void * e_table_model_duplicate_value (ETableModel *e_table_model, int col, const void *value) { @@ -221,6 +245,9 @@ e_table_model_class_init (GtkObjectClass *object_class) klass->is_cell_editable = NULL; klass->append_row = NULL; + klass->row_sort_group = NULL; + klass->has_sort_group = NULL; + klass->duplicate_value = NULL; klass->free_value = NULL; klass->initialize_value = NULL; |