forked from AuroraMiddleware/gtk
win32: destroy clipboard notification window on dispose
The clipboard uses a hidden window to get some specific events. The window was created but never destroyed on dispose.
This commit is contained in:
parent
a4ccf0e382
commit
1f5f3ca41b
@ -570,9 +570,10 @@ _clipboard_window_procedure (HWND hwnd,
|
||||
/*
|
||||
* Creates a hidden window and adds it to the clipboard chain
|
||||
*/
|
||||
static HWND
|
||||
_gdk_win32_register_clipboard_notification (void)
|
||||
static gboolean
|
||||
register_clipboard_notification (GdkDisplay *display)
|
||||
{
|
||||
GdkWin32Display *display_win32 = GDK_WIN32_DISPLAY (display);
|
||||
WNDCLASS wclass = { 0, };
|
||||
HWND hwnd;
|
||||
ATOM klass;
|
||||
@ -583,17 +584,18 @@ _gdk_win32_register_clipboard_notification (void)
|
||||
|
||||
klass = RegisterClass (&wclass);
|
||||
if (!klass)
|
||||
return NULL;
|
||||
return FALSE;
|
||||
|
||||
hwnd = CreateWindow (MAKEINTRESOURCE (klass),
|
||||
display_win32->clipboard_hwnd = CreateWindow (MAKEINTRESOURCE (klass),
|
||||
NULL, WS_POPUP,
|
||||
0, 0, 0, 0, NULL, NULL,
|
||||
_gdk_app_hmodule, NULL);
|
||||
if (!hwnd)
|
||||
|
||||
if (display_win32->clipboard_hwnd == NULL)
|
||||
goto failed;
|
||||
|
||||
SetLastError (0);
|
||||
_hwnd_next_viewer = SetClipboardViewer (hwnd);
|
||||
_hwnd_next_viewer = SetClipboardViewer (display_win32->clipboard_hwnd);
|
||||
|
||||
if (_hwnd_next_viewer == NULL && GetLastError() != 0)
|
||||
goto failed;
|
||||
@ -603,12 +605,12 @@ _gdk_win32_register_clipboard_notification (void)
|
||||
/* if (AddClipboardFormatListener (hwnd) == FALSE) */
|
||||
/* goto failed; */
|
||||
|
||||
return hwnd;
|
||||
return TRUE;
|
||||
|
||||
failed:
|
||||
g_critical ("Failed to install clipboard viewer");
|
||||
UnregisterClass (MAKEINTRESOURCE (klass), _gdk_app_hmodule);
|
||||
return NULL;
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static gboolean
|
||||
@ -616,7 +618,7 @@ gdk_win32_display_request_selection_notification (GdkDisplay *display,
|
||||
GdkAtom selection)
|
||||
|
||||
{
|
||||
static HWND hwndViewer = NULL;
|
||||
GdkWin32Display *display_win32 = GDK_WIN32_DISPLAY (display);
|
||||
gboolean ret = FALSE;
|
||||
|
||||
GDK_NOTE (DND,
|
||||
@ -626,12 +628,14 @@ gdk_win32_display_request_selection_notification (GdkDisplay *display,
|
||||
if (selection == GDK_SELECTION_CLIPBOARD ||
|
||||
selection == GDK_SELECTION_PRIMARY)
|
||||
{
|
||||
if (!hwndViewer)
|
||||
if (display_win32->clipboard_hwnd == NULL)
|
||||
{
|
||||
hwndViewer = _gdk_win32_register_clipboard_notification ();
|
||||
if (register_clipboard_notification (display))
|
||||
GDK_NOTE (DND, g_print (" registered"));
|
||||
else
|
||||
GDK_NOTE (DND, g_print (" failed to register"));
|
||||
}
|
||||
ret = (hwndViewer != NULL);
|
||||
ret = (display_win32->clipboard_hwnd != NULL);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -711,6 +715,8 @@ gdk_win32_display_dispose (GObject *object)
|
||||
GdkWin32Display *display_win32 = GDK_WIN32_DISPLAY (object);
|
||||
|
||||
g_clear_pointer (&display_win32->hwnd, (GDestroyNotify)DestroyWindow);
|
||||
g_clear_pointer (&display_win32->clipboard_hwnd, (GDestroyNotify)DestroyWindow);
|
||||
_hwnd_next_viewer = NULL;
|
||||
|
||||
G_OBJECT_CLASS (gdk_win32_display_parent_class)->dispose (object);
|
||||
}
|
||||
|
@ -32,6 +32,7 @@ struct _GdkWin32Display
|
||||
GHashTable *cursor_cache;
|
||||
|
||||
HWND hwnd;
|
||||
HWND clipboard_hwnd;
|
||||
|
||||
/* WGL/OpenGL Items */
|
||||
guint have_wgl : 1;
|
||||
|
Loading…
Reference in New Issue
Block a user