From: Matthias Clasen Date: Thu, 21 May 2020 22:59:58 +0000 (-0400) Subject: tooltip: Avoid criticals X-Git-Tag: archive/raspbian/4.4.1+ds1-2+rpi1^2~18^2~16^2~131^2~3 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=af162b70c5a2dee25ae437c907d57746a7a6eb36;p=gtk4.git tooltip: Avoid criticals It is possible that the target widget is already unparented at the time that we call the tooltips handle_event function. Quietly return in that case, no need to emit a critical. --- diff --git a/gtk/gtktooltip.c b/gtk/gtktooltip.c index 36b162885b..4d10edf3e1 100644 --- a/gtk/gtktooltip.c +++ b/gtk/gtktooltip.c @@ -919,18 +919,21 @@ _gtk_tooltip_handle_event (GtkWidget *target, GdkSurface *surface; double x, y; double nx, ny; - GtkWidget *native; + GtkNative *native; if (!tooltips_enabled (event)) return; + native = gtk_widget_get_native (target); + if (!native) + return; + event_type = gdk_event_get_event_type (event); surface = gdk_event_get_surface (event); gdk_event_get_position (event, &x, &y); - native = GTK_WIDGET (gtk_widget_get_native (target)); - gtk_native_get_surface_transform (GTK_NATIVE (native), &nx, &ny); - gtk_widget_translate_coordinates (native, target, x - nx, y - ny, &x, &y); + gtk_native_get_surface_transform (native, &nx, &ny); + gtk_widget_translate_coordinates (GTK_WIDGET (native), target, x - nx, y - ny, &x, &y); gtk_tooltip_handle_event_internal (event_type, surface, target, x, y); }