mirror of
https://github.com/brl/mutter.git
synced 2024-11-25 09:30:45 -05:00
rename from {un}grab_all_keys_and_keyboard and only do an XKeyboardGrab,
2002-07-02 Mark McLoughlin <mark@skynet.ie> * src/keybindings.c: (grab_keyboard), (ungrab_keyboard): rename from {un}grab_all_keys_and_keyboard and only do an XKeyboardGrab, the XKeyGrab isn't neccessary. (meta_screen_grab_all_keys), (meta_screen_ungrab_all_keys), (meta_window_grab_all_keys), (meta_window_ungrab_all_keys): update for above change. (handle_workspace_switch): don't use a MetaWindow when workspace switching, use the root window instead.
This commit is contained in:
parent
086f3d807e
commit
b6177f74a7
12
ChangeLog
12
ChangeLog
@ -1,3 +1,15 @@
|
|||||||
|
2002-07-02 Mark McLoughlin <mark@skynet.ie>
|
||||||
|
|
||||||
|
* src/keybindings.c:
|
||||||
|
(grab_keyboard), (ungrab_keyboard): rename from
|
||||||
|
{un}grab_all_keys_and_keyboard and only do an XKeyboardGrab,
|
||||||
|
the XKeyGrab isn't neccessary.
|
||||||
|
(meta_screen_grab_all_keys), (meta_screen_ungrab_all_keys),
|
||||||
|
(meta_window_grab_all_keys), (meta_window_ungrab_all_keys):
|
||||||
|
update for above change.
|
||||||
|
(handle_workspace_switch): don't use a MetaWindow when
|
||||||
|
workspace switching, use the root window instead.
|
||||||
|
|
||||||
2002-07-01 Mark McLoughlin <mark@skynet.ie>
|
2002-07-01 Mark McLoughlin <mark@skynet.ie>
|
||||||
|
|
||||||
Fix broken workspace switching from my previous commit.
|
Fix broken workspace switching from my previous commit.
|
||||||
|
@ -785,25 +785,12 @@ meta_window_ungrab_keys (MetaWindow *window)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
grab_all_keys_and_keyboard (MetaDisplay *display,
|
grab_keyboard (MetaDisplay *display,
|
||||||
Window xwindow)
|
Window xwindow)
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
meta_error_trap_push (display);
|
/* Grab the keyboard, so we get key releases and all key
|
||||||
XGrabKey (display->xdisplay, AnyKey, AnyModifier,
|
|
||||||
xwindow, True,
|
|
||||||
GrabModeAsync, GrabModeAsync);
|
|
||||||
|
|
||||||
result = meta_error_trap_pop (display);
|
|
||||||
if (result != Success)
|
|
||||||
{
|
|
||||||
meta_topic (META_DEBUG_KEYBINDINGS,
|
|
||||||
"Global key grab failed\n");
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Also grab the keyboard, so we get key releases and all key
|
|
||||||
* presses
|
* presses
|
||||||
*/
|
*/
|
||||||
meta_error_trap_push (display);
|
meta_error_trap_push (display);
|
||||||
@ -827,17 +814,13 @@ grab_all_keys_and_keyboard (MetaDisplay *display,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ungrab_all_keys_and_keyboard (MetaDisplay *display,
|
ungrab_keyboard (MetaDisplay *display)
|
||||||
Window xwindow)
|
|
||||||
{
|
{
|
||||||
Time timestamp;
|
Time timestamp;
|
||||||
|
|
||||||
timestamp = meta_display_get_current_time (display);
|
timestamp = meta_display_get_current_time (display);
|
||||||
|
|
||||||
meta_error_trap_push (display);
|
meta_error_trap_push (display);
|
||||||
XUngrabKey (display->xdisplay,
|
|
||||||
AnyKey, AnyModifier,
|
|
||||||
xwindow);
|
|
||||||
|
|
||||||
meta_topic (META_DEBUG_KEYBINDINGS,
|
meta_topic (META_DEBUG_KEYBINDINGS,
|
||||||
"Ungrabbing keyboard with timestamp %lu\n",
|
"Ungrabbing keyboard with timestamp %lu\n",
|
||||||
@ -859,8 +842,7 @@ meta_screen_grab_all_keys (MetaScreen *screen)
|
|||||||
|
|
||||||
meta_topic (META_DEBUG_KEYBINDINGS,
|
meta_topic (META_DEBUG_KEYBINDINGS,
|
||||||
"Grabbing all keys on RootWindow\n");
|
"Grabbing all keys on RootWindow\n");
|
||||||
retval = grab_all_keys_and_keyboard (screen->display,
|
retval = grab_keyboard (screen->display, screen->xroot);
|
||||||
screen->xroot);
|
|
||||||
if (retval)
|
if (retval)
|
||||||
screen->all_keys_grabbed = TRUE;
|
screen->all_keys_grabbed = TRUE;
|
||||||
else
|
else
|
||||||
@ -874,8 +856,7 @@ meta_screen_ungrab_all_keys (MetaScreen *screen)
|
|||||||
{
|
{
|
||||||
if (screen->all_keys_grabbed)
|
if (screen->all_keys_grabbed)
|
||||||
{
|
{
|
||||||
ungrab_all_keys_and_keyboard (screen->display,
|
ungrab_keyboard (screen->display);
|
||||||
screen->xroot);
|
|
||||||
|
|
||||||
screen->all_keys_grabbed = FALSE;
|
screen->all_keys_grabbed = FALSE;
|
||||||
screen->keys_grabbed = FALSE;
|
screen->keys_grabbed = FALSE;
|
||||||
@ -910,7 +891,7 @@ meta_window_grab_all_keys (MetaWindow *window)
|
|||||||
|
|
||||||
meta_topic (META_DEBUG_KEYBINDINGS,
|
meta_topic (META_DEBUG_KEYBINDINGS,
|
||||||
"Grabbing all keys on window %s\n", window->desc);
|
"Grabbing all keys on window %s\n", window->desc);
|
||||||
retval = grab_all_keys_and_keyboard (window->display, grabwindow);
|
retval = grab_keyboard (window->display, grabwindow);
|
||||||
if (retval)
|
if (retval)
|
||||||
{
|
{
|
||||||
window->keys_grabbed = FALSE;
|
window->keys_grabbed = FALSE;
|
||||||
@ -926,12 +907,7 @@ meta_window_ungrab_all_keys (MetaWindow *window)
|
|||||||
{
|
{
|
||||||
if (window->all_keys_grabbed)
|
if (window->all_keys_grabbed)
|
||||||
{
|
{
|
||||||
Window grabwindow;
|
ungrab_keyboard (window->display);
|
||||||
|
|
||||||
grabwindow = (window->frame && window->grab_on_frame) ?
|
|
||||||
window->frame->xwindow : window->xwindow;
|
|
||||||
|
|
||||||
ungrab_all_keys_and_keyboard (window->display, grabwindow);
|
|
||||||
|
|
||||||
window->grab_on_frame = FALSE;
|
window->grab_on_frame = FALSE;
|
||||||
window->all_keys_grabbed = FALSE;
|
window->all_keys_grabbed = FALSE;
|
||||||
@ -2336,26 +2312,12 @@ handle_workspace_switch (MetaDisplay *display,
|
|||||||
if (screen == NULL)
|
if (screen == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* FIXME this is all broken, that you need a window to grab on.
|
|
||||||
* There's no reason we need a window here, in fact it's broken
|
|
||||||
* that you have to have one.
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (display->focus_window != NULL)
|
|
||||||
{
|
|
||||||
window = display->focus_window;
|
|
||||||
}
|
|
||||||
else if (window == NULL)
|
|
||||||
{
|
|
||||||
window = get_previous_focus_window (display, screen);
|
|
||||||
}
|
|
||||||
|
|
||||||
meta_topic (META_DEBUG_KEYBINDINGS,
|
meta_topic (META_DEBUG_KEYBINDINGS,
|
||||||
"Starting tab between workspaces, showing popup\n");
|
"Starting tab between workspaces, showing popup\n");
|
||||||
|
|
||||||
if (meta_display_begin_grab_op (display,
|
if (meta_display_begin_grab_op (display,
|
||||||
screen,
|
screen,
|
||||||
window,
|
NULL,
|
||||||
META_GRAB_OP_KEYBOARD_WORKSPACE_SWITCHING,
|
META_GRAB_OP_KEYBOARD_WORKSPACE_SWITCHING,
|
||||||
FALSE,
|
FALSE,
|
||||||
0,
|
0,
|
||||||
@ -2365,16 +2327,13 @@ handle_workspace_switch (MetaDisplay *display,
|
|||||||
{
|
{
|
||||||
MetaWorkspace *next;
|
MetaWorkspace *next;
|
||||||
|
|
||||||
next = meta_workspace_get_neighbor (window->screen->active_workspace,
|
next = meta_workspace_get_neighbor (screen->active_workspace, motion);
|
||||||
motion);
|
|
||||||
g_assert (next);
|
g_assert (next);
|
||||||
|
|
||||||
meta_ui_tab_popup_select (window->screen->tab_popup,
|
meta_ui_tab_popup_select (screen->tab_popup, (MetaTabEntryKey) next);
|
||||||
(MetaTabEntryKey) next);
|
|
||||||
|
|
||||||
/* only after selecting proper window */
|
/* only after selecting proper window */
|
||||||
meta_ui_tab_popup_set_showing (window->screen->tab_popup,
|
meta_ui_tab_popup_set_showing (screen->tab_popup, TRUE);
|
||||||
TRUE);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user