1 /* GDK - The GIMP Drawing Kit
2 * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
3 * Copyright (C) 1998-1999 Tor Lillqvist
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the
17 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 * Boston, MA 02111-1307, USA.
22 * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
23 * file for a list of people on the GTK+ Team. See the ChangeLog
24 * files for a list of changes. These files are distributed with
25 * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
30 #include "gdk.h" /* gdk_rectangle_intersect */
31 #include "gdkevents.h"
32 #include "gdkpixmap.h"
33 #include "gdkwindow.h"
34 #include "gdkinternals.h"
35 #include "gdkprivate-win32.h"
36 #include "gdkinput-win32.h"
38 static gboolean gdk_window_gravity_works (void);
39 static void gdk_window_set_static_win_gravity (GdkWindow *window,
42 static GdkColormap* gdk_window_impl_win32_get_colormap (GdkDrawable *drawable);
43 static void gdk_window_impl_win32_set_colormap (GdkDrawable *drawable,
45 static void gdk_window_impl_win32_get_size (GdkDrawable *drawable,
48 static GdkRegion* gdk_window_impl_win32_get_visible_region (GdkDrawable *drawable);
49 static void gdk_window_impl_win32_init (GdkWindowImplWin32 *window);
50 static void gdk_window_impl_win32_class_init (GdkWindowImplWin32Class *klass);
51 static void gdk_window_impl_win32_finalize (GObject *object);
53 static gpointer parent_class = NULL;
56 gdk_window_impl_win32_get_type (void)
58 static GType object_type = 0;
62 static const GTypeInfo object_info =
64 sizeof (GdkWindowImplWin32Class),
66 (GBaseFinalizeFunc) NULL,
67 (GClassInitFunc) gdk_window_impl_win32_class_init,
68 NULL, /* class_finalize */
69 NULL, /* class_data */
70 sizeof (GdkWindowImplWin32),
72 (GInstanceInitFunc) gdk_window_impl_win32_init,
75 object_type = g_type_register_static (GDK_TYPE_DRAWABLE_IMPL_WIN32,
84 _gdk_window_impl_get_type (void)
86 return gdk_window_impl_win32_get_type ();
90 gdk_window_impl_win32_init (GdkWindowImplWin32 *impl)
98 impl->extension_events_selected = FALSE;
99 impl->input_locale = GetKeyboardLayout (0);
100 TranslateCharsetInfo ((DWORD FAR *) GetACP (), &impl->charset_info,
105 gdk_window_impl_win32_class_init (GdkWindowImplWin32Class *klass)
107 GObjectClass *object_class = G_OBJECT_CLASS (klass);
108 GdkDrawableClass *drawable_class = GDK_DRAWABLE_CLASS (klass);
110 parent_class = g_type_class_peek_parent (klass);
112 object_class->finalize = gdk_window_impl_win32_finalize;
114 drawable_class->set_colormap = gdk_window_impl_win32_set_colormap;
115 drawable_class->get_colormap = gdk_window_impl_win32_get_colormap;
116 drawable_class->get_size = gdk_window_impl_win32_get_size;
118 /* Visible and clip regions are the same */
119 drawable_class->get_clip_region = gdk_window_impl_win32_get_visible_region;
120 drawable_class->get_visible_region = gdk_window_impl_win32_get_visible_region;
124 gdk_window_impl_win32_finalize (GObject *object)
126 GdkWindowObject *wrapper;
127 GdkDrawableImplWin32 *draw_impl;
128 GdkWindowImplWin32 *window_impl;
130 g_return_if_fail (GDK_IS_WINDOW_IMPL_WIN32 (object));
132 draw_impl = GDK_DRAWABLE_IMPL_WIN32 (object);
133 window_impl = GDK_WINDOW_IMPL_WIN32 (object);
135 wrapper = (GdkWindowObject*) draw_impl->wrapper;
137 if (!GDK_WINDOW_DESTROYED (wrapper))
139 gdk_win32_handle_table_remove (draw_impl->handle);
142 if (window_impl->hcursor != NULL)
144 if (!DestroyCursor (window_impl->hcursor))
145 WIN32_GDI_FAILED("DestroyCursor");
146 window_impl->hcursor = NULL;
149 G_OBJECT_CLASS (parent_class)->finalize (object);
153 gdk_window_impl_win32_get_colormap (GdkDrawable *drawable)
155 GdkDrawableImplWin32 *drawable_impl;
156 GdkWindowImplWin32 *window_impl;
158 g_return_val_if_fail (GDK_IS_WINDOW_IMPL_WIN32 (drawable), NULL);
160 drawable_impl = GDK_DRAWABLE_IMPL_WIN32 (drawable);
161 window_impl = GDK_WINDOW_IMPL_WIN32 (drawable);
163 if (!((GdkWindowObject *) drawable_impl->wrapper)->input_only &&
164 drawable_impl->colormap == NULL)
166 drawable_impl->colormap = gdk_colormap_get_system ();
167 gdk_colormap_ref (drawable_impl->colormap);
170 return drawable_impl->colormap;
174 gdk_window_impl_win32_set_colormap (GdkDrawable *drawable,
177 GdkWindowImplWin32 *impl;
178 GdkDrawableImplWin32 *draw_impl;
180 g_return_if_fail (GDK_IS_WINDOW_IMPL_WIN32 (drawable));
181 g_return_if_fail (gdk_colormap_get_visual (cmap) != gdk_drawable_get_visual (drawable));
183 impl = GDK_WINDOW_IMPL_WIN32 (drawable);
184 draw_impl = GDK_DRAWABLE_IMPL_WIN32 (drawable);
186 GDK_DRAWABLE_GET_CLASS (draw_impl)->set_colormap (drawable, cmap);
189 g_print("gdk_window_impl_win32_set_colormap: XXX\n");
193 gdk_window_impl_win32_get_size (GdkDrawable *drawable,
197 g_return_if_fail (GDK_IS_WINDOW_IMPL_WIN32 (drawable));
200 *width = GDK_WINDOW_IMPL_WIN32 (drawable)->width;
202 *height = GDK_WINDOW_IMPL_WIN32 (drawable)->height;
206 gdk_window_impl_win32_get_visible_region (GdkDrawable *drawable)
208 GdkWindowImplWin32 *impl = GDK_WINDOW_IMPL_WIN32 (drawable);
209 GdkRectangle result_rect;
213 result_rect.width = impl->width;
214 result_rect.height = impl->height;
216 gdk_rectangle_intersect (&result_rect, &impl->position_info.clip_rect, &result_rect);
218 return gdk_region_rectangle (&result_rect);
222 _gdk_windowing_window_init (void)
224 GdkWindowObject *private;
225 GdkWindowImplWin32 *impl;
226 GdkDrawableImplWin32 *draw_impl;
231 g_assert (gdk_parent_root == NULL);
233 SystemParametersInfo(SPI_GETWORKAREA, 0, &rect, 0);
234 width = rect.right - rect.left;
235 height = rect.bottom - rect.top;
237 gdk_parent_root = g_object_new (GDK_TYPE_WINDOW, NULL);
238 private = (GdkWindowObject *)gdk_parent_root;
239 impl = GDK_WINDOW_IMPL_WIN32 (private->impl);
240 draw_impl = GDK_DRAWABLE_IMPL_WIN32 (private->impl);
242 draw_impl->handle = gdk_root_window;
243 draw_impl->wrapper = GDK_DRAWABLE (private);
245 private->window_type = GDK_WINDOW_ROOT;
246 private->depth = gdk_visual_get_system ()->depth;
248 impl->height = height;
250 gdk_win32_handle_table_insert (&gdk_root_window, gdk_parent_root);
253 /* The Win API function AdjustWindowRect may return negative values
254 * resulting in obscured title bars. This helper function is coreccting it.
257 SafeAdjustWindowRectEx (RECT* lpRect,
262 if (!AdjustWindowRectEx(lpRect, dwStyle, bMenu, dwExStyle))
264 WIN32_API_FAILED ("AdjustWindowRectEx");
267 if (lpRect->left < 0)
269 lpRect->right -= lpRect->left;
274 lpRect->bottom -= lpRect->top;
281 * is a wrapper function for RegisterWindowClassEx.
282 * It creates at least one unique class for every
283 * GdkWindowType. If support for single window-specific icons
284 * is ever needed (e.g Dialog specific), every such window should
288 RegisterGdkClass (GdkWindowType wtype)
290 static ATOM klassTOPLEVEL = 0;
291 static ATOM klassDIALOG = 0;
292 static ATOM klassCHILD = 0;
293 static ATOM klassTEMP = 0;
294 static HICON hAppIcon = NULL;
295 static WNDCLASSEX wcl;
298 wcl.cbSize = sizeof(WNDCLASSEX);
299 wcl.style = 0; /* DON'T set CS_<H,V>REDRAW. It causes total redraw
300 * on WM_SIZE and WM_MOVE. Flicker, Performance!
302 wcl.lpfnWndProc = gdk_window_procedure;
305 wcl.hInstance = gdk_app_hmodule;
307 /* initialize once! */
310 gchar sLoc [_MAX_PATH+1];
312 if (0 != GetModuleFileName (gdk_app_hmodule, sLoc, _MAX_PATH))
314 hAppIcon = ExtractIcon (gdk_app_hmodule, sLoc, 0);
317 char *gdklibname = g_strdup_printf ("gdk-%s.dll", GDK_VERSION);
319 hAppIcon = ExtractIcon (gdk_app_hmodule, gdklibname, 0);
324 hAppIcon = LoadIcon (NULL, IDI_APPLICATION);
328 wcl.lpszMenuName = NULL;
331 /* initialize once per class */
333 * HB: Setting the background brush leads to flicker, because we
334 * don't get asked how to clear the background. This is not what
335 * we want, at least not for input_only windows ...
337 #define ONCE_PER_CLASS() \
338 wcl.hIcon = CopyIcon (hAppIcon); \
339 wcl.hIconSm = CopyIcon (hAppIcon); \
340 wcl.hbrBackground = NULL; /* CreateSolidBrush (RGB (0,0,0)); */ \
341 wcl.hCursor = LoadCursor (NULL, IDC_ARROW);
345 case GDK_WINDOW_TOPLEVEL:
346 if (0 == klassTOPLEVEL)
348 wcl.lpszClassName = "gdkWindowToplevel";
351 klassTOPLEVEL = RegisterClassEx (&wcl);
353 klass = klassTOPLEVEL;
356 case GDK_WINDOW_CHILD:
359 wcl.lpszClassName = "gdkWindowChild";
361 wcl.style |= CS_PARENTDC; /* MSDN: ... enhances system performance. */
363 klassCHILD = RegisterClassEx (&wcl);
368 case GDK_WINDOW_DIALOG:
369 if (0 == klassDIALOG)
371 wcl.lpszClassName = "gdkWindowDialog";
372 wcl.style |= CS_SAVEBITS;
374 klassDIALOG = RegisterClassEx (&wcl);
379 case GDK_WINDOW_TEMP:
382 wcl.lpszClassName = "gdkWindowTemp";
383 wcl.style |= CS_SAVEBITS;
385 klassTEMP = RegisterClassEx (&wcl);
391 g_assert_not_reached ();
397 WIN32_API_FAILED ("RegisterClassEx");
398 g_error ("That is a fatal error");
404 gdk_window_new (GdkWindow *parent,
405 GdkWindowAttr *attributes,
406 gint attributes_mask)
409 GdkWindowObject *private;
410 GdkWindowObject *parent_private;
411 GdkWindowImplWin32 *impl;
412 GdkDrawableImplWin32 *draw_impl;
418 DWORD dwStyle, dwExStyle;
427 g_return_val_if_fail (attributes != NULL, NULL);
430 parent = gdk_parent_root;
432 g_return_val_if_fail (GDK_IS_WINDOW (parent), NULL);
435 g_print ("gdk_window_new: %s\n",
436 (attributes->window_type == GDK_WINDOW_TOPLEVEL ? "TOPLEVEL" :
437 (attributes->window_type == GDK_WINDOW_CHILD ? "CHILD" :
438 (attributes->window_type == GDK_WINDOW_DIALOG ? "DIALOG" :
439 (attributes->window_type == GDK_WINDOW_TEMP ? "TEMP" :
442 parent_private = (GdkWindowObject*) parent;
443 if (GDK_WINDOW_DESTROYED (parent))
446 hparent = GDK_WINDOW_HWND (parent);
448 window = g_object_new (GDK_TYPE_WINDOW, NULL);
449 private = (GdkWindowObject *)window;
450 impl = GDK_WINDOW_IMPL_WIN32 (private->impl);
451 draw_impl = GDK_DRAWABLE_IMPL_WIN32 (private->impl);
452 draw_impl->wrapper = GDK_DRAWABLE (window);
454 private->parent = (GdkWindowObject *)parent;
456 if (attributes_mask & GDK_WA_X)
461 if (attributes_mask & GDK_WA_Y)
463 else if (attributes_mask & GDK_WA_X)
464 y = 100; /* ??? We must put it somewhere... */
466 y = 0; /* x is CW_USEDEFAULT, y doesn't matter then */
470 impl->width = (attributes->width > 1) ? (attributes->width) : (1);
471 impl->height = (attributes->height > 1) ? (attributes->height) : (1);
472 impl->extension_events_selected = FALSE;
473 private->window_type = attributes->window_type;
475 _gdk_window_init_position (GDK_WINDOW (private));
476 if (impl->position_info.big)
477 private->guffaw_gravity = TRUE;
479 if (attributes_mask & GDK_WA_VISUAL)
480 visual = attributes->visual;
482 visual = gdk_visual_get_system ();
483 xvisual = ((GdkVisualPrivate*) visual)->xvisual;
485 if (attributes_mask & GDK_WA_TITLE)
486 title = attributes->title;
488 title = g_get_prgname ();
489 if (!title || !*title)
490 title = "GDK client window";
492 impl->event_mask = GDK_STRUCTURE_MASK | attributes->event_mask;
494 if (parent_private && parent_private->guffaw_gravity)
499 if (attributes->wclass == GDK_INPUT_OUTPUT)
503 private->input_only = FALSE;
504 private->depth = visual->depth;
506 if (attributes_mask & GDK_WA_COLORMAP)
508 draw_impl->colormap = attributes->colormap;
509 gdk_colormap_ref (attributes->colormap);
513 if ((((GdkVisualPrivate*)gdk_visual_get_system ())->xvisual) == xvisual)
515 draw_impl->colormap = gdk_colormap_get_system ();
516 gdk_colormap_ref (draw_impl->colormap);
517 GDK_NOTE (MISC, g_print ("...using system colormap %p\n",
518 draw_impl->colormap));
522 draw_impl->colormap = gdk_colormap_new (visual, FALSE);
523 GDK_NOTE (MISC, g_print ("...using new colormap %p\n",
524 draw_impl->colormap));
530 dwExStyle = WS_EX_TRANSPARENT;
532 private->input_only = TRUE;
533 draw_impl->colormap = NULL;
534 GDK_NOTE (MISC, g_print ("...GDK_INPUT_ONLY, NULL colormap\n"));
538 parent_private->children = g_list_prepend (parent_private->children, window);
540 switch (private->window_type)
542 case GDK_WINDOW_TOPLEVEL:
543 dwStyle = WS_OVERLAPPEDWINDOW | WS_CLIPCHILDREN;
544 hparent = gdk_root_window;
547 case GDK_WINDOW_CHILD:
548 dwStyle = WS_CHILDWINDOW | WS_CLIPCHILDREN | WS_CLIPSIBLINGS;
551 case GDK_WINDOW_DIALOG:
552 dwStyle = WS_OVERLAPPED | WS_MINIMIZEBOX | WS_SYSMENU | WS_CAPTION | WS_THICKFRAME | WS_CLIPCHILDREN;
554 dwExStyle |= WS_EX_TOPMOST; /* //HB: want this? */
556 hparent = gdk_root_window;
559 case GDK_WINDOW_TEMP:
560 dwStyle = WS_CLIPCHILDREN | WS_CLIPSIBLINGS;
561 /* a temp window is not necessarily a top level window */
562 dwStyle |= (gdk_parent_root == parent ? WS_POPUP : WS_CHILDWINDOW);
563 dwExStyle |= WS_EX_TOOLWINDOW;
566 case GDK_WINDOW_ROOT:
567 g_error ("cannot make windows of type GDK_WINDOW_ROOT");
571 klass = RegisterGdkClass (private->window_type);
573 if (private->window_type != GDK_WINDOW_CHILD)
575 if (x == CW_USEDEFAULT)
586 rect.right = rect.left + impl->width;
587 rect.bottom = rect.top + impl->height;
589 SafeAdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle);
591 if (x != CW_USEDEFAULT)
596 width = rect.right - rect.left;
597 height = rect.bottom - rect.top;
602 height = impl->height;
605 mbtitle = g_locale_from_utf8 (title, -1, NULL, NULL, NULL);
607 #ifdef WITHOUT_WM_CREATE
608 draw_impl->handle = CreateWindowEx (dwExStyle,
609 MAKEINTRESOURCE(klass),
621 CreateWindowEx (dwExStyle,
622 MAKEINTRESOURCE(klass),
631 if (GDK_WINDOW_HWND (window) != hwndNew)
633 g_warning("gdk_window_new: gdk_event_translate::WM_CREATE (%#x, %#x) HWND mismatch.",
634 (guint) GDK_WINDOW_HWND (window),
637 /* HB: IHMO due to a race condition the handle was increased by
638 * one, which causes much trouble. Because I can't find the
639 * real bug, try to workaround it ...
640 * To reproduce: compile with MSVC 5, DEBUG=1
643 gdk_win32_handle_table_remove (GDK_WINDOW_HWND (window));
644 GDK_WINDOW_HWND (window) = hwndNew;
645 gdk_win32_handle_table_insert (&GDK_WINDOW_HWND (window), window);
647 /* the old behaviour, but with warning */
648 GDK_WINDOW_HWND (window) = hwndNew;
653 gdk_drawable_ref (window);
654 gdk_win32_handle_table_insert (&GDK_WINDOW_HWND (window), window);
658 g_print ("... \"%s\" %dx%d@+%d+%d %#x = %#x\n"
659 "... locale %#x codepage %d\n",
661 width, height, (x == CW_USEDEFAULT ? -9999 : x), y,
663 (guint) GDK_WINDOW_HWND (window),
664 (guint) impl->input_locale,
665 (guint) impl->charset_info.ciACP));
669 if (draw_impl->handle == NULL)
671 WIN32_API_FAILED ("CreateWindowEx");
672 g_object_unref ((GObject *) window);
676 #ifdef WITHOUT_WM_CREATE
677 gdk_drawable_ref (window);
678 gdk_win32_handle_table_insert (&GDK_WINDOW_HWND (window), window);
681 gdk_window_set_cursor (window, ((attributes_mask & GDK_WA_CURSOR) ?
682 (attributes->cursor) :
689 gdk_window_foreign_new (GdkNativeWindow anid)
692 GdkWindowObject *private;
693 GdkWindowObject *parent_private;
694 GdkWindowImplWin32 *impl;
695 GdkDrawableImplWin32 *draw_impl;
701 window = g_object_new (GDK_TYPE_WINDOW, NULL);
702 private = (GdkWindowObject *)window;
703 impl = GDK_WINDOW_IMPL_WIN32 (private->impl);
704 draw_impl = GDK_DRAWABLE_IMPL_WIN32 (private->impl);
705 draw_impl->wrapper = GDK_DRAWABLE (window);
706 parent = GetParent ((HWND)anid);
708 private->parent = gdk_win32_handle_table_lookup ((GdkNativeWindow) parent);
710 parent_private = (GdkWindowObject *)private->parent;
713 parent_private->children = g_list_prepend (parent_private->children, window);
715 draw_impl->handle = (HWND) anid;
716 GetClientRect ((HWND) anid, &rect);
718 point.y = rect.right;
719 ClientToScreen ((HWND) anid, &point);
720 if (parent != gdk_root_window)
721 ScreenToClient (parent, &point);
722 private->x = point.x;
723 private->y = point.y;
724 impl->width = rect.right - rect.left;
725 impl->height = rect.bottom - rect.top;
726 private->window_type = GDK_WINDOW_FOREIGN;
727 private->destroyed = FALSE;
728 if (IsWindowVisible ((HWND) anid))
729 private->state &= (~GDK_WINDOW_STATE_WITHDRAWN);
731 private->state |= GDK_WINDOW_STATE_WITHDRAWN;
732 private->depth = gdk_visual_get_system ()->depth;
734 gdk_drawable_ref (window);
735 gdk_win32_handle_table_insert (&GDK_WINDOW_HWND (window), window);
741 _gdk_windowing_window_destroy (GdkWindow *window,
743 gboolean foreign_destroy)
745 GdkWindowObject *private = (GdkWindowObject *)window;
747 g_return_if_fail (GDK_IS_WINDOW (window));
749 GDK_NOTE (MISC, g_print ("_gdk_windowing_window_destroy %#x\n",
750 (guint) GDK_WINDOW_HWND (window)));
752 if (private->extension_events != 0)
753 gdk_input_window_destroy (window);
755 if (private->window_type == GDK_WINDOW_FOREIGN)
757 if (!foreign_destroy && (private->parent != NULL))
759 /* It's somebody else's window, but in our hierarchy,
760 * so reparent it to the root window, and then call
761 * DestroyWindow() on it.
763 gdk_window_hide (window);
764 gdk_window_reparent (window, NULL, 0, 0);
766 /* Is this too drastic? Many (most?) applications
767 * quit if any window receives WM_QUIT I think.
768 * OTOH, I don't think foreign windows are much
769 * used, so the question is maybe academic.
771 PostMessage (GDK_WINDOW_HWND (window), WM_QUIT, 0, 0);
774 else if (!recursing && !foreign_destroy)
776 private->destroyed = TRUE;
777 DestroyWindow (GDK_WINDOW_HWND (window));
781 /* This function is called when the window really gone.
784 gdk_window_destroy_notify (GdkWindow *window)
786 g_return_if_fail (window != NULL);
787 g_return_if_fail (GDK_IS_WINDOW (window));
790 g_print ("gdk_window_destroy_notify: %#x %s\n",
791 (guint) GDK_WINDOW_HWND (window),
792 (GDK_WINDOW_DESTROYED (window) ? "(destroyed)" : "")));
794 if (!GDK_WINDOW_DESTROYED (window))
796 if (GDK_WINDOW_TYPE(window) != GDK_WINDOW_FOREIGN)
797 g_warning ("window %#x unexpectedly destroyed",
798 (guint) GDK_WINDOW_HWND (window));
800 _gdk_window_destroy (window, TRUE);
803 gdk_win32_handle_table_remove (GDK_WINDOW_HWND (window));
804 gdk_drawable_unref (window);
808 gdk_window_show (GdkWindow *window)
810 GdkWindowObject *private;
812 g_return_if_fail (GDK_IS_WINDOW (window));
814 private = (GdkWindowObject*) window;
815 if (!private->destroyed)
817 GDK_NOTE (MISC, g_print ("gdk_window_show: %#x\n",
818 (guint) GDK_WINDOW_HWND (window)));
820 private->state &= (~GDK_WINDOW_STATE_WITHDRAWN);
821 if (GDK_WINDOW_TYPE (window) == GDK_WINDOW_TEMP)
823 ShowWindow (GDK_WINDOW_HWND (window), SW_SHOWNOACTIVATE);
824 SetWindowPos (GDK_WINDOW_HWND (window), HWND_TOPMOST, 0, 0, 0, 0,
825 SWP_NOACTIVATE | SWP_NOMOVE | SWP_NOSIZE);
827 /* Don't put on toolbar */
828 ShowWindow (GDK_WINDOW_HWND (window), SW_HIDE);
833 if (GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE) & WS_EX_TRANSPARENT)
835 SetWindowPos(GDK_WINDOW_HWND (window), HWND_TOP, 0, 0, 0, 0,
836 SWP_SHOWWINDOW | SWP_NOREDRAW | SWP_NOMOVE | SWP_NOSIZE);
840 GdkWindow *parent = GDK_WINDOW (private->parent);
842 /* Todo: GDK_WINDOW_STATE_STICKY */
843 if (private->state & GDK_WINDOW_STATE_ICONIFIED)
844 ShowWindow (GDK_WINDOW_HWND (window), SW_SHOWMINIMIZED);
845 else if (private->state & GDK_WINDOW_STATE_MAXIMIZED)
846 ShowWindow (GDK_WINDOW_HWND (window), SW_SHOWMAXIMIZED);
849 ShowWindow (GDK_WINDOW_HWND (window), SW_SHOWNORMAL);
850 ShowWindow (GDK_WINDOW_HWND (window), SW_RESTORE);
852 if (parent == gdk_parent_root)
853 SetForegroundWindow (GDK_WINDOW_HWND (window));
854 BringWindowToTop (GDK_WINDOW_HWND (window));
856 ShowOwnedPopups (GDK_WINDOW_HWND (window), TRUE);
864 gdk_window_hide (GdkWindow *window)
866 GdkWindowObject *private;
868 g_return_if_fail (window != NULL);
870 private = (GdkWindowObject*) window;
871 if (!private->destroyed)
873 GDK_NOTE (MISC, g_print ("gdk_window_hide: %#x\n",
874 (guint) GDK_WINDOW_HWND (window)));
876 private->state |= GDK_WINDOW_STATE_WITHDRAWN;
877 if (GDK_WINDOW_TYPE (window) == GDK_WINDOW_TOPLEVEL)
878 ShowOwnedPopups (GDK_WINDOW_HWND (window), FALSE);
880 if (GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE) & WS_EX_TRANSPARENT)
882 SetWindowPos(GDK_WINDOW_HWND (window), HWND_BOTTOM, 0, 0, 0, 0,
883 SWP_HIDEWINDOW | SWP_NOREDRAW | SWP_NOZORDER | SWP_NOMOVE | SWP_NOSIZE);
887 ShowWindow (GDK_WINDOW_HWND (window), SW_HIDE);
893 gdk_window_withdraw (GdkWindow *window)
895 GdkWindowObject *private;
897 g_return_if_fail (window != NULL);
899 private = (GdkWindowObject*) window;
900 if (!private->destroyed)
902 GDK_NOTE (MISC, g_print ("gdk_window_withdraw: %#x\n",
903 (guint) GDK_WINDOW_HWND (window)));
905 gdk_window_hide (window); /* ??? */
910 gdk_window_move (GdkWindow *window,
914 GdkWindowObject *private = (GdkWindowObject *)window;
915 GdkWindowImplWin32 *impl;
917 g_return_if_fail (window != NULL);
918 g_return_if_fail (GDK_IS_WINDOW (window));
920 impl = GDK_WINDOW_IMPL_WIN32 (private->impl);
922 gdk_window_move_resize (window, x, y, impl->width, impl->height);
926 gdk_window_resize (GdkWindow *window,
930 GdkWindowObject *private = (GdkWindowObject*) window;
931 GdkWindowImplWin32 *impl;
934 g_return_if_fail (window != NULL);
935 g_return_if_fail (GDK_IS_WINDOW (window));
942 impl = GDK_WINDOW_IMPL_WIN32 (private->impl);
944 if (!private->destroyed)
946 GDK_NOTE (MISC, g_print ("gdk_window_resize: %#x %dx%d\n",
947 (guint) GDK_WINDOW_HWND (window),
950 if (GDK_WINDOW_TYPE (private) != GDK_WINDOW_CHILD)
959 ClientToScreen (GDK_WINDOW_HWND (window), &pt);
962 rect.right = pt.x + width;
963 rect.bottom = pt.y + height;
965 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
966 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
967 if (!AdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle))
968 WIN32_API_FAILED ("AdjustWindowRectEx");
972 width = rect.right - rect.left;
973 height = rect.bottom - rect.top;
980 impl->height = height;
983 private->resize_count += 1;
985 GDK_NOTE (MISC, g_print ("...MoveWindow(%#x,%dx%d@+%d+%d)\n",
986 (guint) GDK_WINDOW_HWND (window),
987 width, height, x, y));
988 if (!MoveWindow (GDK_WINDOW_HWND (window), x, y, width, height, TRUE))
989 WIN32_API_FAILED ("MoveWindow");
994 gdk_window_move_resize (GdkWindow *window,
1000 GdkWindowObject *private = (GdkWindowObject*) window;
1001 GdkWindowImplWin32 *impl;
1003 g_return_if_fail (window != NULL);
1004 g_return_if_fail (GDK_IS_WINDOW (window));
1011 impl = GDK_WINDOW_IMPL_WIN32 (private->impl);
1013 if (!private->destroyed)
1019 GDK_NOTE (MISC, g_print ("gdk_window_move_resize: %#x %dx%d@+%d+%d\n",
1020 (guint) GDK_WINDOW_HWND (window),
1021 width, height, x, y));
1023 if (GDK_WINDOW_TYPE (private) == GDK_WINDOW_CHILD)
1024 _gdk_window_move_resize_child (window, x, y, width, height);
1029 rect.right = x + width;
1030 rect.bottom = y + height;
1032 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
1033 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
1034 if (!AdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle))
1035 WIN32_API_FAILED ("AdjustWindowRectEx");
1037 GDK_NOTE (MISC, g_print ("...MoveWindow(%#x,%ldx%ld@+%ld+%ld)\n",
1038 (guint) GDK_WINDOW_HWND (window),
1039 rect.right - rect.left, rect.bottom - rect.top,
1040 rect.left, rect.top));
1041 if (!MoveWindow (GDK_WINDOW_HWND (window),
1042 rect.left, rect.top,
1043 rect.right - rect.left, rect.bottom - rect.top,
1045 WIN32_API_FAILED ("MoveWindow");
1051 gdk_window_reparent (GdkWindow *window,
1052 GdkWindow *new_parent,
1056 GdkWindowObject *window_private;
1057 GdkWindowObject *parent_private;
1058 GdkWindowObject *old_parent_private;
1059 GdkWindowImplWin32 *impl;
1061 g_return_if_fail (window != NULL);
1064 new_parent = gdk_parent_root;
1066 window_private = (GdkWindowObject*) window;
1067 old_parent_private = (GdkWindowObject *) window_private->parent;
1068 parent_private = (GdkWindowObject*) new_parent;
1069 impl = GDK_WINDOW_IMPL_WIN32 (window_private->impl);
1071 if (!GDK_WINDOW_DESTROYED (window) && !GDK_WINDOW_DESTROYED (new_parent))
1073 GDK_NOTE (MISC, g_print ("gdk_window_reparent: %#x %#x\n",
1074 (guint) GDK_WINDOW_HWND (window),
1075 (guint) GDK_WINDOW_HWND (new_parent)));
1076 if (!SetParent (GDK_WINDOW_HWND (window),
1077 GDK_WINDOW_HWND (new_parent)))
1078 WIN32_API_FAILED ("SetParent");
1080 if (!MoveWindow (GDK_WINDOW_HWND (window),
1081 x, y, impl->width, impl->height, TRUE))
1082 WIN32_API_FAILED ("MoveWindow");
1085 window_private->parent = (GdkWindowObject *)new_parent;
1087 if (old_parent_private)
1088 old_parent_private->children =
1089 g_list_remove (old_parent_private->children, window);
1091 if ((old_parent_private &&
1092 (!old_parent_private->guffaw_gravity != !parent_private->guffaw_gravity)) ||
1093 (!old_parent_private && parent_private->guffaw_gravity))
1094 gdk_window_set_static_win_gravity (window, parent_private->guffaw_gravity);
1096 parent_private->children = g_list_prepend (parent_private->children, window);
1100 _gdk_windowing_window_clear_area (GdkWindow *window,
1106 GdkWindowImplWin32 *impl;
1108 g_return_if_fail (window != NULL);
1109 g_return_if_fail (GDK_IS_WINDOW (window));
1111 impl = GDK_WINDOW_IMPL_WIN32 (GDK_WINDOW_OBJECT (window)->impl);
1113 if (!GDK_WINDOW_DESTROYED (window))
1118 width = impl->width - x;
1120 height = impl->height - y;
1121 GDK_NOTE (MISC, g_print ("_gdk_windowing_window_clear_area: "
1122 "%#x %dx%d@+%d+%d\n",
1123 (guint) GDK_WINDOW_HWND (window),
1124 width, height, x, y));
1125 hdc = GetDC (GDK_WINDOW_HWND (window));
1126 IntersectClipRect (hdc, x, y, x + width + 1, y + height + 1);
1127 SendMessage (GDK_WINDOW_HWND (window), WM_ERASEBKGND, (WPARAM) hdc, 0);
1128 ReleaseDC (GDK_WINDOW_HWND (window), hdc);
1133 _gdk_windowing_window_clear_area_e (GdkWindow *window,
1139 g_return_if_fail (window != NULL);
1140 g_return_if_fail (GDK_IS_WINDOW (window));
1142 if (!GDK_WINDOW_DESTROYED (window))
1146 GDK_NOTE (MISC, g_print ("_gdk_windowing_window_clear_area_e: "
1147 "%#x %dx%d@+%d+%d\n",
1148 (guint) GDK_WINDOW_HWND (window),
1149 width, height, x, y));
1152 rect.right = x + width + 1;
1154 rect.bottom = y + height + 1;
1155 if (!InvalidateRect (GDK_WINDOW_HWND (window), &rect, TRUE))
1156 WIN32_GDI_FAILED ("InvalidateRect");
1157 UpdateWindow (GDK_WINDOW_HWND (window));
1162 gdk_window_raise (GdkWindow *window)
1164 g_return_if_fail (window != NULL);
1165 g_return_if_fail (GDK_IS_WINDOW (window));
1167 if (!GDK_WINDOW_DESTROYED (window))
1169 GDK_NOTE (MISC, g_print ("gdk_window_raise: %#x\n",
1170 (guint) GDK_WINDOW_HWND (window)));
1172 if (!BringWindowToTop (GDK_WINDOW_HWND (window)))
1173 WIN32_API_FAILED ("BringWindowToTop");
1178 gdk_window_lower (GdkWindow *window)
1180 g_return_if_fail (window != NULL);
1181 g_return_if_fail (GDK_IS_WINDOW (window));
1183 if (!GDK_WINDOW_DESTROYED (window))
1185 GDK_NOTE (MISC, g_print ("gdk_window_lower: %#x\n",
1186 (guint) GDK_WINDOW_HWND (window)));
1188 if (!SetWindowPos (GDK_WINDOW_HWND (window), HWND_BOTTOM, 0, 0, 0, 0,
1189 SWP_NOACTIVATE | SWP_NOMOVE | SWP_NOSIZE))
1190 WIN32_API_FAILED ("SetWindowPos");
1195 gdk_window_set_hints (GdkWindow *window,
1204 GdkWindowImplWin32 *impl;
1205 WINDOWPLACEMENT size_hints;
1211 g_return_if_fail (window != NULL);
1212 g_return_if_fail (GDK_IS_WINDOW (window));
1214 if (GDK_WINDOW_DESTROYED (window))
1217 impl = GDK_WINDOW_IMPL_WIN32 (GDK_WINDOW_OBJECT (window)->impl);
1219 GDK_NOTE (MISC, g_print ("gdk_window_set_hints: %#x %dx%d..%dx%d @+%d+%d\n",
1220 (guint) GDK_WINDOW_HWND (window),
1221 min_width, min_height, max_width, max_height,
1224 impl->hint_flags = flags;
1225 size_hints.length = sizeof (size_hints);
1229 if (flags & GDK_HINT_POS)
1231 if (!GetWindowPlacement (GDK_WINDOW_HWND (window), &size_hints))
1232 WIN32_API_FAILED ("GetWindowPlacement");
1235 GDK_NOTE (MISC, g_print ("...rcNormalPosition:"
1236 " (%ld,%ld)--(%ld,%ld)\n",
1237 size_hints.rcNormalPosition.left,
1238 size_hints.rcNormalPosition.top,
1239 size_hints.rcNormalPosition.right,
1240 size_hints.rcNormalPosition.bottom));
1241 /* What are the corresponding window coordinates for client
1242 * area coordinates x, y
1246 rect.right = rect.left + 200; /* dummy */
1247 rect.bottom = rect.top + 200;
1248 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
1249 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
1250 AdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle);
1251 size_hints.flags = 0;
1252 size_hints.showCmd = SW_SHOWNA;
1254 /* Set the normal position hint to that location, with unchanged
1257 diff = size_hints.rcNormalPosition.left - rect.left;
1258 size_hints.rcNormalPosition.left = rect.left;
1259 size_hints.rcNormalPosition.right -= diff;
1260 diff = size_hints.rcNormalPosition.top - rect.top;
1261 size_hints.rcNormalPosition.top = rect.top;
1262 size_hints.rcNormalPosition.bottom -= diff;
1263 GDK_NOTE (MISC, g_print ("...setting: (%ld,%ld)--(%ld,%ld)\n",
1264 size_hints.rcNormalPosition.left,
1265 size_hints.rcNormalPosition.top,
1266 size_hints.rcNormalPosition.right,
1267 size_hints.rcNormalPosition.bottom));
1268 if (!SetWindowPlacement (GDK_WINDOW_HWND (window), &size_hints))
1269 WIN32_API_FAILED ("SetWindowPlacement");
1270 impl->hint_x = rect.left;
1271 impl->hint_y = rect.top;
1275 if (flags & GDK_HINT_MIN_SIZE)
1279 rect.right = min_width;
1280 rect.bottom = min_height;
1281 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
1282 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
1283 SafeAdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle);
1284 impl->hint_min_width = rect.right - rect.left;
1285 impl->hint_min_height = rect.bottom - rect.top;
1287 /* Also chek if he current size of the window is in bounds. */
1288 GetClientRect (GDK_WINDOW_HWND (window), &rect);
1289 if (rect.right < min_width && rect.bottom < min_height)
1290 gdk_window_resize (window, min_width, min_height);
1291 else if (rect.right < min_width)
1292 gdk_window_resize (window, min_width, rect.bottom);
1293 else if (rect.bottom < min_height)
1294 gdk_window_resize (window, rect.right, min_height);
1297 if (flags & GDK_HINT_MAX_SIZE)
1301 rect.right = max_width;
1302 rect.bottom = max_height;
1303 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
1304 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
1305 AdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle);
1306 impl->hint_max_width = rect.right - rect.left;
1307 impl->hint_max_height = rect.bottom - rect.top;
1308 /* Again, check if the window is too large currently. */
1309 GetClientRect (GDK_WINDOW_HWND (window), &rect);
1310 if (rect.right > max_width && rect.bottom > max_height)
1311 gdk_window_resize (window, max_width, max_height);
1312 else if (rect.right > max_width)
1313 gdk_window_resize (window, max_width, rect.bottom);
1314 else if (rect.bottom > max_height)
1315 gdk_window_resize (window, rect.right, max_height);
1321 gdk_window_set_geometry_hints (GdkWindow *window,
1322 GdkGeometry *geometry,
1323 GdkWindowHints geom_mask)
1325 GdkWindowImplWin32 *impl;
1326 WINDOWPLACEMENT size_hints;
1331 g_return_if_fail (window != NULL);
1332 g_return_if_fail (GDK_IS_WINDOW (window));
1334 if (GDK_WINDOW_DESTROYED (window))
1337 impl = GDK_WINDOW_IMPL_WIN32 (GDK_WINDOW_OBJECT (window)->impl);
1338 size_hints.length = sizeof (size_hints);
1340 impl->hint_flags = geom_mask;
1342 if (geom_mask & GDK_HINT_POS)
1343 ; /* even the X11 mplementation doesn't care */
1345 if (geom_mask & GDK_HINT_MIN_SIZE)
1349 rect.right = geometry->min_width;
1350 rect.bottom = geometry->min_height;
1351 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
1352 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
1353 AdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle);
1354 impl->hint_min_width = rect.right - rect.left;
1355 impl->hint_min_height = rect.bottom - rect.top;
1357 /* Also check if he current size of the window is in bounds */
1358 GetClientRect (GDK_WINDOW_HWND (window), &rect);
1359 if (rect.right < geometry->min_width
1360 && rect.bottom < geometry->min_height)
1361 gdk_window_resize (window, geometry->min_width, geometry->min_height);
1362 else if (rect.right < geometry->min_width)
1363 gdk_window_resize (window, geometry->min_width, rect.bottom);
1364 else if (rect.bottom < geometry->min_height)
1365 gdk_window_resize (window, rect.right, geometry->min_height);
1368 if (geom_mask & GDK_HINT_MAX_SIZE)
1372 rect.right = geometry->max_width;
1373 rect.bottom = geometry->max_height;
1374 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
1375 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
1376 /* HB: dont' know why AdjustWindowRectEx is called here, ... */
1377 SafeAdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle);
1378 impl->hint_max_width = rect.right - rect.left;
1379 impl->hint_max_height = rect.bottom - rect.top;
1380 /* ... but negative sizes are always wrong */
1381 if (impl->hint_max_width < 0) impl->hint_max_width = G_MAXSHORT;
1382 if (impl->hint_max_height < 0) impl->hint_max_height = G_MAXSHORT;
1384 /* Again, check if the window is too large currently. */
1385 GetClientRect (GDK_WINDOW_HWND (window), &rect);
1386 if (rect.right > geometry->max_width
1387 && rect.bottom > geometry->max_height)
1388 gdk_window_resize (window, geometry->max_width, geometry->max_height);
1389 else if (rect.right > geometry->max_width)
1390 gdk_window_resize (window, geometry->max_width, rect.bottom);
1391 else if (rect.bottom > geometry->max_height)
1392 gdk_window_resize (window, rect.right, geometry->max_height);
1395 /* I don't know what to do when called with zero base_width and height. */
1396 if (geom_mask & GDK_HINT_BASE_SIZE
1397 && geometry->base_width > 0
1398 && geometry->base_height > 0)
1400 if (!GetWindowPlacement (GDK_WINDOW_HWND (window), &size_hints))
1401 WIN32_API_FAILED ("GetWindowPlacement");
1404 GDK_NOTE (MISC, g_print ("gdk_window_set_geometry_hints:"
1405 " rcNormalPosition: (%ld,%ld)--(%ld,%ld)\n",
1406 size_hints.rcNormalPosition.left,
1407 size_hints.rcNormalPosition.top,
1408 size_hints.rcNormalPosition.right,
1409 size_hints.rcNormalPosition.bottom));
1410 size_hints.rcNormalPosition.right =
1411 size_hints.rcNormalPosition.left + geometry->base_width;
1412 size_hints.rcNormalPosition.bottom =
1413 size_hints.rcNormalPosition.top + geometry->base_height;
1414 GDK_NOTE (MISC, g_print ("...setting: rcNormal: (%ld,%ld)--(%ld,%ld)\n",
1415 size_hints.rcNormalPosition.left,
1416 size_hints.rcNormalPosition.top,
1417 size_hints.rcNormalPosition.right,
1418 size_hints.rcNormalPosition.bottom));
1419 if (!SetWindowPlacement (GDK_WINDOW_HWND (window), &size_hints))
1420 WIN32_API_FAILED ("SetWindowPlacement");
1424 if (geom_mask & GDK_HINT_RESIZE_INC)
1429 if (geom_mask & GDK_HINT_ASPECT)
1436 gdk_window_set_title (GdkWindow *window,
1441 g_return_if_fail (window != NULL);
1442 g_return_if_fail (GDK_IS_WINDOW (window));
1443 g_return_if_fail (title != NULL);
1445 /* Empty window titles not allowed, so set it to just a period. */
1449 GDK_NOTE (MISC, g_print ("gdk_window_set_title: %#x %s\n",
1450 (guint) GDK_WINDOW_HWND (window), title));
1452 if (!GDK_WINDOW_DESTROYED (window))
1454 /* As the title is in UTF-8 we must translate it
1455 * to the system codepage.
1457 mbtitle = g_locale_from_utf8 (title, -1, NULL, NULL, NULL);
1458 if (!SetWindowText (GDK_WINDOW_HWND (window), mbtitle))
1459 WIN32_API_FAILED ("SetWindowText");
1466 gdk_window_set_role (GdkWindow *window,
1469 g_return_if_fail (window != NULL);
1470 g_return_if_fail (GDK_IS_WINDOW (window));
1472 GDK_NOTE (MISC, g_print ("gdk_window_set_role: %#x %s\n",
1473 (guint) GDK_WINDOW_HWND (window),
1474 (role ? role : "NULL")));
1479 gdk_window_set_transient_for (GdkWindow *window,
1482 HWND window_id, parent_id;
1485 g_return_if_fail (window != NULL);
1486 g_return_if_fail (GDK_IS_WINDOW (window));
1488 GDK_NOTE (MISC, g_print ("gdk_window_set_transient_for: %#x %#x\n",
1489 (guint) GDK_WINDOW_HWND (window),
1490 (guint) GDK_WINDOW_HWND (parent)));
1492 if (GDK_WINDOW_DESTROYED (window) || GDK_WINDOW_DESTROYED (parent))
1495 window_id = GDK_WINDOW_HWND (window);
1496 parent_id = GDK_WINDOW_HWND (parent);
1498 if ((style = GetWindowLong (window_id, GWL_STYLE)) == 0)
1499 WIN32_API_FAILED ("GetWindowLong");
1502 #if 0 /* not sure if we want to do this */
1503 style &= ~(WS_SYSMENU | WS_MAXIMIZEBOX | WS_MINIMIZEBOX);
1506 if (!SetWindowLong (window_id, GWL_STYLE, style))
1507 WIN32_API_FAILED ("SetWindowLong");
1508 if (!SetParent (window_id, parent_id))
1509 WIN32_API_FAILED ("SetParent");
1511 if (!RedrawWindow (window_id, NULL, NULL,
1512 RDW_FRAME | RDW_INVALIDATE | RDW_UPDATENOW))
1513 WIN32_API_FAILED ("RedrawWindow");
1517 gdk_window_set_background (GdkWindow *window,
1520 GdkWindowObject *private = (GdkWindowObject *)window;
1522 g_return_if_fail (window != NULL);
1523 g_return_if_fail (GDK_IS_WINDOW (window));
1525 GDK_NOTE (MISC, g_print ("gdk_window_set_background: %#x %s\n",
1526 (guint) GDK_WINDOW_HWND (window),
1527 gdk_win32_color_to_string (color)));
1529 private->bg_color = *color;
1531 if (private->bg_pixmap &&
1532 private->bg_pixmap != GDK_PARENT_RELATIVE_BG &&
1533 private->bg_pixmap != GDK_NO_BG)
1535 gdk_drawable_unref (private->bg_pixmap);
1536 private->bg_pixmap = NULL;
1541 gdk_window_set_back_pixmap (GdkWindow *window,
1543 gint parent_relative)
1545 GdkWindowObject *private = (GdkWindowObject *)window;
1547 g_return_if_fail (window != NULL);
1548 g_return_if_fail (GDK_IS_WINDOW (window));
1549 g_return_if_fail (pixmap == NULL || !parent_relative);
1551 if (private->bg_pixmap &&
1552 private->bg_pixmap != GDK_PARENT_RELATIVE_BG &&
1553 private->bg_pixmap != GDK_NO_BG)
1554 gdk_drawable_unref (private->bg_pixmap);
1556 if (parent_relative)
1558 private->bg_pixmap = GDK_PARENT_RELATIVE_BG;
1564 gdk_drawable_ref (pixmap);
1565 private->bg_pixmap = pixmap;
1569 private->bg_pixmap = GDK_NO_BG;
1575 gdk_window_set_cursor (GdkWindow *window,
1578 GdkWindowImplWin32 *impl;
1579 GdkCursorPrivate *cursor_private;
1581 HCURSOR hprevcursor;
1584 g_return_if_fail (window != NULL);
1585 g_return_if_fail (GDK_IS_WINDOW (window));
1587 impl = GDK_WINDOW_IMPL_WIN32 (GDK_WINDOW_OBJECT (window)->impl);
1588 cursor_private = (GdkCursorPrivate*) cursor;
1590 if (!GDK_WINDOW_DESTROYED (window))
1595 hcursor = cursor_private->hcursor;
1597 GDK_NOTE (MISC, g_print ("gdk_window_set_cursor: %#x %#x\n",
1598 (guint) GDK_WINDOW_HWND (window),
1600 hprevcursor = impl->hcursor;
1601 if (hcursor == NULL)
1602 impl->hcursor = NULL;
1605 /* We must copy the cursor as it is OK to destroy the GdkCursor
1606 * while still in use for some window. See for instance
1607 * gimp_change_win_cursor() which calls
1608 * gdk_window_set_cursor (win, cursor), and immediately
1609 * afterwards gdk_cursor_destroy (cursor).
1611 impl->hcursor = CopyCursor (hcursor);
1612 GDK_NOTE (MISC, g_print ("...CopyCursor (%#x) = %#x\n",
1613 (guint) hcursor, (guint) impl->hcursor));
1615 if (hprevcursor != NULL && GetCursor () == hprevcursor)
1616 SetCursor (impl->hcursor);
1618 if (hprevcursor != NULL)
1620 GDK_NOTE (MISC, g_print ("...DestroyCursor (%#x)\n",
1621 (guint) hprevcursor));
1623 if (!DestroyCursor (hprevcursor))
1624 WIN32_API_FAILED ("DestroyCursor");
1631 gdk_window_get_geometry (GdkWindow *window,
1638 g_return_if_fail (window == NULL || GDK_IS_WINDOW (window));
1641 window = gdk_parent_root;
1643 if (!GDK_WINDOW_DESTROYED (window))
1647 if (!GetClientRect (GDK_WINDOW_HWND (window), &rect))
1648 WIN32_API_FAILED ("GetClientRect");
1655 *width = rect.right - rect.left;
1657 *height = rect.bottom - rect.top;
1659 *depth = gdk_drawable_get_visual (window)->depth;
1664 gdk_window_get_origin (GdkWindow *window,
1672 g_return_val_if_fail (window != NULL, 0);
1674 if (!GDK_WINDOW_DESTROYED (window))
1680 ClientToScreen (GDK_WINDOW_HWND (window), &pt);
1693 GDK_NOTE (MISC, g_print ("gdk_window_get_origin: %#x: +%d+%d\n",
1694 (guint) GDK_WINDOW_HWND (window),
1700 gdk_window_get_deskrelative_origin (GdkWindow *window,
1704 return gdk_window_get_origin (window, x, y);
1708 gdk_window_get_root_origin (GdkWindow *window,
1712 GdkWindowObject *rover;
1715 g_return_if_fail (window != NULL);
1716 g_return_if_fail (GDK_IS_WINDOW (window));
1718 rover = (GdkWindowObject*) window;
1724 if (GDK_WINDOW_DESTROYED (window))
1727 while (rover->parent && ((GdkWindowObject*) rover->parent)->parent)
1728 rover = (GdkWindowObject *) rover->parent;
1729 if (rover->destroyed)
1734 ClientToScreen (GDK_WINDOW_HWND (rover), &pt);
1740 GDK_NOTE (MISC, g_print ("gdk_window_get_root_origin: %#x: (%#x) +%ld+%ld\n",
1741 (guint) GDK_WINDOW_HWND (window),
1742 (guint) GDK_WINDOW_HWND (rover),
1747 gdk_window_get_frame_extents (GdkWindow *window,
1750 GdkWindowObject *private;
1759 if (GDK_WINDOW_DESTROYED (window))
1762 hwnd = GDK_WINDOW_HWND (window);
1763 /* find the frame window */
1764 while (HWND_DESKTOP != GetParent (hwnd))
1766 hwnd = GetParent (hwnd);
1767 g_return_if_fail (NULL != hwnd);
1770 if (GetWindowRect (hwnd, &r))
1771 WIN32_API_FAILED ("GetWindowRect");
1775 rect->width = r.right - r.left;
1776 rect->height = r.bottom - r.top;
1780 _gdk_windowing_window_get_pointer (GdkWindow *window,
1783 GdkModifierType *mask)
1785 GdkWindow *return_val;
1786 POINT pointc, point;
1789 g_return_val_if_fail (window == NULL || GDK_IS_WINDOW (window), NULL);
1792 window = gdk_parent_root;
1795 GetCursorPos (&pointc);
1797 ScreenToClient (GDK_WINDOW_HWND (window), &point);
1804 hwnd = WindowFromPoint (point);
1806 ScreenToClient (hwnd, &point);
1809 hwndc = ChildWindowFromPoint (hwnd, point);
1810 ClientToScreen (hwnd, &point);
1811 ScreenToClient (hwndc, &point);
1812 } while (hwndc != hwnd && (hwnd = hwndc, 1)); /* Ouch! */
1814 return_val = gdk_win32_handle_table_lookup ((GdkNativeWindow) hwnd);
1820 GetKeyboardState (kbd);
1822 if (kbd[VK_SHIFT] & 0x80)
1823 *mask |= GDK_SHIFT_MASK;
1824 if (kbd[VK_CAPITAL] & 0x80)
1825 *mask |= GDK_LOCK_MASK;
1826 if (kbd[VK_CONTROL] & 0x80)
1827 *mask |= GDK_CONTROL_MASK;
1828 if (kbd[VK_MENU] & 0x80)
1829 *mask |= GDK_MOD1_MASK;
1830 if (kbd[VK_LBUTTON] & 0x80)
1831 *mask |= GDK_BUTTON1_MASK;
1832 if (kbd[VK_MBUTTON] & 0x80)
1833 *mask |= GDK_BUTTON2_MASK;
1834 if (kbd[VK_RBUTTON] & 0x80)
1835 *mask |= GDK_BUTTON3_MASK;
1842 _gdk_windowing_window_at_pointer (gint *win_x,
1846 POINT point, pointc;
1850 GetCursorPos (&pointc);
1852 hwnd = WindowFromPoint (point);
1856 window = gdk_parent_root;
1864 ScreenToClient (hwnd, &point);
1867 hwndc = ChildWindowFromPoint (hwnd, point);
1868 ClientToScreen (hwnd, &point);
1869 ScreenToClient (hwndc, &point);
1870 } while (hwndc != hwnd && (hwnd = hwndc, 1));
1872 window = gdk_win32_handle_table_lookup ((GdkNativeWindow) hwnd);
1874 if (window && (win_x || win_y))
1876 GetClientRect (hwnd, &rect);
1878 *win_x = point.x - rect.left;
1880 *win_y = point.y - rect.top;
1883 GDK_NOTE (MISC, g_print ("gdk_window_at_pointer: +%ld+%ld %#x%s\n",
1886 (window == NULL ? " NULL" : "")));
1892 gdk_window_get_events (GdkWindow *window)
1894 g_return_val_if_fail (window != NULL, 0);
1895 g_return_val_if_fail (GDK_IS_WINDOW (window), 0);
1897 if (GDK_WINDOW_DESTROYED (window))
1900 return GDK_WINDOW_IMPL_WIN32 (GDK_WINDOW_OBJECT (window)->impl)->event_mask;
1904 gdk_window_set_events (GdkWindow *window,
1905 GdkEventMask event_mask)
1907 g_return_if_fail (window != NULL);
1908 g_return_if_fail (GDK_IS_WINDOW (window));
1910 if (GDK_WINDOW_DESTROYED (window))
1913 GDK_WINDOW_IMPL_WIN32 (GDK_WINDOW_OBJECT (window)->impl)->event_mask = event_mask;
1917 gdk_window_shape_combine_mask (GdkWindow *window,
1921 g_return_if_fail (window != NULL);
1922 g_return_if_fail (GDK_IS_WINDOW (window));
1926 GDK_NOTE (MISC, g_print ("gdk_window_shape_combine_mask: %#x none\n",
1927 (guint) GDK_WINDOW_HWND (window)));
1928 SetWindowRgn (GDK_WINDOW_HWND (window), NULL, TRUE);
1937 /* Convert mask bitmap to region */
1938 hrgn = BitmapToRegion (GDK_WINDOW_HWND (mask));
1940 GDK_NOTE (MISC, g_print ("gdk_window_shape_combine_mask: %#x %#x\n",
1941 (guint) GDK_WINDOW_HWND (window),
1942 (guint) GDK_WINDOW_HWND (mask)));
1944 /* SetWindowRgn wants window (not client) coordinates */
1945 dwStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
1946 dwExStyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
1947 GetClientRect (GDK_WINDOW_HWND (window), &rect);
1948 AdjustWindowRectEx (&rect, dwStyle, FALSE, dwExStyle);
1949 OffsetRgn (hrgn, -rect.left, -rect.top);
1951 OffsetRgn (hrgn, x, y);
1953 /* If this is a top-level window, add the title bar to the region */
1954 if (GDK_WINDOW_TYPE (window) == GDK_WINDOW_TOPLEVEL)
1956 CombineRgn (hrgn, hrgn,
1957 CreateRectRgn (0, 0, rect.right - rect.left, -rect.top),
1961 SetWindowRgn (GDK_WINDOW_HWND (window), hrgn, TRUE);
1966 gdk_window_set_override_redirect (GdkWindow *window,
1967 gboolean override_redirect)
1969 g_return_if_fail (window != NULL);
1970 g_return_if_fail (GDK_IS_WINDOW (window));
1972 g_warning ("gdk_window_set_override_redirect not implemented");
1976 gdk_window_set_icon (GdkWindow *window,
1977 GdkWindow *icon_window,
1981 g_return_if_fail (window != NULL);
1982 g_return_if_fail (GDK_IS_WINDOW (window));
1984 if (GDK_WINDOW_DESTROYED (window))
1987 /* Nothing to do, really. As we share window classes between windows
1988 * we can't have window-specific icons, sorry. Don't print any warning
1994 gdk_window_set_icon_name (GdkWindow *window,
1997 g_return_if_fail (window != NULL);
1998 g_return_if_fail (GDK_IS_WINDOW (window));
2000 if (GDK_WINDOW_DESTROYED (window))
2003 if (!SetWindowText (GDK_WINDOW_HWND (window), name))
2004 WIN32_API_FAILED ("SetWindowText");
2008 gdk_window_set_group (GdkWindow *window,
2011 g_return_if_fail (window != NULL);
2012 g_return_if_fail (GDK_IS_WINDOW (window));
2013 g_return_if_fail (leader != NULL);
2014 g_return_if_fail (GDK_IS_WINDOW (leader));
2016 if (GDK_WINDOW_DESTROYED (window) || GDK_WINDOW_DESTROYED (leader))
2019 g_warning ("gdk_window_set_group not implemented");
2023 gdk_window_set_decorations (GdkWindow *window,
2024 GdkWMDecoration decorations)
2026 LONG style, exstyle;
2028 g_return_if_fail (window != NULL);
2029 g_return_if_fail (GDK_IS_WINDOW (window));
2031 style = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
2032 exstyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
2034 style &= (WS_OVERLAPPED|WS_POPUP|WS_CHILD|WS_MINIMIZE|WS_VISIBLE|WS_DISABLED
2035 |WS_CLIPSIBLINGS|WS_CLIPCHILDREN|WS_MAXIMIZE);
2037 exstyle &= (WS_EX_TOPMOST|WS_EX_TRANSPARENT);
2039 if (decorations & GDK_DECOR_ALL)
2040 style |= (WS_CAPTION|WS_SYSMENU|WS_THICKFRAME|WS_MINIMIZEBOX|WS_MAXIMIZEBOX);
2041 if (decorations & GDK_DECOR_BORDER)
2042 style |= (WS_BORDER);
2043 if (decorations & GDK_DECOR_RESIZEH)
2044 style |= (WS_THICKFRAME);
2045 if (decorations & GDK_DECOR_TITLE)
2046 style |= (WS_CAPTION);
2047 if (decorations & GDK_DECOR_MENU)
2048 style |= (WS_SYSMENU);
2049 if (decorations & GDK_DECOR_MINIMIZE)
2050 style |= (WS_MINIMIZEBOX);
2051 if (decorations & GDK_DECOR_MAXIMIZE)
2052 style |= (WS_MAXIMIZEBOX);
2054 SetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE, style);
2058 gdk_window_set_functions (GdkWindow *window,
2059 GdkWMFunction functions)
2061 LONG style, exstyle;
2063 g_return_if_fail (window != NULL);
2064 g_return_if_fail (GDK_IS_WINDOW (window));
2066 style = GetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE);
2067 exstyle = GetWindowLong (GDK_WINDOW_HWND (window), GWL_EXSTYLE);
2069 style &= (WS_OVERLAPPED|WS_POPUP|WS_CHILD|WS_MINIMIZE|WS_VISIBLE|WS_DISABLED
2070 |WS_CLIPSIBLINGS|WS_CLIPCHILDREN|WS_MAXIMIZE|WS_CAPTION|WS_BORDER
2073 exstyle &= (WS_EX_TOPMOST|WS_EX_TRANSPARENT);
2075 if (functions & GDK_FUNC_ALL)
2076 style |= (WS_THICKFRAME|WS_MINIMIZEBOX|WS_MAXIMIZEBOX);
2077 if (functions & GDK_FUNC_RESIZE)
2078 style |= (WS_THICKFRAME);
2079 if (functions & GDK_FUNC_MOVE)
2080 style |= (WS_THICKFRAME);
2081 if (functions & GDK_FUNC_MINIMIZE)
2082 style |= (WS_MINIMIZEBOX);
2083 if (functions & GDK_FUNC_MAXIMIZE)
2084 style |= (WS_MAXIMIZEBOX);
2086 SetWindowLong (GDK_WINDOW_HWND (window), GWL_STYLE, style);
2090 * propagate the shapes from all child windows of a GDK window to the parent
2091 * window. Shamelessly ripped from Enlightenment's code
2097 QueryTree (HWND hwnd,
2107 child = GetWindow (hwnd, GW_CHILD);
2109 child = GetWindow (child, GW_HWNDNEXT);
2112 } while (child != NULL);
2116 *children = g_new (HWND, n);
2117 for (i = 0; i < n; i++)
2120 child = GetWindow (hwnd, GW_CHILD);
2122 child = GetWindow (child, GW_HWNDNEXT);
2123 *children[i] = child;
2129 gdk_propagate_shapes (HANDLE win,
2133 HRGN region, childRegion;
2137 SetRectEmpty (&emptyRect);
2138 region = CreateRectRgnIndirect (&emptyRect);
2140 GetWindowRgn (win, region);
2142 QueryTree (win, &list, &num);
2145 WINDOWPLACEMENT placement;
2147 placement.length = sizeof (WINDOWPLACEMENT);
2148 /* go through all child windows and combine regions */
2149 for (i = 0; i < num; i++)
2151 GetWindowPlacement (list[i], &placement);
2152 if (placement.showCmd == SW_SHOWNORMAL)
2154 childRegion = CreateRectRgnIndirect (&emptyRect);
2155 GetWindowRgn (list[i], childRegion);
2156 CombineRgn (region, region, childRegion, RGN_OR);
2157 DeleteObject (childRegion);
2160 SetWindowRgn (win, region, TRUE);
2163 DeleteObject (region);
2167 gdk_window_set_child_shapes (GdkWindow *window)
2169 g_return_if_fail (window != NULL);
2170 g_return_if_fail (GDK_IS_WINDOW (window));
2172 if (GDK_WINDOW_DESTROYED (window))
2175 gdk_propagate_shapes (GDK_WINDOW_HWND (window), FALSE);
2179 gdk_window_merge_child_shapes (GdkWindow *window)
2181 g_return_if_fail (window != NULL);
2182 g_return_if_fail (GDK_IS_WINDOW (window));
2184 if (GDK_WINDOW_DESTROYED (window))
2187 gdk_propagate_shapes (GDK_WINDOW_HWND (window), TRUE);
2190 /* Support for windows that can be guffaw-scrolled
2191 * (See http://www.gtk.org/~otaylor/whitepapers/guffaw-scrolling.txt)
2195 gdk_window_gravity_works (void)
2197 enum { UNKNOWN, NO, YES };
2198 static gint gravity_works = UNKNOWN;
2200 if (gravity_works == UNKNOWN)
2207 attr.window_type = GDK_WINDOW_TEMP;
2208 attr.wclass = GDK_INPUT_OUTPUT;
2213 attr.event_mask = 0;
2215 parent = gdk_window_new (NULL, &attr, GDK_WA_X | GDK_WA_Y);
2217 attr.window_type = GDK_WINDOW_CHILD;
2218 child = gdk_window_new (parent, &attr, GDK_WA_X | GDK_WA_Y);
2220 gdk_window_set_static_win_gravity (child, TRUE);
2222 gdk_window_resize (parent, 100, 110);
2223 gdk_window_move (parent, 0, -10);
2224 gdk_window_move_resize (parent, 0, 0, 100, 100);
2226 gdk_window_resize (parent, 100, 110);
2227 gdk_window_move (parent, 0, -10);
2228 gdk_window_move_resize (parent, 0, 0, 100, 100);
2230 gdk_window_get_geometry (child, NULL, &y, NULL, NULL, NULL);
2232 gdk_window_destroy (parent);
2233 gdk_window_destroy (child);
2235 gravity_works = ((y == -20) ? YES : NO);
2238 return (gravity_works == YES);
2242 gdk_window_set_static_bit_gravity (GdkWindow *window, gboolean on)
2244 g_return_if_fail (window != NULL);
2246 GDK_NOTE (MISC, g_print ("gdk_window_set_static_bit_gravity: Not implemented\n"));
2250 gdk_window_set_static_win_gravity (GdkWindow *window, gboolean on)
2252 g_return_if_fail (window != NULL);
2255 g_print ("gdk_window_set_static_win_gravity: Not implemented\n"));
2258 /*************************************************************
2259 * gdk_window_set_static_gravities:
2260 * Set the bit gravity of the given window to static,
2261 * and flag it so all children get static subwindow
2264 * window: window for which to set static gravity
2265 * use_static: Whether to turn static gravity on or off.
2267 * Does the XServer support static gravity?
2268 *************************************************************/
2271 gdk_window_set_static_gravities (GdkWindow *window,
2272 gboolean use_static)
2274 GdkWindowObject *private = (GdkWindowObject *)window;
2277 g_return_val_if_fail (window != NULL, FALSE);
2278 g_return_val_if_fail (GDK_IS_WINDOW (window), FALSE);
2280 if (!use_static == !private->guffaw_gravity)
2283 if (use_static && !gdk_window_gravity_works ())
2286 private->guffaw_gravity = use_static;
2288 if (!GDK_WINDOW_DESTROYED (window))
2290 gdk_window_set_static_bit_gravity (window, use_static);
2292 tmp_list = private->children;
2295 gdk_window_set_static_win_gravity (window, use_static);
2297 tmp_list = tmp_list->next;
2305 * Setting window states
2308 gdk_window_iconify (GdkWindow *window)
2310 g_return_if_fail (window != NULL);
2311 g_return_if_fail (GDK_IS_WINDOW (window));
2313 if (GDK_WINDOW_DESTROYED (window))
2316 if (GDK_WINDOW_IS_MAPPED (window))
2318 ShowWindow (GDK_WINDOW_HWND (window), SW_MINIMIZE);
2322 /* Flip our client side flag, the real work happens on map. */
2323 gdk_synthesize_window_state (window,
2325 GDK_WINDOW_STATE_ICONIFIED);
2330 gdk_window_deiconify (GdkWindow *window)
2332 g_return_if_fail (window != NULL);
2333 g_return_if_fail (GDK_IS_WINDOW (window));
2335 if (GDK_WINDOW_DESTROYED (window))
2338 if (GDK_WINDOW_IS_MAPPED (window))
2340 gdk_window_show (window);
2344 /* Flip our client side flag, the real work happens on map. */
2345 gdk_synthesize_window_state (window,
2346 GDK_WINDOW_STATE_ICONIFIED,
2352 gdk_window_stick (GdkWindow *window)
2354 g_return_if_fail (GDK_IS_WINDOW (window));
2356 if (GDK_WINDOW_DESTROYED (window))
2359 if (GDK_WINDOW_IS_MAPPED (window))
2361 /* "stick" means stick to all desktops _and_ do not scroll with the
2362 * viewport. i.e. glue to the monitor glass in all cases.
2364 g_warning ("gdk_window_stick (0x%X) ???", GDK_WINDOW_HWND (window));
2368 /* Flip our client side flag, the real work happens on map. */
2369 gdk_synthesize_window_state (window,
2371 GDK_WINDOW_STATE_STICKY);
2376 gdk_window_unstick (GdkWindow *window)
2378 g_return_if_fail (GDK_IS_WINDOW (window));
2380 if (GDK_WINDOW_DESTROYED (window))
2383 if (GDK_WINDOW_IS_MAPPED (window))
2385 g_warning ("gdk_window_unstick (0x%X) ???", GDK_WINDOW_HWND (window));
2389 /* Flip our client side flag, the real work happens on map. */
2390 gdk_synthesize_window_state (window,
2391 GDK_WINDOW_STATE_STICKY,
2398 gdk_window_maximize (GdkWindow *window)
2400 g_return_if_fail (GDK_IS_WINDOW (window));
2402 if (GDK_WINDOW_DESTROYED (window))
2405 if (GDK_WINDOW_IS_MAPPED (window))
2406 ShowWindow (GDK_WINDOW_HWND (window), SW_MAXIMIZE);
2408 gdk_synthesize_window_state (window,
2410 GDK_WINDOW_STATE_MAXIMIZED);
2414 gdk_window_unmaximize (GdkWindow *window)
2416 g_return_if_fail (GDK_IS_WINDOW (window));
2418 if (GDK_WINDOW_DESTROYED (window))
2421 if (GDK_WINDOW_IS_MAPPED (window))
2422 ShowWindow (GDK_WINDOW_HWND (window), SW_RESTORE);
2424 gdk_synthesize_window_state (window,
2425 GDK_WINDOW_STATE_MAXIMIZED,
2430 gdk_window_focus (GdkWindow *window,
2433 g_return_if_fail (GDK_IS_WINDOW (window));
2435 if (GDK_WINDOW_DESTROYED (window))
2438 ShowWindow (GDK_WINDOW_HWND (window), SW_SHOWNORMAL);
2442 gdk_window_set_modal_hint (GdkWindow *window,
2445 GdkWindowObject *private;
2447 g_return_if_fail (window != NULL);
2448 g_return_if_fail (GDK_IS_WINDOW (window));
2450 if (GDK_WINDOW_DESTROYED (window))
2453 private = (GdkWindowObject*) window;
2455 private->modal_hint = modal;
2457 if (GDK_WINDOW_IS_MAPPED (window))
2458 if (!SetWindowPos (GDK_WINDOW_HWND (window), HWND_TOPMOST,
2459 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE))
2460 WIN32_API_FAILED ("SetWindowPos");
2464 gdk_window_set_type_hint (GdkWindow *window,
2465 GdkWindowTypeHint hint)
2469 g_return_if_fail (window != NULL);
2470 g_return_if_fail (GDK_IS_WINDOW (window));
2472 if (GDK_WINDOW_DESTROYED (window))
2477 case GDK_WINDOW_TYPE_HINT_DIALOG:
2478 atom = gdk_atom_intern ("_NET_WM_WINDOW_TYPE_DIALOG", FALSE);
2480 case GDK_WINDOW_TYPE_HINT_MENU:
2481 atom = gdk_atom_intern ("_NET_WM_WINDOW_TYPE_MENU", FALSE);
2483 case GDK_WINDOW_TYPE_HINT_TOOLBAR:
2484 atom = gdk_atom_intern ("_NET_WM_WINDOW_TYPE_TOOLBAR", FALSE);
2487 g_warning ("Unknown hint %d passed to gdk_window_set_type_hint", hint);
2489 case GDK_WINDOW_TYPE_HINT_NORMAL:
2490 atom = gdk_atom_intern ("_NET_WM_WINDOW_TYPE_NORMAL", FALSE);
2497 g_print ("gdk_window_set_type_hint (0x%0X)\n",
2498 GDK_WINDOW_HWND (window)));
2502 gdk_window_shape_combine_region (GdkWindow *window,
2503 GdkRegion *shape_region,
2507 gint xoffset, yoffset;
2509 g_return_if_fail (GDK_IS_WINDOW (window));
2511 if (GDK_WINDOW_DESTROYED (window))
2514 /* XXX: even on X implemented conditional ... */
2518 gdk_window_begin_resize_drag (GdkWindow *window,
2525 g_return_if_fail (GDK_IS_WINDOW (window));
2527 if (GDK_WINDOW_DESTROYED (window))
2530 /* XXX: isn't all this default on win32 ... */
2534 gdk_window_begin_move_drag (GdkWindow *window,
2540 g_return_if_fail (GDK_IS_WINDOW (window));
2542 if (GDK_WINDOW_DESTROYED (window))
2545 /* XXX: isn't all this default on win32 ... */