mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-15 14:50:06 +00:00
window: Inline gtk_window_configure() into only caller
And remove the prototype from gtkwindowprivate.h
This commit is contained in:
parent
ec594f80dc
commit
018efdb8eb
@ -4700,67 +4700,6 @@ gtk_window_size_allocate (GtkWidget *widget,
|
|||||||
gtk_tooltip_maybe_allocate (GTK_NATIVE (widget));
|
gtk_tooltip_maybe_allocate (GTK_NATIVE (widget));
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
|
||||||
gtk_window_configure (GtkWindow *window,
|
|
||||||
guint width,
|
|
||||||
guint height)
|
|
||||||
{
|
|
||||||
GtkAllocation allocation;
|
|
||||||
GtkWidget *widget = GTK_WIDGET (window);
|
|
||||||
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
|
|
||||||
|
|
||||||
check_scale_changed (window);
|
|
||||||
|
|
||||||
/* If this is a gratuitous ConfigureNotify that's already
|
|
||||||
* the same as our allocation, then we can fizzle it out.
|
|
||||||
* This is the case for dragging windows around.
|
|
||||||
*
|
|
||||||
* We can't do this for a ConfigureRequest, since it might
|
|
||||||
* have been a queued resize from child widgets, and so we
|
|
||||||
* need to reallocate our children in case *they* changed.
|
|
||||||
*/
|
|
||||||
gtk_widget_get_allocation (widget, &allocation);
|
|
||||||
if (priv->configure_request_count == 0 &&
|
|
||||||
(allocation.width == width && allocation.height == height))
|
|
||||||
{
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* priv->configure_request_count incremented for each
|
|
||||||
* configure request, and decremented to a min of 0 for
|
|
||||||
* each configure notify.
|
|
||||||
*
|
|
||||||
* All it means is that we know we will get at least
|
|
||||||
* priv->configure_request_count more configure notifies.
|
|
||||||
* We could get more configure notifies than that; some
|
|
||||||
* of the configure notifies we get may be unrelated to
|
|
||||||
* the configure requests. But we will get at least
|
|
||||||
* priv->configure_request_count notifies.
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (priv->configure_request_count > 0)
|
|
||||||
{
|
|
||||||
priv->configure_request_count -= 1;
|
|
||||||
|
|
||||||
gdk_surface_thaw_toplevel_updates (priv->surface);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If we do need to resize, we do that by:
|
|
||||||
* - setting configure_notify_received to TRUE
|
|
||||||
* for use in gtk_window_move_resize()
|
|
||||||
* - queueing a resize, leading to invocation of
|
|
||||||
* gtk_window_move_resize() in an idle handler
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
priv->configure_notify_received = TRUE;
|
|
||||||
|
|
||||||
gtk_widget_queue_allocate (widget);
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
update_edge_constraints (GtkWindow *window,
|
update_edge_constraints (GtkWindow *window,
|
||||||
GdkSurfaceState state)
|
GdkSurfaceState state)
|
||||||
@ -4832,7 +4771,40 @@ surface_size_changed (GtkWidget *widget,
|
|||||||
int width,
|
int width,
|
||||||
int height)
|
int height)
|
||||||
{
|
{
|
||||||
gtk_window_configure (GTK_WINDOW (widget), width, height);
|
GtkWindowPrivate *priv = gtk_window_get_instance_private (GTK_WINDOW (widget));
|
||||||
|
|
||||||
|
check_scale_changed (GTK_WINDOW (widget));
|
||||||
|
|
||||||
|
/* priv->configure_request_count incremented for each
|
||||||
|
* configure request, and decremented to a min of 0 for
|
||||||
|
* each configure notify.
|
||||||
|
*
|
||||||
|
* All it means is that we know we will get at least
|
||||||
|
* priv->configure_request_count more configure notifies.
|
||||||
|
* We could get more configure notifies than that; some
|
||||||
|
* of the configure notifies we get may be unrelated to
|
||||||
|
* the configure requests. But we will get at least
|
||||||
|
* priv->configure_request_count notifies.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (priv->configure_request_count > 0)
|
||||||
|
{
|
||||||
|
priv->configure_request_count -= 1;
|
||||||
|
|
||||||
|
gdk_surface_thaw_toplevel_updates (priv->surface);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we do need to resize, we do that by:
|
||||||
|
* - setting configure_notify_received to TRUE
|
||||||
|
* for use in gtk_window_move_resize()
|
||||||
|
* - queueing a resize, leading to invocation of
|
||||||
|
* gtk_window_move_resize() in an idle handler
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
priv->configure_notify_received = TRUE;
|
||||||
|
|
||||||
|
gtk_widget_queue_allocate (widget);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -59,9 +59,6 @@ typedef void (*GtkWindowKeysForeachFunc) (GtkWindow *window,
|
|||||||
gpointer data);
|
gpointer data);
|
||||||
|
|
||||||
gboolean gtk_window_emit_close_request (GtkWindow *window);
|
gboolean gtk_window_emit_close_request (GtkWindow *window);
|
||||||
gboolean gtk_window_configure (GtkWindow *window,
|
|
||||||
guint width,
|
|
||||||
guint height);
|
|
||||||
|
|
||||||
/* --- internal (GtkAcceleratable) --- */
|
/* --- internal (GtkAcceleratable) --- */
|
||||||
void _gtk_window_schedule_mnemonics_visible (GtkWindow *window);
|
void _gtk_window_schedule_mnemonics_visible (GtkWindow *window);
|
||||||
|
Loading…
Reference in New Issue
Block a user