[gnome-shell] Adapt to CoglFramebuffers turning into GObjects
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell] Adapt to CoglFramebuffers turning into GObjects
- Date: Fri, 16 Oct 2020 16:32:38 +0000 (UTC)
commit bd710ff4fd2c2cc3972919ae9b9a803d4e97ef1b
Author: Jonas Ã…dahl <jadahl gmail com>
Date: Tue Oct 13 15:51:22 2020 +0200
Adapt to CoglFramebuffers turning into GObjects
Requires some more explicit type casting as things turned into 'void *'
less. Also memory management changes, as we can't use CoglObject
functions anymore for these objects.
https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/1465
src/shell-blur-effect.c | 7 ++++---
src/st/st-private.c | 4 ++--
src/st/st-theme-node-drawing.c | 16 +++++++++-------
src/st/st-theme-node-transition.c | 12 ++++++------
4 files changed, 21 insertions(+), 18 deletions(-)
---
diff --git a/src/shell-blur-effect.c b/src/shell-blur-effect.c
index 7647e1530f..24cf971dba 100644
--- a/src/shell-blur-effect.c
+++ b/src/shell-blur-effect.c
@@ -351,7 +351,7 @@ update_fbo (FramebufferData *data,
clutter_backend_get_cogl_context (clutter_get_default_backend ());
g_clear_pointer (&data->texture, cogl_object_unref);
- g_clear_pointer (&data->framebuffer, cogl_object_unref);
+ g_clear_object (&data->framebuffer);
float new_width = floorf (width / downscale_factor);
float new_height = floorf (height / downscale_factor);
@@ -362,7 +362,8 @@ update_fbo (FramebufferData *data,
cogl_pipeline_set_layer_texture (data->pipeline, 0, data->texture);
- data->framebuffer = cogl_offscreen_new_with_texture (data->texture);
+ data->framebuffer =
+ COGL_FRAMEBUFFER (cogl_offscreen_new_with_texture (data->texture));
if (!data->framebuffer)
{
g_warning ("%s: Unable to create an Offscreen buffer", G_STRLOC);
@@ -451,7 +452,7 @@ static void
clear_framebuffer_data (FramebufferData *fb_data)
{
g_clear_pointer (&fb_data->texture, cogl_object_unref);
- g_clear_pointer (&fb_data->framebuffer, cogl_object_unref);
+ g_clear_object (&fb_data->framebuffer);
}
static float
diff --git a/src/st/st-private.c b/src/st/st-private.c
index 129c87f51e..65ad250452 100644
--- a/src/st/st-private.c
+++ b/src/st/st-private.c
@@ -501,7 +501,7 @@ _st_create_shadow_pipeline_from_actor (StShadow *shadow_spec,
if (!cogl_framebuffer_allocate (fb, &catch_error))
{
g_error_free (catch_error);
- cogl_object_unref (offscreen);
+ g_object_unref (offscreen);
cogl_object_unref (buffer);
return NULL;
}
@@ -526,7 +526,7 @@ _st_create_shadow_pipeline_from_actor (StShadow *shadow_spec,
clutter_actor_set_opacity_override (actor, -1);
- cogl_object_unref (fb);
+ g_object_unref (fb);
shadow_pipeline = _st_create_shadow_pipeline (shadow_spec, buffer,
resource_scale);
diff --git a/src/st/st-theme-node-drawing.c b/src/st/st-theme-node-drawing.c
index c5df5fc62d..1e00a06f37 100644
--- a/src/st/st-theme-node-drawing.c
+++ b/src/st/st-theme-node-drawing.c
@@ -2281,7 +2281,8 @@ st_theme_node_prerender_shadow (StThemeNodePaintState *state)
CoglContext *ctx;
int fb_width, fb_height;
CoglTexture *buffer;
- CoglFramebuffer *offscreen = NULL;
+ CoglOffscreen *offscreen = NULL;
+ CoglFramebuffer *framebuffer;
GError *error = NULL;
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
@@ -2294,26 +2295,27 @@ st_theme_node_prerender_shadow (StThemeNodePaintState *state)
return;
offscreen = cogl_offscreen_new_with_texture (buffer);
+ framebuffer = COGL_FRAMEBUFFER (offscreen);
- if (cogl_framebuffer_allocate (COGL_FRAMEBUFFER (offscreen), &error))
+ if (cogl_framebuffer_allocate (framebuffer, &error))
{
ClutterActorBox box = { 0, 0, state->box_shadow_width, state->box_shadow_height};
- cogl_framebuffer_orthographic (offscreen, 0, 0,
+ cogl_framebuffer_orthographic (framebuffer, 0, 0,
fb_width, fb_height, 0, 1.0);
- cogl_framebuffer_scale (offscreen,
+ cogl_framebuffer_scale (framebuffer,
state->resource_scale,
state->resource_scale, 1);
- cogl_framebuffer_clear4f (offscreen, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 0);
+ cogl_framebuffer_clear4f (framebuffer, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 0);
- st_theme_node_paint_borders (state, offscreen, &box, 0xFF);
+ st_theme_node_paint_borders (state, framebuffer, &box, 0xFF);
state->box_shadow_pipeline = _st_create_shadow_pipeline (st_theme_node_get_box_shadow (node),
buffer, state->resource_scale);
}
g_clear_error (&error);
- cogl_clear_object (&offscreen);
+ g_clear_object (&offscreen);
cogl_clear_object (&buffer);
}
diff --git a/src/st/st-theme-node-transition.c b/src/st/st-theme-node-transition.c
index b7366653d4..61199b437e 100644
--- a/src/st/st-theme-node-transition.c
+++ b/src/st/st-theme-node-transition.c
@@ -274,21 +274,21 @@ setup_framebuffers (StThemeNodeTransition *transition,
if (priv->new_texture == NULL)
return FALSE;
- cogl_clear_object (&priv->old_offscreen);
+ g_clear_object (&priv->old_offscreen);
priv->old_offscreen = COGL_FRAMEBUFFER (cogl_offscreen_new_with_texture (priv->old_texture));
if (!cogl_framebuffer_allocate (priv->old_offscreen, &catch_error))
{
g_error_free (catch_error);
- cogl_clear_object (&priv->old_offscreen);
+ g_clear_object (&priv->old_offscreen);
return FALSE;
}
- cogl_clear_object (&priv->new_offscreen);
+ g_clear_object (&priv->new_offscreen);
priv->new_offscreen = COGL_FRAMEBUFFER (cogl_offscreen_new_with_texture (priv->new_texture));
if (!cogl_framebuffer_allocate (priv->new_offscreen, &catch_error))
{
g_error_free (catch_error);
- cogl_clear_object (&priv->new_offscreen);
+ g_clear_object (&priv->new_offscreen);
return FALSE;
}
@@ -404,8 +404,8 @@ st_theme_node_transition_dispose (GObject *object)
cogl_clear_object (&priv->old_texture);
cogl_clear_object (&priv->new_texture);
- cogl_clear_object (&priv->old_offscreen);
- cogl_clear_object (&priv->new_offscreen);
+ g_clear_object (&priv->old_offscreen);
+ g_clear_object (&priv->new_offscreen);
cogl_clear_object (&priv->material);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]