[gtk+/broadway: 33/71] [broadway] Track window<->id mapping
- From: Alexander Larsson <alexl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/broadway: 33/71] [broadway] Track window<->id mapping
- Date: Thu, 25 Nov 2010 21:18:02 +0000 (UTC)
commit d211d78eef4282cbd6e02dac6df893d5257b04f8
Author: Alexander Larsson <alexl redhat com>
Date: Sat Nov 20 22:38:34 2010 +0100
[broadway] Track window<->id mapping
gdk/broadway/gdkdisplay-broadway.c | 1 +
gdk/broadway/gdkdisplay-broadway.h | 2 ++
gdk/broadway/gdkwindow-broadway.c | 5 +++++
3 files changed, 8 insertions(+), 0 deletions(-)
---
diff --git a/gdk/broadway/gdkdisplay-broadway.c b/gdk/broadway/gdkdisplay-broadway.c
index b043da1..3384793 100644
--- a/gdk/broadway/gdkdisplay-broadway.c
+++ b/gdk/broadway/gdkdisplay-broadway.c
@@ -59,6 +59,7 @@ _gdk_display_broadway_class_init (GdkDisplayBroadwayClass * class)
static void
_gdk_display_broadway_init (GdkDisplayBroadway *display)
{
+ display->id_ht = g_hash_table_new (NULL, NULL);
}
static void
diff --git a/gdk/broadway/gdkdisplay-broadway.h b/gdk/broadway/gdkdisplay-broadway.h
index 30934e9..a294cbe 100644
--- a/gdk/broadway/gdkdisplay-broadway.h
+++ b/gdk/broadway/gdkdisplay-broadway.h
@@ -49,6 +49,8 @@ struct _GdkDisplayBroadway
GdkScreen *default_screen;
GdkScreen **screens;
+ GHashTable *id_ht;
+
GSource *event_source;
GdkWindow *mouse_in_toplevel;
diff --git a/gdk/broadway/gdkwindow-broadway.c b/gdk/broadway/gdkwindow-broadway.c
index 14f4d03..b8937b5 100644
--- a/gdk/broadway/gdkwindow-broadway.c
+++ b/gdk/broadway/gdkwindow-broadway.c
@@ -251,6 +251,7 @@ gdk_window_impl_broadway_finalize (GObject *object)
GdkWindowObject *wrapper;
GdkDrawableImplBroadway *draw_impl;
GdkWindowImplBroadway *window_impl;
+ GdkDisplayBroadway *display_broadway;
g_return_if_fail (GDK_IS_WINDOW_IMPL_BROADWAY (object));
@@ -259,6 +260,9 @@ gdk_window_impl_broadway_finalize (GObject *object)
wrapper = (GdkWindowObject*) draw_impl->wrapper;
+ display_broadway = GDK_DISPLAY_BROADWAY (gdk_window_get_display (wrapper));
+ g_hash_table_remove (display_broadway->id_ht, window_impl->id);
+
if (window_impl->cursor)
gdk_cursor_unref (window_impl->cursor);
@@ -330,6 +334,7 @@ _gdk_window_impl_new (GdkWindow *window,
impl = g_object_new (_gdk_window_impl_get_type (), NULL);
private->impl = (GdkDrawable *)impl;
impl->id = current_id++;
+ g_hash_table_insert (display_broadway->id_ht, impl->id, window);
draw_impl = GDK_DRAWABLE_IMPL_BROADWAY (impl);
draw_impl->wrapper = GDK_DRAWABLE (window);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]