wayland: Make synchronous subsurface a very special case in commit

Really, it is a special case. When the subsurface is synchronous,
commit changes meaning from being applied immediately to being
queued up for replay later. Handle this explicit special case
with an explicit special case in the code.

This means that in all other paths, we can unconditionally
apply the actor immediately.
This commit is contained in:
Jasper St. Pierre 2014-04-11 23:40:36 -07:00
parent dbe4fc0e45
commit e1b0c9c756

View File

@ -289,24 +289,6 @@ move_double_buffered_state (MetaWaylandDoubleBufferedState *from,
static void static void
subsurface_surface_commit (MetaWaylandSurface *surface, subsurface_surface_commit (MetaWaylandSurface *surface,
MetaWaylandDoubleBufferedState *pending) MetaWaylandDoubleBufferedState *pending)
{
/*
* If the sub-surface is in synchronous mode, post-pone the commit of its
* state until the sub-surface parent commits.
*
* This is done by moving the various states (damage, input region, buffer
* etc.) from the buffered state pending commit to the sub-surface's pending
* buffered state.
*
* The sub-surface's pending buffered state will be committed to the
* associated surface when its parent surface is committed, or if the user
* issues a wl_subsurface.set_desync request.
*/
if (surface->sub.synchronous)
{
move_double_buffered_state (pending, &surface->sub.pending_surface_state);
}
else
{ {
actor_surface_commit (surface, pending); actor_surface_commit (surface, pending);
@ -327,7 +309,6 @@ subsurface_surface_commit (MetaWaylandSurface *surface,
clutter_actor_set_position (CLUTTER_ACTOR (surface_actor), x, y); clutter_actor_set_position (CLUTTER_ACTOR (surface_actor), x, y);
} }
} }
}
static void static void
subsurface_parent_surface_committed (MetaWaylandSurface *surface); subsurface_parent_surface_committed (MetaWaylandSurface *surface);
@ -344,6 +325,18 @@ commit_double_buffered_state (MetaWaylandSurface *surface,
{ {
MetaWaylandCompositor *compositor = surface->compositor; MetaWaylandCompositor *compositor = surface->compositor;
/* If this surface is a subsurface in in synchronous mode, commit
* has a special-case and should not apply the pending state immediately.
*
* Instead, we move it to another pending state, which will be
* actually committed when the parent commits.
*/
if (surface->sub.synchronous)
{
move_double_buffered_state (pending, &surface->sub.pending_surface_state);
return;
}
if (pending->newly_attached) if (pending->newly_attached)
surface_set_buffer (surface, pending->buffer); surface_set_buffer (surface, pending->buffer);