diff options
author | Christopher James Lahey <clahey@ximian.com> | 2002-03-12 22:30:53 +0800 |
---|---|---|
committer | Chris Lahey <clahey@src.gnome.org> | 2002-03-12 22:30:53 +0800 |
commit | fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e (patch) | |
tree | efb6b0e9d933ad2989b62abb2b9f9c1e5e76ff34 /widgets/table/e-table-extras.c | |
parent | 8358586161bd2f1b17ea30f1a483e6b85dff8e47 (diff) | |
download | gsoc2013-evolution-fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e.tar gsoc2013-evolution-fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e.tar.gz gsoc2013-evolution-fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e.tar.bz2 gsoc2013-evolution-fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e.tar.lz gsoc2013-evolution-fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e.tar.xz gsoc2013-evolution-fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e.tar.zst gsoc2013-evolution-fd4ffbd38ccef4d2a35675a50f89e0b5f2d6d86e.zip |
Added e-table-search.lo.
2002-03-12 Christopher James Lahey <clahey@ximian.com>
* gal/Makefile.am (libgal_la_LIBADD): Added e-table-search.lo.
* gal/util/e-util.c, gal/util/e-util.h (e_marshal_BOOL__STRING):
Added this marshal function.
From gal/e-table/ChangeLog:
2002-03-12 Christopher James Lahey <clahey@ximian.com>
* Makefile.am (libetable_la_SOURCES): Added e-table-search.c.
(libetableinclude_HEADERS): Added e-table-search.h.
* e-cell.h: Added ETableSearchFun here.
* e-table-col.h: Added search here.
* e-table-column-specification.c, e-table-column-specification.h:
Added search here.
* e-table-extras.c, e-table-extras.h (e_table_extras_add_search):
Added ETableSearchFuncs here.
* e-table-memory-store.c (e_table_memory_store_insert,
e_table_memory_store_insert_adopt): Handle row == -1 here.
* e-table-search.c, e-table-search.h: New class to reusably handle
the semantics of searching for a string.
* e-table-simple.c, e-table-simple.h: Added a bunch of simple
functions here for if your table is all strings. Should be
reusable.
* e-table-utils.c (et_col_spec_to_col): Added support for searches
here.
* e-table.c, e-table.h: Added an ETableSearch here.
svn path=/trunk/; revision=16119
Diffstat (limited to 'widgets/table/e-table-extras.c')
-rw-r--r-- | widgets/table/e-table-extras.c | 44 |
1 files changed, 42 insertions, 2 deletions
diff --git a/widgets/table/e-table-extras.c b/widgets/table/e-table-extras.c index d5cb1191ad..9f80557901 100644 --- a/widgets/table/e-table-extras.c +++ b/widgets/table/e-table-extras.c @@ -33,6 +33,7 @@ #include "gal/e-table/e-cell-size.h" #include "gal/e-table/e-cell-tree.h" #include "e-table-extras.h" +#include <string.h> #define PARENT_TYPE (gtk_object_get_type()) @@ -65,14 +66,17 @@ ete_destroy (GtkObject *object) g_hash_table_foreach (ete->cells, (GHFunc) cell_hash_free, NULL); g_hash_table_foreach (ete->compares, (GHFunc) g_free, NULL); + g_hash_table_foreach (ete->searches, (GHFunc) g_free, NULL); g_hash_table_foreach (ete->pixbufs, (GHFunc) pixbuf_hash_free, NULL); g_hash_table_destroy (ete->cells); g_hash_table_destroy (ete->compares); + g_hash_table_destroy (ete->searches); g_hash_table_destroy (ete->pixbufs); ete->cells = NULL; ete->compares = NULL; + ete->searches = NULL; ete->pixbufs = NULL; GTK_OBJECT_CLASS (ete_parent_class)->destroy (object); @@ -95,17 +99,30 @@ e_strint_compare(gconstpointer data1, gconstpointer data2) return g_int_compare(GINT_TO_POINTER(int1), GINT_TO_POINTER(int2)); } +static gboolean +e_string_search(gconstpointer haystack, const char *needle) +{ + int length = g_utf8_strlen (needle, -1); + if (g_utf8_strncasecmp (haystack, needle, length) == 0) + return TRUE; + else + return FALSE; +} + static void ete_init (ETableExtras *extras) { extras->cells = g_hash_table_new(g_str_hash, g_str_equal); extras->compares = g_hash_table_new(g_str_hash, g_str_equal); + extras->searches = g_hash_table_new(g_str_hash, g_str_equal); extras->pixbufs = g_hash_table_new(g_str_hash, g_str_equal); e_table_extras_add_compare(extras, "string", g_str_compare); e_table_extras_add_compare(extras, "integer", g_int_compare); e_table_extras_add_compare(extras, "string-integer", e_strint_compare); + e_table_extras_add_search(extras, "string", e_string_search); + e_table_extras_add_cell(extras, "checkbox", e_cell_checkbox_new()); e_table_extras_add_cell(extras, "date", e_cell_date_new (NULL, GTK_JUSTIFY_LEFT)); e_table_extras_add_cell(extras, "number", e_cell_number_new (NULL, GTK_JUSTIFY_RIGHT)); @@ -162,8 +179,8 @@ e_table_extras_add_compare (ETableExtras *extras, gchar *old_key; GCompareFunc old_compare; - if (g_hash_table_lookup_extended (extras->cells, id, (gpointer *)&old_key, (gpointer *)&old_compare)) { - g_hash_table_remove (extras->cells, old_key); + if (g_hash_table_lookup_extended (extras->compares, id, (gpointer *)&old_key, (gpointer *)&old_compare)) { + g_hash_table_remove (extras->compares, old_key); g_free (old_key); } @@ -178,6 +195,29 @@ e_table_extras_get_compare (ETableExtras *extras, } void +e_table_extras_add_search (ETableExtras *extras, + char *id, + ETableSearchFunc search) +{ + gchar *old_key; + ETableSearchFunc old_search; + + if (g_hash_table_lookup_extended (extras->searches, id, (gpointer *)&old_key, (gpointer *)&old_search)) { + g_hash_table_remove (extras->searches, old_key); + g_free (old_key); + } + + g_hash_table_insert(extras->searches, g_strdup(id), search); +} + +ETableSearchFunc +e_table_extras_get_search (ETableExtras *extras, + char *id) +{ + return g_hash_table_lookup(extras->searches, id); +} + +void e_table_extras_add_pixbuf (ETableExtras *extras, char *id, GdkPixbuf *pixbuf) |