summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--gtk/gtktooltip.c23
2 files changed, 28 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index af16c666a5..6d6ec01d9b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2007-12-17 Kristian Rietveld <kris@imendio.com>
+ * gtk/gtktooltip.c (gtk_tooltip_finalize),
+ (gtk_tooltip_set_last_window): use a weak pointer to set last_window
+ to NULL as soon as it's destroyed. (#496546, patch from
+ Benjamin Berg).
+
+2007-12-17 Kristian Rietveld <kris@imendio.com>
+
* gtk/gtktreeviewcolumn.c (gtk_tree_view_column_update_button):
always determine what arrow to show if show_sort_indicator is true.
(#352738, Chris Vine).
diff --git a/gtk/gtktooltip.c b/gtk/gtktooltip.c
index 762840374b..53de9cfa73 100644
--- a/gtk/gtktooltip.c
+++ b/gtk/gtktooltip.c
@@ -92,6 +92,8 @@ static void gtk_tooltip_window_hide (GtkWidget *widget,
static void gtk_tooltip_display_closed (GdkDisplay *display,
gboolean was_error,
GtkTooltip *tooltip);
+static void gtk_tooltip_set_last_window (GtkTooltip *tooltip,
+ GdkWindow *window);
G_DEFINE_TYPE (GtkTooltip, gtk_tooltip, G_TYPE_OBJECT);
@@ -179,6 +181,8 @@ gtk_tooltip_finalize (GObject *object)
tooltip->browse_mode_timeout_id = 0;
}
+ gtk_tooltip_set_last_window (tooltip, NULL);
+
if (tooltip->window)
{
GdkDisplay *display;
@@ -734,6 +738,21 @@ gtk_tooltip_display_closed (GdkDisplay *display,
g_object_set_data (G_OBJECT (display), "gdk-display-current-tooltip", NULL);
}
+static void
+gtk_tooltip_set_last_window (GtkTooltip *tooltip,
+ GdkWindow *window)
+{
+ if (tooltip->last_window)
+ g_object_remove_weak_pointer (G_OBJECT (tooltip->last_window),
+ (gpointer *) &tooltip->last_window);
+
+ tooltip->last_window = window;
+
+ if (window)
+ g_object_add_weak_pointer (G_OBJECT (tooltip->last_window),
+ (gpointer *) &tooltip->last_window);
+}
+
static gboolean
gtk_tooltip_run_requery (GtkWidget **widget,
GtkTooltip *tooltip,
@@ -1190,7 +1209,7 @@ _gtk_tooltip_handle_event (GdkEvent *event)
if (current_tooltip)
{
- current_tooltip->last_window = event->any.window;
+ gtk_tooltip_set_last_window (current_tooltip, event->any.window);
gdk_event_get_root_coords (event,
&current_tooltip->last_x,
&current_tooltip->last_y);
@@ -1298,7 +1317,7 @@ _gtk_tooltip_handle_event (GdkEvent *event)
G_CALLBACK (gtk_tooltip_display_closed),
current_tooltip);
- current_tooltip->last_window = event->any.window;
+ gtk_tooltip_set_last_window (current_tooltip, event->any.window);
gdk_event_get_root_coords (event,
&current_tooltip->last_x,
&current_tooltip->last_y);