2000-10-11 Christopher James Lahey <clahey@helixcode.com> * tests/test-tree-1.c, tests/test-tree-2.c, tests/test-tree-3.c: Changed these to match the new ETable system. * gal/Makefile.am: Added e-table-column-specification.lo, e-table-extras.lo, e-table-specification.lo, and e-table-state.lo. From gal/e-table/ChangeLog: 2000-10-11 Christopher James Lahey <clahey@helixcode.com> * Makefile.am: Added e-table-column-specification.c, e-table-column-specification.h, e-table-extras.c, e-table-extras.h, e-table-specification.c, e-table-specification.h, e-table-state.c, and e-table-state.h. Removed some duplicated .h files. * e-cell-tree.c: Ref, sink, and unref the subcell instead of destroying it when done. * e-table-column-specification.c, e-table-column-specification.h: New class which describes a column without having a table get instantiated. * e-table-config.c: Changed get_specification to get_state to get this to compile. * e-table-defines.h, e-table-item.h: Moved the definition of ETableCursorMode from e-table-item.h to e-table-defines.h. * e-table-extras.c, e-table-extras.h: New class which acts as a set of 3 hash tables. All from char * and to alternately, ECells, GCompareFuncs, and GdkPxibufs. * e-table-scrolled.c, e-table-scrolled.h: Changed this to match the new ETable function declarations. * e-table-sort-info.c, e-table-sort-info.h: Added functions for saving to and loading from xml. * e-table-specification.c, e-table-specification.h: New class which describes a table without having to instantiate it. * e-table-state.c, e-table-state.h: New class which describes the state of a table without having to instantiate the table. * e-table.c, e-table.h: Changed this to accept both a state and a specification instead of just a specification. You then save only the state. The specification stays exactly the same. Also, you no longer need to pass in an ETableHeader. Most of the information contained in the ETableHeader are in the specification. However you may need to translate some of the strings in the specification to objects. If you need anything other than the builtin choices, you need to create an ETableExtras and pass it in. * e-tree-model.c: Removed an unused variable. svn path=/trunk/; revision=5837
74 lines
2.6 KiB
C
74 lines
2.6 KiB
C
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
|
|
#ifndef _E_TABLE_SORT_INFO_H_
|
|
#define _E_TABLE_SORT_INFO_H_
|
|
|
|
#include <gtk/gtkobject.h>
|
|
#include <gnome-xml/tree.h>
|
|
|
|
#define E_TABLE_SORT_INFO_TYPE (e_table_sort_info_get_type ())
|
|
#define E_TABLE_SORT_INFO(o) (GTK_CHECK_CAST ((o), E_TABLE_SORT_INFO_TYPE, ETableSortInfo))
|
|
#define E_TABLE_SORT_INFO_CLASS(k) (GTK_CHECK_CLASS_CAST((k), E_TABLE_SORT_INFO_TYPE, ETableSortInfoClass))
|
|
#define E_IS_TABLE_SORT_INFO(o) (GTK_CHECK_TYPE ((o), E_TABLE_SORT_INFO_TYPE))
|
|
#define E_IS_TABLE_SORT_INFO_CLASS(k) (GTK_CHECK_CLASS_TYPE ((k), E_TABLE_SORT_INFO_TYPE))
|
|
|
|
typedef struct _ETableSortColumn ETableSortColumn;
|
|
|
|
struct _ETableSortColumn {
|
|
guint column : 31;
|
|
guint ascending : 1;
|
|
};
|
|
|
|
typedef struct {
|
|
GtkObject base;
|
|
|
|
gint group_count;
|
|
ETableSortColumn *groupings;
|
|
gint sort_count;
|
|
ETableSortColumn *sortings;
|
|
|
|
guint frozen : 1;
|
|
guint sort_info_changed : 1;
|
|
guint group_info_changed : 1;
|
|
} ETableSortInfo;
|
|
|
|
typedef struct {
|
|
GtkObjectClass parent_class;
|
|
|
|
/*
|
|
* Signals
|
|
*/
|
|
void (*sort_info_changed) (ETableSortInfo *info);
|
|
void (*group_info_changed) (ETableSortInfo *info);
|
|
} ETableSortInfoClass;
|
|
|
|
GtkType e_table_sort_info_get_type (void);
|
|
|
|
void e_table_sort_info_freeze (ETableSortInfo *info);
|
|
void e_table_sort_info_thaw (ETableSortInfo *info);
|
|
|
|
guint e_table_sort_info_grouping_get_count (ETableSortInfo *info);
|
|
void e_table_sort_info_grouping_truncate (ETableSortInfo *info,
|
|
int length);
|
|
ETableSortColumn e_table_sort_info_grouping_get_nth (ETableSortInfo *info,
|
|
int n);
|
|
void e_table_sort_info_grouping_set_nth (ETableSortInfo *info,
|
|
int n,
|
|
ETableSortColumn column);
|
|
|
|
guint e_table_sort_info_sorting_get_count (ETableSortInfo *info);
|
|
void e_table_sort_info_sorting_truncate (ETableSortInfo *info,
|
|
int length);
|
|
ETableSortColumn e_table_sort_info_sorting_get_nth (ETableSortInfo *info,
|
|
int n);
|
|
void e_table_sort_info_sorting_set_nth (ETableSortInfo *info,
|
|
int n,
|
|
ETableSortColumn column);
|
|
|
|
ETableSortInfo *e_table_sort_info_new (void);
|
|
void e_table_sort_info_load_from_node (ETableSortInfo *info,
|
|
xmlNode *node);
|
|
xmlNode *e_table_sort_info_save_to_node (ETableSortInfo *info,
|
|
xmlNode *parent);
|
|
|
|
#endif /* _E_TABLE_SORT_INFO_H_ */
|