aboutsummaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
Diffstat (limited to 'main.c')
-rw-r--r--main.c48
1 files changed, 5 insertions, 43 deletions
diff --git a/main.c b/main.c
index b30edbf..3bc0f0a 100644
--- a/main.c
+++ b/main.c
@@ -525,6 +525,9 @@ void keypress(struct menu_state *state, enum wl_keyboard_key_state key_state,
case XKB_KEY_g:
sym = XKB_KEY_Escape;
break;
+ case XKB_KEY_bracketleft:
+ sym = XKB_KEY_Escape;
+ break;
case XKB_KEY_h:
sym = XKB_KEY_BackSpace;
break;
@@ -641,48 +644,8 @@ void keypress(struct menu_state *state, enum wl_keyboard_key_state key_state,
break;
case XKB_KEY_Left:
case XKB_KEY_KP_Left:
- if (state->vertical) {
- break;
- }
- if (state->cursor && (!state->selection || !state->selection->left)) {
- state->cursor = nextrune(state, -1);
- render_frame(state);
- }
- if (state->selection && state->selection->left) {
- if (state->selection == state->leftmost) {
- state->rightmost = state->selection->left;
- state->leftmost = NULL;
- }
- state->selection = state->selection->left;
- scroll_matches(state);
- render_frame(state);
- }
- break;
- case XKB_KEY_Right:
- case XKB_KEY_KP_Right:
- if (state->vertical) {
- break;
- }
- if (state->cursor < len) {
- state->cursor = nextrune(state, +1);
- render_frame(state);
- } else if (state->cursor == len) {
- if (state->selection && state->selection->right) {
- if (state->selection == state->rightmost) {
- state->leftmost = state->selection->right;
- state->rightmost = NULL;
- }
- state->selection = state->selection->right;
- scroll_matches(state);
- render_frame(state);
- }
- }
- break;
case XKB_KEY_Up:
case XKB_KEY_KP_Up:
- if (!state->vertical) {
- break;
- }
if (state->cursor && (!state->selection || !state->selection->left)) {
state->cursor = nextrune(state, -1);
render_frame(state);
@@ -697,11 +660,10 @@ void keypress(struct menu_state *state, enum wl_keyboard_key_state key_state,
render_frame(state);
}
break;
+ case XKB_KEY_Right:
+ case XKB_KEY_KP_Right:
case XKB_KEY_Down:
case XKB_KEY_KP_Down:
- if (!state->vertical) {
- break;
- }
if (state->cursor < len) {
state->cursor = nextrune(state, +1);
render_frame(state);