mutter/src/wayland/meta-cursor-sprite-wayland.c
Carlos Garnacho 5e93708d86 wayland: Mark sprite as invalid after cursor changes
This will be used to hint the backend that the cursor surface
might need uploading again.

Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1915>
2021-12-07 20:04:08 +00:00

99 lines
2.5 KiB
C

/*
* Copyright 2015, 2018 Red Hat, Inc.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, see <http://www.gnu.org/licenses/>.
*
*/
#include "config.h"
#include "wayland/meta-cursor-sprite-wayland.h"
struct _MetaCursorSpriteWayland
{
MetaCursorSprite parent;
MetaWaylandSurface *surface;
gboolean invalidated;
};
G_DEFINE_TYPE (MetaCursorSpriteWayland,
meta_cursor_sprite_wayland,
META_TYPE_CURSOR_SPRITE)
static gboolean
meta_cursor_sprite_wayland_realize_texture (MetaCursorSprite *sprite)
{
MetaCursorSpriteWayland *sprite_wayland;
sprite_wayland = META_CURSOR_SPRITE_WAYLAND (sprite);
if (sprite_wayland->invalidated)
{
sprite_wayland->invalidated = FALSE;
return TRUE;
}
return FALSE;
}
static gboolean
meta_cursor_sprite_wayland_is_animated (MetaCursorSprite *sprite)
{
return FALSE;
}
static void
meta_cursor_sprite_wayland_invalidate (MetaCursorSprite *sprite)
{
MetaCursorSpriteWayland *sprite_wayland;
sprite_wayland = META_CURSOR_SPRITE_WAYLAND (sprite);
sprite_wayland->invalidated = TRUE;
}
MetaCursorSpriteWayland *
meta_cursor_sprite_wayland_new (MetaWaylandSurface *surface)
{
MetaCursorSpriteWayland *sprite_wayland;
sprite_wayland = g_object_new (META_TYPE_CURSOR_SPRITE_WAYLAND, NULL);
sprite_wayland->surface = surface;
return sprite_wayland;
}
MetaWaylandBuffer *
meta_cursor_sprite_wayland_get_buffer (MetaCursorSpriteWayland *sprite_wayland)
{
return meta_wayland_surface_get_buffer (sprite_wayland->surface);
}
static void
meta_cursor_sprite_wayland_init (MetaCursorSpriteWayland *sprite_wayland)
{
}
static void
meta_cursor_sprite_wayland_class_init (MetaCursorSpriteWaylandClass *klass)
{
MetaCursorSpriteClass *cursor_sprite_class = META_CURSOR_SPRITE_CLASS (klass);
cursor_sprite_class->realize_texture =
meta_cursor_sprite_wayland_realize_texture;
cursor_sprite_class->invalidate =
meta_cursor_sprite_wayland_invalidate;
cursor_sprite_class->is_animated = meta_cursor_sprite_wayland_is_animated;
}