mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-15 14:50:06 +00:00
gdk/surface: Try to reschedule pending phase until dispatched
If a surface scheduled a relayout, got frozen, and a layout phase happened, then got unfrozen, it wouldn't see it's layout being requested; avoid this race by remembering the pending phases until they actually happened.
This commit is contained in:
parent
880ceebae4
commit
e0f13ecae7
@ -1368,6 +1368,8 @@ gdk_surface_layout_on_clock (GdkFrameClock *clock,
|
|||||||
if (surface->update_freeze_count)
|
if (surface->update_freeze_count)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
surface->pending_phases &= ~GDK_FRAME_CLOCK_PHASE_LAYOUT;
|
||||||
|
|
||||||
class = GDK_SURFACE_GET_CLASS (surface);
|
class = GDK_SURFACE_GET_CLASS (surface);
|
||||||
if (class->compute_size)
|
if (class->compute_size)
|
||||||
class->compute_size (surface);
|
class->compute_size (surface);
|
||||||
@ -1420,6 +1422,7 @@ gdk_surface_paint_on_clock (GdkFrameClock *clock,
|
|||||||
* do the update later when idle instead. */
|
* do the update later when idle instead. */
|
||||||
!surface->in_update)
|
!surface->in_update)
|
||||||
{
|
{
|
||||||
|
surface->pending_phases &= ~GDK_FRAME_CLOCK_PHASE_PAINT;
|
||||||
gdk_surface_process_updates_internal (surface);
|
gdk_surface_process_updates_internal (surface);
|
||||||
gdk_surface_remove_update_surface (surface);
|
gdk_surface_remove_update_surface (surface);
|
||||||
}
|
}
|
||||||
@ -1602,10 +1605,7 @@ gdk_surface_thaw_updates (GdkSurface *surface)
|
|||||||
_gdk_frame_clock_inhibit_freeze (frame_clock);
|
_gdk_frame_clock_inhibit_freeze (frame_clock);
|
||||||
|
|
||||||
if (surface->pending_phases)
|
if (surface->pending_phases)
|
||||||
{
|
gdk_frame_clock_request_phase (frame_clock, surface->pending_phases);
|
||||||
gdk_frame_clock_request_phase (frame_clock, surface->pending_phases);
|
|
||||||
surface->pending_phases = 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user