[gtk+/gdk-backend-wayland] wayland: Fix hiding and withdrawing surfaces
- From: Kristian Høgsberg <krh src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gdk-backend-wayland] wayland: Fix hiding and withdrawing surfaces
- Date: Fri, 11 Feb 2011 04:05:02 +0000 (UTC)
commit 6d20bcb84878e69b0f913911b1af498562ecadb3
Author: Kristian Høgsberg <krh bitplanet net>
Date: Thu Feb 10 22:21:08 2011 -0500
wayland: Fix hiding and withdrawing surfaces
gdk/wayland/gdkwindow-wayland.c | 17 +++++++++--------
1 files changed, 9 insertions(+), 8 deletions(-)
---
diff --git a/gdk/wayland/gdkwindow-wayland.c b/gdk/wayland/gdkwindow-wayland.c
index ca14684..b5ddb65 100644
--- a/gdk/wayland/gdkwindow-wayland.c
+++ b/gdk/wayland/gdkwindow-wayland.c
@@ -453,6 +453,9 @@ gdk_wayland_window_show (GdkWindow *window, gboolean already_mapped)
_gdk_make_event (window, GDK_MAP, NULL, FALSE);
event = _gdk_make_event (window, GDK_VISIBILITY_NOTIFY, NULL, FALSE);
event->visibility.state = GDK_VISIBILITY_UNOBSCURED;
+
+ if (impl->cairo_surface)
+ gdk_wayland_window_attach_image (window);
}
static void
@@ -462,10 +465,11 @@ gdk_wayland_window_hide (GdkWindow *window)
if (impl->surface)
{
- fprintf (stderr, "hide surface %p\n", impl->surface);
-
wl_surface_destroy(impl->surface);
impl->surface = NULL;
+ cairo_surface_destroy(impl->server_surface);
+ impl->server_surface = NULL;
+ impl->mapped = FALSE;
}
_gdk_window_clear_update_area (window);
@@ -486,11 +490,11 @@ gdk_window_wayland_withdraw (GdkWindow *window)
impl = GDK_WINDOW_IMPL_WAYLAND (window->impl);
if (impl->surface)
{
- fprintf (stderr, "hide surface %p\n", impl->surface);
-
wl_surface_destroy(impl->surface);
impl->surface = NULL;
- cairo_surface_destroy(GDK_WINDOW_IMPL_WAYLAND(impl)->cairo_surface);
+ cairo_surface_destroy(impl->server_surface);
+ impl->server_surface = NULL;
+ impl->mapped = FALSE;
}
}
}
@@ -736,9 +740,6 @@ gdk_wayland_window_destroy (GdkWindow *window,
if (!recursing && !foreign_destroy)
{
- fprintf (stderr, "destroy window, surface %p\n",
- GDK_WINDOW_IMPL_WAYLAND (window->impl)->surface);
-
if (GDK_WINDOW_IMPL_WAYLAND (window->impl)->surface)
wl_surface_destroy(GDK_WINDOW_IMPL_WAYLAND (window->impl)->surface);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]