diff options
author | Jonathan Blandford <jrb@redhat.com> | 2000-11-18 23:59:30 +0000 |
---|---|---|
committer | Jonathan Blandford <jrb@src.gnome.org> | 2000-11-18 23:59:30 +0000 |
commit | c9e39436b9cae1c03fb15242116798550a44b66e (patch) | |
tree | 04471c79ad93c6c7ec5486fee393ba144b0d6cc6 /demos | |
parent | 14ec95efb42c28947caa74894bf5049c474dd846 (diff) | |
download | gtk+-c9e39436b9cae1c03fb15242116798550a44b66e.tar.gz |
Changed to have the list become non-italic when the demo window is
Sat Nov 18 18:00:17 2000 Jonathan Blandford <jrb@redhat.com>
* demos/gtk-demo/main.c: Changed to have the list become
non-italic when the demo window is destroyed through an external
event (like a close button). Doing so found three bugs in the
widget.
* demos/gtk-demo/*.c (do_*): Changed to return the toplevel window.
* gtk/gtkliststore.c (gtk_list_store_set_cell): emit "change" when
we actually set the cell.
* gtk/gtktreestore.c (gtk_tree_store_set_cell): ditto
* gtk/gtktreeselection.c (gtk_tree_selection_real_select_node):
free a leaked path. Thanks memprof.
Diffstat (limited to 'demos')
-rw-r--r-- | demos/gtk-demo/button_box.c | 13 | ||||
-rwxr-xr-x | demos/gtk-demo/geninclude.pl | 6 | ||||
-rwxr-xr-x | demos/gtk-demo/geninclude.pl.in | 6 | ||||
-rw-r--r-- | demos/gtk-demo/item_factory.c | 9 | ||||
-rw-r--r-- | demos/gtk-demo/main.c | 50 | ||||
-rw-r--r-- | demos/gtk-demo/menus.c | 13 | ||||
-rw-r--r-- | demos/gtk-demo/panes.c | 13 | ||||
-rw-r--r-- | demos/gtk-demo/textview.c | 15 |
8 files changed, 103 insertions, 22 deletions
diff --git a/demos/gtk-demo/button_box.c b/demos/gtk-demo/button_box.c index 432bfbbfc6..6291375d2e 100644 --- a/demos/gtk-demo/button_box.c +++ b/demos/gtk-demo/button_box.c @@ -43,7 +43,7 @@ create_bbox (gint horizontal, return frame; } -void +GtkWidget * do_button_box (void) { static GtkWidget* window = NULL; @@ -115,8 +115,15 @@ do_button_box (void) } if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show_all (window); + { + gtk_widget_show_all (window); + } else - gtk_widget_destroy (window); + { + gtk_widget_destroy (window); + window = NULL; + } + + return window; } diff --git a/demos/gtk-demo/geninclude.pl b/demos/gtk-demo/geninclude.pl index 31036cc399..df534bc46d 100755 --- a/demos/gtk-demo/geninclude.pl +++ b/demos/gtk-demo/geninclude.pl @@ -1,13 +1,15 @@ #!/usr/bin/perl -w print <<EOT; +typedef GtkWidget *(*GDoDemoFunc) (void); + typedef struct _Demo Demo; struct _Demo { gchar *title; gchar *filename; - void (*func) (void); + GDoDemoFunc func; }; EOT @@ -31,7 +33,7 @@ for $file (@ARGV) { close INFO_FILE; - print "void do_$basename (void);\n"; + print "GtkWidget *do_$basename (void);\n"; $array .= qq( { "$title", "$file", do_$basename }); } diff --git a/demos/gtk-demo/geninclude.pl.in b/demos/gtk-demo/geninclude.pl.in index 31036cc399..df534bc46d 100755 --- a/demos/gtk-demo/geninclude.pl.in +++ b/demos/gtk-demo/geninclude.pl.in @@ -1,13 +1,15 @@ #!/usr/bin/perl -w print <<EOT; +typedef GtkWidget *(*GDoDemoFunc) (void); + typedef struct _Demo Demo; struct _Demo { gchar *title; gchar *filename; - void (*func) (void); + GDoDemoFunc func; }; EOT @@ -31,7 +33,7 @@ for $file (@ARGV) { close INFO_FILE; - print "void do_$basename (void);\n"; + print "GtkWidget *do_$basename (void);\n"; $array .= qq( { "$title", "$file", do_$basename }); } diff --git a/demos/gtk-demo/item_factory.c b/demos/gtk-demo/item_factory.c index 4e808f9da9..32f13ea067 100644 --- a/demos/gtk-demo/item_factory.c +++ b/demos/gtk-demo/item_factory.c @@ -41,7 +41,7 @@ static GtkItemFactoryEntry menu_items[] = static int nmenu_items = sizeof (menu_items) / sizeof (menu_items[0]); -void +GtkWidget * do_item_factory (void) { static GtkWidget *window = NULL; @@ -114,5 +114,10 @@ do_item_factory (void) gtk_widget_show_all (window); } else - gtk_widget_destroy (window); + { + gtk_widget_destroy (window); + window = NULL; + } + + return window; } diff --git a/demos/gtk-demo/main.c b/demos/gtk-demo/main.c index 227b2bfa7f..f86cd122e9 100644 --- a/demos/gtk-demo/main.c +++ b/demos/gtk-demo/main.c @@ -20,6 +20,33 @@ enum { NUM_COLUMNS }; +typedef struct _CallbackData CallbackData; +struct _CallbackData +{ + GtkTreeModel *model; + GtkTreePath *path; +}; + +static void +window_closed_cb (GtkWidget *window, gpointer data) +{ + CallbackData *cbdata = data; + GtkTreeIter iter; + gboolean italic; + + gtk_tree_model_get_iter (cbdata->model, &iter, cbdata->path); + gtk_tree_store_get (GTK_TREE_STORE (cbdata->model), &iter, + ITALIC_COLUMN, &italic, + -1); + if (italic) + gtk_tree_store_set (GTK_TREE_STORE (cbdata->model), &iter, + ITALIC_COLUMN, !italic, + -1); + + gtk_tree_path_free (cbdata->path); + g_free (cbdata); +} + gboolean read_line (FILE *stream, GString *str) { @@ -224,7 +251,8 @@ button_press_event_cb (GtkTreeView *tree_view, { GtkTreeIter iter; gboolean italic; - GVoidFunc func; + GDoDemoFunc func; + GtkWidget *window; gtk_tree_model_get_iter (model, &iter, path); gtk_tree_store_get (GTK_TREE_STORE (model), @@ -232,12 +260,28 @@ button_press_event_cb (GtkTreeView *tree_view, FUNC_COLUMN, &func, ITALIC_COLUMN, &italic, -1); - (func) (); gtk_tree_store_set (GTK_TREE_STORE (model), &iter, ITALIC_COLUMN, !italic, -1); - gtk_tree_path_free (path); + window = (func) (); + if (window != NULL) + { + CallbackData *cbdata; + + cbdata = g_new (CallbackData, 1); + cbdata->model = model; + cbdata->path = path; + + gtk_signal_connect (GTK_OBJECT (window), + "destroy", + window_closed_cb, + cbdata); + } + else + { + gtk_tree_path_free (path); + } } gtk_signal_emit_stop_by_name (GTK_OBJECT (tree_view), diff --git a/demos/gtk-demo/menus.c b/demos/gtk-demo/menus.c index 03ce18d1bd..95ddb10e1a 100644 --- a/demos/gtk-demo/menus.c +++ b/demos/gtk-demo/menus.c @@ -52,7 +52,7 @@ create_menu (gint depth, gboolean tearoff) return menu; } -void +GtkWidget * do_menus (void) { static GtkWidget *window = NULL; @@ -180,8 +180,15 @@ do_menus (void) } if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); + { + gtk_widget_show (window); + } else - gtk_widget_destroy (window); + { + gtk_widget_destroy (window); + window = NULL; + } + + return window; } diff --git a/demos/gtk-demo/panes.c b/demos/gtk-demo/panes.c index 718f8969bc..0bb1bd5e5f 100644 --- a/demos/gtk-demo/panes.c +++ b/demos/gtk-demo/panes.c @@ -113,7 +113,7 @@ create_pane_options (GtkPaned *paned, return frame; } -void +GtkWidget * do_panes (void) { static GtkWidget *window = NULL; @@ -182,7 +182,14 @@ do_panes (void) } if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); + { + gtk_widget_show (window); + } else - gtk_widget_destroy (window); + { + gtk_widget_destroy (window); + window = NULL; + } + + return window; } diff --git a/demos/gtk-demo/textview.c b/demos/gtk-demo/textview.c index dc6ad428d4..a6f6b2206d 100644 --- a/demos/gtk-demo/textview.c +++ b/demos/gtk-demo/textview.c @@ -163,7 +163,7 @@ insert_text (GtkTextBuffer *buffer) GtkTextIter start, end; GdkPixbuf *pixbuf; - pixbuf = gdk_pixbuf_new_from_xpm_data (book_closed_xpm); + pixbuf = gdk_pixbuf_new_from_xpm_data ((const char **) book_closed_xpm); /* get start of buffer; each insertion will revalidate the * iterator to point to just after the inserted text. @@ -282,7 +282,7 @@ insert_text (GtkTextBuffer *buffer) g_object_unref (G_OBJECT (pixbuf)); } -void +GtkWidget * do_textview (void) { static GtkWidget *window = NULL; @@ -342,8 +342,15 @@ do_textview (void) } if (!GTK_WIDGET_VISIBLE (window)) - gtk_widget_show (window); + { + gtk_widget_show (window); + } else - gtk_widget_destroy (window); + { + gtk_widget_destroy (window); + window = NULL; + } + + return window; } |