summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Blandford <jrb@redhat.com>2000-11-18 23:59:30 +0000
committerJonathan Blandford <jrb@src.gnome.org>2000-11-18 23:59:30 +0000
commitc9e39436b9cae1c03fb15242116798550a44b66e (patch)
tree04471c79ad93c6c7ec5486fee393ba144b0d6cc6
parent14ec95efb42c28947caa74894bf5049c474dd846 (diff)
downloadgdk-pixbuf-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.
-rw-r--r--ChangeLog17
-rw-r--r--ChangeLog.pre-2-017
-rw-r--r--ChangeLog.pre-2-1017
-rw-r--r--ChangeLog.pre-2-217
-rw-r--r--ChangeLog.pre-2-417
-rw-r--r--ChangeLog.pre-2-617
-rw-r--r--ChangeLog.pre-2-817
-rw-r--r--demos/gtk-demo/button_box.c13
-rwxr-xr-xdemos/gtk-demo/geninclude.pl6
-rwxr-xr-xdemos/gtk-demo/geninclude.pl.in6
-rw-r--r--demos/gtk-demo/item_factory.c9
-rw-r--r--demos/gtk-demo/main.c50
-rw-r--r--demos/gtk-demo/menus.c13
-rw-r--r--demos/gtk-demo/panes.c13
-rw-r--r--demos/gtk-demo/textview.c15
-rw-r--r--gtk/gtkliststore.c3
-rw-r--r--gtk/gtktreeselection.c1
-rw-r--r--gtk/gtktreestore.c3
-rw-r--r--gtk/gtktreeview.c2
19 files changed, 230 insertions, 23 deletions
diff --git a/ChangeLog b/ChangeLog
index ebd096871..b529e70e1 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,20 @@
+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.
+
Sat Nov 18 11:58:17 2000 Owen Taylor <otaylor@redhat.com>
* gdk/gdkrgb.c (gdk_rgb_allocate_images): Fix
diff --git a/ChangeLog.pre-2-0 b/ChangeLog.pre-2-0
index ebd096871..b529e70e1 100644
--- a/ChangeLog.pre-2-0
+++ b/ChangeLog.pre-2-0
@@ -1,3 +1,20 @@
+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.
+
Sat Nov 18 11:58:17 2000 Owen Taylor <otaylor@redhat.com>
* gdk/gdkrgb.c (gdk_rgb_allocate_images): Fix
diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10
index ebd096871..b529e70e1 100644
--- a/ChangeLog.pre-2-10
+++ b/ChangeLog.pre-2-10
@@ -1,3 +1,20 @@
+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.
+
Sat Nov 18 11:58:17 2000 Owen Taylor <otaylor@redhat.com>
* gdk/gdkrgb.c (gdk_rgb_allocate_images): Fix
diff --git a/ChangeLog.pre-2-2 b/ChangeLog.pre-2-2
index ebd096871..b529e70e1 100644
--- a/ChangeLog.pre-2-2
+++ b/ChangeLog.pre-2-2
@@ -1,3 +1,20 @@
+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.
+
Sat Nov 18 11:58:17 2000 Owen Taylor <otaylor@redhat.com>
* gdk/gdkrgb.c (gdk_rgb_allocate_images): Fix
diff --git a/ChangeLog.pre-2-4 b/ChangeLog.pre-2-4
index ebd096871..b529e70e1 100644
--- a/ChangeLog.pre-2-4
+++ b/ChangeLog.pre-2-4
@@ -1,3 +1,20 @@
+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.
+
Sat Nov 18 11:58:17 2000 Owen Taylor <otaylor@redhat.com>
* gdk/gdkrgb.c (gdk_rgb_allocate_images): Fix
diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6
index ebd096871..b529e70e1 100644
--- a/ChangeLog.pre-2-6
+++ b/ChangeLog.pre-2-6
@@ -1,3 +1,20 @@
+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.
+
Sat Nov 18 11:58:17 2000 Owen Taylor <otaylor@redhat.com>
* gdk/gdkrgb.c (gdk_rgb_allocate_images): Fix
diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8
index ebd096871..b529e70e1 100644
--- a/ChangeLog.pre-2-8
+++ b/ChangeLog.pre-2-8
@@ -1,3 +1,20 @@
+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.
+
Sat Nov 18 11:58:17 2000 Owen Taylor <otaylor@redhat.com>
* gdk/gdkrgb.c (gdk_rgb_allocate_images): Fix
diff --git a/demos/gtk-demo/button_box.c b/demos/gtk-demo/button_box.c
index 432bfbbfc..6291375d2 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 31036cc39..df534bc46 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 31036cc39..df534bc46 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 4e808f9da..32f13ea06 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 227b2bfa7..f86cd122e 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 03ce18d1b..95ddb10e1 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 718f8969b..0bb1bd5e5 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 dc6ad428d..a6f6b2206 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;
}
diff --git a/gtk/gtkliststore.c b/gtk/gtkliststore.c
index fb23aadfb..063a844b5 100644
--- a/gtk/gtkliststore.c
+++ b/gtk/gtkliststore.c
@@ -442,6 +442,9 @@ gtk_list_store_set_cell (GtkListStore *list_store,
if (column == 0)
{
_gtk_tree_data_list_value_to_node (list, value);
+ gtk_signal_emit_by_name (GTK_OBJECT (list_store),
+ "changed",
+ NULL, iter);
return;
}
diff --git a/gtk/gtktreeselection.c b/gtk/gtktreeselection.c
index 706549ee3..4654a7de2 100644
--- a/gtk/gtktreeselection.c
+++ b/gtk/gtktreeselection.c
@@ -893,6 +893,7 @@ gtk_tree_selection_real_select_node (GtkTreeSelection *selection,
}
else
selected = TRUE;
+ gtk_tree_path_free (path);
}
if (selected == TRUE)
{
diff --git a/gtk/gtktreestore.c b/gtk/gtktreestore.c
index c85c251b8..b57de7082 100644
--- a/gtk/gtktreestore.c
+++ b/gtk/gtktreestore.c
@@ -502,6 +502,9 @@ gtk_tree_store_set_cell (GtkTreeStore *tree_store,
if (column == 0)
{
_gtk_tree_data_list_value_to_node (list, value);
+ gtk_signal_emit_by_name (GTK_OBJECT (tree_store),
+ "changed",
+ NULL, iter);
return;
}
diff --git a/gtk/gtktreeview.c b/gtk/gtktreeview.c
index de3d50472..e1122db48 100644
--- a/gtk/gtktreeview.c
+++ b/gtk/gtktreeview.c
@@ -1947,7 +1947,7 @@ gtk_tree_view_changed (GtkTreeModel *model,
else
{
/* FIXME: just redraw the node */
- gtk_widget_queue_resize (GTK_WIDGET (data));
+ gtk_widget_queue_draw (GTK_WIDGET (data));
}
}