summaryrefslogtreecommitdiff
path: root/tests/testtreesort.c
diff options
context:
space:
mode:
authorKristian Rietveld <kris@gtk.org>2006-01-24 10:49:29 +0000
committerKristian Rietveld <kristian@src.gnome.org>2006-01-24 10:49:29 +0000
commit58e77fe25bde289f178153a8a01e62d8b2e8093b (patch)
tree71ba038287f62706864023a51bc661f431fd2544 /tests/testtreesort.c
parent4c4ee382568f677b918fea8737f0d30dd69d61a2 (diff)
downloadgtk+-58e77fe25bde289f178153a8a01e62d8b2e8093b.tar.gz
#322591, Jonathan Blandford.
2006-01-24 Kristian Rietveld <kris@gtk.org> #322591, Jonathan Blandford. * gtk/gtktreeview.[ch] (gtk_tree_view_get_search_entry), (gtk_tree_view_set_search_entry), (gtk_tree_view_get_search_position_func), (gtk_tree_view_set_search_position_func): New functions, and small adaptions to the tree view code to allow for setting the entry and search position function. * gtk/gtktreeprivate.h: Removed GtkTreeViewSearchDialogPositionFunc typedef, which is now in gtktreeview.h as GtkTreeViewSearchPositionFunc. Add/update fields. * gtk/gtk.symbols: Add new functions. * tests/testtreesort.c: Add a little test for _set_search_entry().
Diffstat (limited to 'tests/testtreesort.c')
-rw-r--r--tests/testtreesort.c29
1 files changed, 28 insertions, 1 deletions
diff --git a/tests/testtreesort.c b/tests/testtreesort.c
index 622f678fb1..3b792c2d87 100644
--- a/tests/testtreesort.c
+++ b/tests/testtreesort.c
@@ -84,6 +84,19 @@ select_func (GtkTreeSelection *selection,
return FALSE;
}
+static void
+switch_search_method (GtkWidget *button,
+ gpointer tree_view)
+{
+ if (!gtk_tree_view_get_search_entry (GTK_TREE_VIEW (tree_view)))
+ {
+ gpointer data = g_object_get_data (tree_view, "my-search-entry");
+ gtk_tree_view_set_search_entry (GTK_TREE_VIEW (tree_view), GTK_ENTRY (data));
+ }
+ else
+ gtk_tree_view_set_search_entry (GTK_TREE_VIEW (tree_view), NULL);
+}
+
int
main (int argc, char *argv[])
{
@@ -99,6 +112,7 @@ main (int argc, char *argv[])
GtkTreeIter iter;
gint i;
+ GtkWidget *entry, *button;
GtkWidget *window2, *vbox2, *scrolled_window2, *tree_view2;
GtkWidget *window3, *vbox3, *scrolled_window3, *tree_view3;
@@ -116,6 +130,12 @@ main (int argc, char *argv[])
gtk_box_pack_start (GTK_BOX (vbox), gtk_label_new ("Jonathan and Kristian's list of cool words. (And Anders' cool list of numbers) \n\nThis is just a GtkTreeStore"), FALSE, FALSE, 0);
gtk_container_add (GTK_CONTAINER (window), vbox);
+ entry = gtk_entry_new ();
+ gtk_box_pack_start (GTK_BOX (vbox), entry, FALSE, FALSE, 0);
+
+ button = gtk_button_new_with_label ("Switch search method");
+ gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
+
scrolled_window = gtk_scrolled_window_new (NULL, NULL);
gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_window), GTK_SHADOW_ETCHED_IN);
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
@@ -128,7 +148,14 @@ main (int argc, char *argv[])
ssmodel = gtk_tree_model_sort_new_with_model (GTK_TREE_MODEL (smodel));
*/
tree_view = gtk_tree_view_new_with_model (GTK_TREE_MODEL (model));
- gtk_tree_selection_set_select_function (gtk_tree_view_get_selection (GTK_TREE_VIEW (tree_view)), select_func, NULL, NULL);
+
+ gtk_tree_view_set_search_entry (GTK_TREE_VIEW (tree_view), GTK_ENTRY (entry));
+ g_object_set_data (G_OBJECT (tree_view), "my-search-entry", entry);
+ g_signal_connect (button, "clicked",
+ G_CALLBACK (switch_search_method), tree_view);
+
+ /* gtk_tree_selection_set_select_function (gtk_tree_view_get_selection (GTK_TREE_VIEW (tree_view)), select_func, NULL, NULL);*/
+
/* 12 iters now, 12 later... */
for (i = 0; data[i].word_1 != NULL; i++)
{