diff options
author | Matthias Clasen <maclas@gmx.de> | 2003-12-10 23:58:23 +0000 |
---|---|---|
committer | Matthias Clasen <matthiasc@src.gnome.org> | 2003-12-10 23:58:23 +0000 |
commit | 5fb61f307553d9455240315f79923fbbf71bfeba (patch) | |
tree | 2cb5c7df896d7dc4de690c2d8a69a12526daeee3 /gdk | |
parent | c9c99b3f1b96cef1863503612e6c2689ae2ebbe6 (diff) | |
download | gtk+-5fb61f307553d9455240315f79923fbbf71bfeba.tar.gz |
Changes to allow "no input" windows (#64613):
Thu Dec 11 00:35:12 2003 Matthias Clasen <maclas@gmx.de>
Changes to allow "no input" windows (#64613):
* gdk/gdkwindow.h (struct _GdkWindowObject): Add a new boolean
field accept_focus.
* gdk/gdkwindow.h (gdk_window_set_accept_focus): New function to
set it.
* gtk/gtkwindow.[hc]: Add a boolean property "accept_focus"
and gtk_window_get_focus() and gtk_window_set_focus().
* gdk/win32/gdkwindow-win32.c (gdk_window_new):
* gdk/linux-fb/gdkwindow-fb.c (gdk_window_new):
* gdk/x11/gdkwindow-x11.c (gdk_window_set_new):
Initialize the accept_focus field to TRUE.
* gdk/win32/gdkwindow-win32.c (gdk_window_set_accept_focus):
* gdk/linux-fb/gdkwindow-fb.c (gdk_window_set_accept_focus):
* gdk/x11/gdkwindow-x11.c (gdk_window_set_accept_focus):
Implementations for the various backends. The Win32 and linux-fb
implementations set the accept_focus field, but don't use it yet
to actually implement noinput windows. The X implementation updates
the WM_HINTS to select the globally active input model (see the
ICCCM) if accept_focus is FALSE.
* gdk/x11/gdkevents-x11.c (gdk_wm_protocols_filter): Ignore the
WM_TAKE_FOCUS message if accept_focus is FALSE.
Diffstat (limited to 'gdk')
-rw-r--r-- | gdk/gdkwindow.h | 4 | ||||
-rw-r--r-- | gdk/linux-fb/gdkwindow-fb.c | 18 | ||||
-rw-r--r-- | gdk/win32/gdkwindow-win32.c | 18 | ||||
-rw-r--r-- | gdk/x11/gdkevents-x11.c | 3 | ||||
-rw-r--r-- | gdk/x11/gdkwindow-x11.c | 41 |
5 files changed, 81 insertions, 3 deletions
diff --git a/gdk/gdkwindow.h b/gdk/gdkwindow.h index 1eadf0044d..7568a330b9 100644 --- a/gdk/gdkwindow.h +++ b/gdk/gdkwindow.h @@ -260,6 +260,8 @@ struct _GdkWindowObject guint modal_hint : 1; guint destroyed : 2; + + guint accept_focus : 1; GdkEventMask event_mask; }; @@ -317,6 +319,8 @@ void gdk_window_set_user_data (GdkWindow *window, gpointer user_data); void gdk_window_set_override_redirect (GdkWindow *window, gboolean override_redirect); +void gdk_window_set_accept_focus (GdkWindow *window, + gboolean accept_focus); void gdk_window_add_filter (GdkWindow *window, GdkFilterFunc function, gpointer data); diff --git a/gdk/linux-fb/gdkwindow-fb.c b/gdk/linux-fb/gdkwindow-fb.c index 06d987ad3e..140aba2d23 100644 --- a/gdk/linux-fb/gdkwindow-fb.c +++ b/gdk/linux-fb/gdkwindow-fb.c @@ -188,6 +188,8 @@ gdk_window_new (GdkWindow *parent, private->parent = parent_private; + private->accept_focus = TRUE; + if (attributes_mask & GDK_WA_X) x = attributes->x; else @@ -1990,6 +1992,22 @@ gdk_window_set_override_redirect (GdkWindow *window, /* N/A */ } +void +gdk_window_set_accept_focus (GdkWindow *window, + gboolean accept_focus) +{ + GdkWindowObject *private; + g_return_if_fail (window != NULL); + g_return_if_fail (GDK_IS_WINDOW (window)); + + private = (GdkWindowObject *)window; + + accept_focus = accept_focus != FALSE; + + if (private->accept_focus != accept_focus) + private->accept_focus = accept_focus; +} + void gdk_window_set_icon (GdkWindow *window, GdkWindow *icon_window, diff --git a/gdk/win32/gdkwindow-win32.c b/gdk/win32/gdkwindow-win32.c index 640eaccf3e..7f28f8ae0c 100644 --- a/gdk/win32/gdkwindow-win32.c +++ b/gdk/win32/gdkwindow-win32.c @@ -468,6 +468,8 @@ gdk_window_new (GdkWindow *parent, private->parent = (GdkWindowObject *)parent; + private->accept_focus = TRUE; + if (attributes_mask & GDK_WA_X) private->x = attributes->x; else @@ -2151,6 +2153,22 @@ gdk_window_set_override_redirect (GdkWindow *window, g_warning ("gdk_window_set_override_redirect not implemented"); } +void +gdk_window_set_accept_focus (GdkWindow *window, + gboolean accept_focus) +{ + GdkWindowObject *private; + g_return_if_fail (window != NULL); + g_return_if_fail (GDK_IS_WINDOW (window)); + + private = (GdkWindowObject *)window; + + accept_focus = accept_focus != FALSE; + + if (private->accept_focus != accept_focus) + private->accept_focus = accept_focus; +} + void gdk_window_set_icon_list (GdkWindow *window, GList *pixbufs) diff --git a/gdk/x11/gdkevents-x11.c b/gdk/x11/gdkevents-x11.c index ad1ade8121..bc2a38de7b 100644 --- a/gdk/x11/gdkevents-x11.c +++ b/gdk/x11/gdkevents-x11.c @@ -1969,11 +1969,12 @@ gdk_wm_protocols_filter (GdkXEvent *xev, else if ((Atom) xevent->xclient.data.l[0] == gdk_x11_get_xatom_by_name_for_display (display, "WM_TAKE_FOCUS")) { GdkToplevelX11 *toplevel = _gdk_x11_window_get_toplevel (event->any.window); + GdkWindowObject *private = (GdkWindowObject *)win; /* There is no way of knowing reliably whether we are viewable; * _gdk_x11_set_input_focus_safe() traps errors asynchronously. */ - if (toplevel) + if (toplevel && private->accept_focus) _gdk_x11_set_input_focus_safe (display, toplevel->focus_window, RevertToParent, xevent->xclient.data.l[1]); diff --git a/gdk/x11/gdkwindow-x11.c b/gdk/x11/gdkwindow-x11.c index 3683e42075..4773885823 100644 --- a/gdk/x11/gdkwindow-x11.c +++ b/gdk/x11/gdkwindow-x11.c @@ -343,6 +343,7 @@ _gdk_windowing_window_init (GdkScreen * screen) static void set_wm_protocols (GdkWindow *window) { + GdkWindowObject *private = (GdkWindowObject *)window; GdkDisplay *display = gdk_drawable_get_display (window); Atom protocols[3]; @@ -463,6 +464,8 @@ gdk_window_new (GdkWindow *parent, private->parent = (GdkWindowObject *)parent; + private->accept_focus = TRUE; + xattributes_mask = 0; if (attributes_mask & GDK_WA_X) @@ -989,8 +992,8 @@ update_wm_hints (GdkWindow *window, private->state & GDK_WINDOW_STATE_WITHDRAWN) return; - wm_hints.flags = StateHint; - wm_hints.input = True; + wm_hints.flags = StateHint | InputHint; + wm_hints.input = private->accept_focus ? True : False; wm_hints.initial_state = NormalState; if (private->state & GDK_WINDOW_STATE_ICONIFIED) @@ -3223,6 +3226,40 @@ gdk_window_set_override_redirect (GdkWindow *window, } } +/** + * gdk_window_set_accept_focus: + * @window: a toplevel #GdkWindow + * @accept_focus: %TRUE if the window should receive input focus + * + * Setting @accept_focus to %FALSE hints the desktop environment that the + * window doesn't want to receive input focus. + * + * On X, it is the responsibility of the window manager to interpret this + * hint. ICCCM-compliant window manager usually respect it. + * + * Since: 2.4 + **/ +void +gdk_window_set_accept_focus (GdkWindow *window, + gboolean accept_focus) +{ + GdkWindowObject *private; + g_return_if_fail (window != NULL); + g_return_if_fail (GDK_IS_WINDOW (window)); + + private = (GdkWindowObject *)window; + + accept_focus = accept_focus != FALSE; + + if (private->accept_focus != accept_focus) + { + private->accept_focus = accept_focus; + + if (!GDK_WINDOW_DESTROYED (window)) + update_wm_hints (window, FALSE); + } +} + /** * gdk_window_set_icon_list: |