From f5c77df86c35de318a791c5a94eff1a0fbfe94d2 Mon Sep 17 00:00:00 2001 From: Georges Basile Stavracas Neto Date: Sat, 27 Jun 2020 22:18:45 -0300 Subject: [PATCH] clutter/offscreen-effect: Unref framebuffer on pre_paint Move unreffing the framebuffer to ClutterOffscreenEffect.pre_paint(). This will allow us to properly chain up ClutterOffscreenEffect.paint() and not reimplement exactly what ClutterEffect does by default. https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1474 --- clutter/clutter/clutter-offscreen-effect.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/clutter/clutter/clutter-offscreen-effect.c b/clutter/clutter/clutter-offscreen-effect.c index 129d7e6f4..d194787b7 100644 --- a/clutter/clutter/clutter-offscreen-effect.c +++ b/clutter/clutter/clutter-offscreen-effect.c @@ -272,10 +272,10 @@ clutter_offscreen_effect_pre_paint (ClutterEffect *effect, local_offset = GRAPHENE_POINT3D_INIT (0.0f, 0.0f, 0.0f); if (!clutter_actor_meta_get_enabled (CLUTTER_ACTOR_META (effect))) - return FALSE; + goto disable_effect; if (priv->actor == NULL) - return FALSE; + goto disable_effect; stage = _clutter_actor_get_stage_internal (priv->actor); clutter_actor_get_size (stage, &stage_width, &stage_height); @@ -320,7 +320,7 @@ clutter_offscreen_effect_pre_paint (ClutterEffect *effect, /* First assert that the framebuffer is the right size... */ if (!update_fbo (effect, target_width, target_height, resource_scale)) - return FALSE; + goto disable_effect; framebuffer = clutter_paint_context_get_framebuffer (paint_context); cogl_framebuffer_get_modelview_matrix (framebuffer, &old_modelview); @@ -387,6 +387,10 @@ clutter_offscreen_effect_pre_paint (ClutterEffect *effect, clutter_actor_set_opacity_override (priv->actor, 0xff); return TRUE; + +disable_effect: + cogl_clear_object (&priv->offscreen); + return FALSE; } static void @@ -510,8 +514,6 @@ clutter_offscreen_effect_paint (ClutterEffect *effect, if (pre_paint_succeeded) effect_class->post_paint (effect, paint_context); - else - g_clear_pointer (&priv->offscreen, cogl_object_unref); } else clutter_offscreen_effect_paint_texture (self, paint_context);