From: Benjamin Otte Date: Fri, 19 Nov 2021 20:58:09 +0000 (+0100) Subject: sizerequest: Add a critical when for_size is too small X-Git-Tag: archive/raspbian/4.6.5+ds-1+rpi1~1^2~19^2~5^2~125^2~9 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=163616cc0ada31ad667e8db7b22a6fa817021ebc;p=gtk4.git sizerequest: Add a critical when for_size is too small It's not expensive to check it because we'll cache the dfault size request anyway, and people do it wrong a lot. As a bonus, don't do any return_if_fail(), just use the min size instead. --- diff --git a/gtk/gtksizerequest.c b/gtk/gtksizerequest.c index a0f066b997..199bce2575 100644 --- a/gtk/gtksizerequest.c +++ b/gtk/gtksizerequest.c @@ -488,6 +488,18 @@ gtk_widget_measure (GtkWidget *widget, g_return_if_fail (orientation == GTK_ORIENTATION_HORIZONTAL || orientation == GTK_ORIENTATION_VERTICAL); + if (for_size >= 0) + { + int min_opposite_size; + gtk_widget_measure (widget, OPPOSITE_ORIENTATION (orientation), -1, &min_opposite_size, NULL, NULL, NULL); + if (for_size < min_opposite_size) + { + g_critical ("gtk_widget_measure: assertion 'for_size >= minimum opposite size' failed for %s %p: %u >= %u", + G_OBJECT_TYPE_NAME (widget), widget, for_size, min_opposite_size); + for_size = min_opposite_size; + } + } + /* This is the main function that checks for a cached size and * possibly queries the widget class to compute the size if it's * not cached.