make menu input work with the new obt keyboard stuff.
create an Input Context for use during keyboard grabs, and use this to translate KeyPress events properly. make the menu respond to KeyPress events, since these are the only ones that can be translated properly, but still execute things from KeyRelease events
This commit is contained in:
parent
62f8a5c49b
commit
08269cefbc
5 changed files with 35 additions and 3 deletions
|
@ -1782,6 +1782,9 @@ static gboolean event_handle_menu_input(XEvent *ev)
|
||||||
frame->press_keycode = ev->xkey.keycode;
|
frame->press_keycode = ev->xkey.keycode;
|
||||||
frame->press_doexec = FALSE;
|
frame->press_doexec = FALSE;
|
||||||
|
|
||||||
|
unikey = obt_keyboard_keypress_to_unichar(menu_frame_ic(frame),
|
||||||
|
&ev->xkey);
|
||||||
|
|
||||||
if (ob_keycode_match(ev->xkey.keycode, OB_KEY_ESCAPE)) {
|
if (ob_keycode_match(ev->xkey.keycode, OB_KEY_ESCAPE)) {
|
||||||
menu_frame_hide_all();
|
menu_frame_hide_all();
|
||||||
ret = TRUE;
|
ret = TRUE;
|
||||||
|
@ -1831,7 +1834,7 @@ static gboolean event_handle_menu_input(XEvent *ev)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* keyboard accelerator shortcuts. (if it was a valid key) */
|
/* keyboard accelerator shortcuts. (if it was a valid key) */
|
||||||
else if ((unikey = obt_keyboard_keypress_to_unichar(&ev->xkey))) {
|
else if (unikey) {
|
||||||
GList *start;
|
GList *start;
|
||||||
GList *it;
|
GList *it;
|
||||||
ObMenuEntryFrame *found = NULL;
|
ObMenuEntryFrame *found = NULL;
|
||||||
|
|
|
@ -40,6 +40,7 @@ static guint pgrabs = 0;
|
||||||
/*! The time at which the last grab was made */
|
/*! The time at which the last grab was made */
|
||||||
static Time grab_time = CurrentTime;
|
static Time grab_time = CurrentTime;
|
||||||
static gint passive_count = 0;
|
static gint passive_count = 0;
|
||||||
|
static ObtIC *ic = NULL;
|
||||||
|
|
||||||
static Time ungrab_time(void)
|
static Time ungrab_time(void)
|
||||||
{
|
{
|
||||||
|
@ -58,6 +59,11 @@ static Time ungrab_time(void)
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static Window grab_window(void)
|
||||||
|
{
|
||||||
|
return screen_support_win;
|
||||||
|
}
|
||||||
|
|
||||||
gboolean grab_on_keyboard(void)
|
gboolean grab_on_keyboard(void)
|
||||||
{
|
{
|
||||||
return kgrabs > 0;
|
return kgrabs > 0;
|
||||||
|
@ -68,13 +74,18 @@ gboolean grab_on_pointer(void)
|
||||||
return pgrabs > 0;
|
return pgrabs > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ObtIC *grab_input_context(void)
|
||||||
|
{
|
||||||
|
return ic;
|
||||||
|
}
|
||||||
|
|
||||||
gboolean grab_keyboard_full(gboolean grab)
|
gboolean grab_keyboard_full(gboolean grab)
|
||||||
{
|
{
|
||||||
gboolean ret = FALSE;
|
gboolean ret = FALSE;
|
||||||
|
|
||||||
if (grab) {
|
if (grab) {
|
||||||
if (kgrabs++ == 0) {
|
if (kgrabs++ == 0) {
|
||||||
ret = XGrabKeyboard(obt_display, obt_root(ob_screen),
|
ret = XGrabKeyboard(obt_display, grab_window(),
|
||||||
False, GrabModeAsync, GrabModeAsync,
|
False, GrabModeAsync, GrabModeAsync,
|
||||||
event_curtime) == Success;
|
event_curtime) == Success;
|
||||||
if (!ret)
|
if (!ret)
|
||||||
|
@ -102,7 +113,7 @@ gboolean grab_pointer_full(gboolean grab, gboolean owner_events,
|
||||||
|
|
||||||
if (grab) {
|
if (grab) {
|
||||||
if (pgrabs++ == 0) {
|
if (pgrabs++ == 0) {
|
||||||
ret = XGrabPointer(obt_display, screen_support_win, owner_events,
|
ret = XGrabPointer(obt_display, grab_window(), owner_events,
|
||||||
GRAB_PTR_MASK,
|
GRAB_PTR_MASK,
|
||||||
GrabModeAsync, GrabModeAsync,
|
GrabModeAsync, GrabModeAsync,
|
||||||
(confine ? obt_root(ob_screen) : None),
|
(confine ? obt_root(ob_screen) : None),
|
||||||
|
@ -157,10 +168,15 @@ void grab_startup(gboolean reconfig)
|
||||||
mask_list[i++] = caps | scroll;
|
mask_list[i++] = caps | scroll;
|
||||||
mask_list[i++] = num | caps | scroll;
|
mask_list[i++] = num | caps | scroll;
|
||||||
g_assert(i == MASK_LIST_SIZE);
|
g_assert(i == MASK_LIST_SIZE);
|
||||||
|
|
||||||
|
ic = obt_keyboard_context_new(obt_root(ob_screen), grab_window());
|
||||||
}
|
}
|
||||||
|
|
||||||
void grab_shutdown(gboolean reconfig)
|
void grab_shutdown(gboolean reconfig)
|
||||||
{
|
{
|
||||||
|
obt_keyboard_context_unref(ic);
|
||||||
|
ic = NULL;
|
||||||
|
|
||||||
if (reconfig) return;
|
if (reconfig) return;
|
||||||
|
|
||||||
while (ungrab_keyboard());
|
while (ungrab_keyboard());
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#define __grab_h
|
#define __grab_h
|
||||||
|
|
||||||
#include "misc.h"
|
#include "misc.h"
|
||||||
|
#include "obt/keyboard.h"
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
|
@ -27,6 +28,8 @@
|
||||||
void grab_startup(gboolean reconfig);
|
void grab_startup(gboolean reconfig);
|
||||||
void grab_shutdown(gboolean reconfig);
|
void grab_shutdown(gboolean reconfig);
|
||||||
|
|
||||||
|
ObtIC *grab_input_context(void);
|
||||||
|
|
||||||
gboolean grab_keyboard_full(gboolean grab);
|
gboolean grab_keyboard_full(gboolean grab);
|
||||||
/*! @param confine If true the pointer is confined to the screen */
|
/*! @param confine If true the pointer is confined to the screen */
|
||||||
gboolean grab_pointer_full(gboolean grab, gboolean owner_events,
|
gboolean grab_pointer_full(gboolean grab, gboolean owner_events,
|
||||||
|
|
|
@ -155,6 +155,13 @@ void menu_frame_free(ObMenuFrame *self)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ObtIC* menu_frame_ic(ObMenuFrame *self)
|
||||||
|
{
|
||||||
|
/* menus are always used through a grab right now, so they can always use
|
||||||
|
the grab input context */
|
||||||
|
return grab_input_context();
|
||||||
|
}
|
||||||
|
|
||||||
static ObMenuEntryFrame* menu_entry_frame_new(ObMenuEntry *entry,
|
static ObMenuEntryFrame* menu_entry_frame_new(ObMenuEntry *entry,
|
||||||
ObMenuFrame *frame)
|
ObMenuFrame *frame)
|
||||||
{
|
{
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include "geom.h"
|
#include "geom.h"
|
||||||
#include "window.h"
|
#include "window.h"
|
||||||
#include "obrender/render.h"
|
#include "obrender/render.h"
|
||||||
|
#include "obt/keyboard.h"
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
|
@ -113,6 +114,8 @@ ObMenuFrame* menu_frame_new(struct _ObMenu *menu,
|
||||||
struct _ObClient *client);
|
struct _ObClient *client);
|
||||||
void menu_frame_free(ObMenuFrame *self);
|
void menu_frame_free(ObMenuFrame *self);
|
||||||
|
|
||||||
|
ObtIC* menu_frame_ic(ObMenuFrame *self);
|
||||||
|
|
||||||
void menu_frame_move(ObMenuFrame *self, gint x, gint y);
|
void menu_frame_move(ObMenuFrame *self, gint x, gint y);
|
||||||
void menu_frame_move_on_screen(ObMenuFrame *self, gint x, gint y,
|
void menu_frame_move_on_screen(ObMenuFrame *self, gint x, gint y,
|
||||||
gint *dx, gint *dy);
|
gint *dx, gint *dy);
|
||||||
|
|
Loading…
Reference in a new issue