summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2020-05-05 22:11:55 -0400
committerMatthias Clasen <mclasen@redhat.com>2020-05-05 22:11:55 -0400
commit07959e50ad96281c44e0f0491120703d8087488f (patch)
treeadf1712be226ef3db76cc0aa14f2dd9a23a98d65
parentb72de7e067309f995fe1fc3cabdb66b2a16779e4 (diff)
downloadgtk+-tooltip-window-allocate.tar.gz
tooltipwindow: Stop using the ::size-allocate signaltooltip-window-allocate
Instead of connecting to ::size-allocate, call gtk_native_set_tooltip and rely on the native to allocate the tooltip window.
-rw-r--r--gtk/gtktooltipwindow.c24
1 files changed, 3 insertions, 21 deletions
diff --git a/gtk/gtktooltipwindow.c b/gtk/gtktooltipwindow.c
index 9ab1bbe698..21889e1d66 100644
--- a/gtk/gtktooltipwindow.c
+++ b/gtk/gtktooltipwindow.c
@@ -355,12 +355,6 @@ gtk_tooltip_window_hide (GtkWidget *widget)
gtk_widget_unmap (widget);
}
-static void size_changed (GtkWidget *widget,
- int width,
- int height,
- int baseline,
- GtkTooltipWindow *window);
-
static void
gtk_tooltip_window_dispose (GObject *object)
{
@@ -368,7 +362,7 @@ gtk_tooltip_window_dispose (GObject *object)
if (window->relative_to)
{
- g_signal_handlers_disconnect_by_func (window->relative_to, size_changed, window);
+ gtk_native_set_tooltip (GTK_NATIVE (window->relative_to), NULL);
gtk_widget_unparent (GTK_WIDGET (window));
}
@@ -523,16 +517,6 @@ gtk_tooltip_window_set_custom_widget (GtkTooltipWindow *window,
}
}
-static void
-size_changed (GtkWidget *widget,
- int width,
- int height,
- int baseline,
- GtkTooltipWindow *window)
-{
- gtk_native_check_resize (GTK_NATIVE (window));
-}
-
void
gtk_tooltip_window_set_relative_to (GtkTooltipWindow *window,
GtkWidget *relative_to)
@@ -546,7 +530,7 @@ gtk_tooltip_window_set_relative_to (GtkTooltipWindow *window,
if (window->relative_to)
{
- g_signal_handlers_disconnect_by_func (window->relative_to, size_changed, window);
+ gtk_native_set_tooltip (GTK_NATIVE (window->relative_to), NULL);
gtk_widget_unparent (GTK_WIDGET (window));
}
@@ -554,9 +538,7 @@ gtk_tooltip_window_set_relative_to (GtkTooltipWindow *window,
if (window->relative_to)
{
- g_signal_connect (window->relative_to, "size-allocate", G_CALLBACK (size_changed), window);
- gtk_css_node_set_parent (gtk_widget_get_css_node (GTK_WIDGET (window)),
- gtk_widget_get_css_node (relative_to));
+ gtk_native_set_tooltip (GTK_NATIVE (relative_to), GTK_NATIVE (window));
gtk_widget_set_parent (GTK_WIDGET (window), relative_to);
}