diff options
author | Jari Vetoniemi <mailroxas@gmail.com> | 2014-11-02 04:08:40 +0200 |
---|---|---|
committer | Jari Vetoniemi <mailroxas@gmail.com> | 2014-11-02 04:08:40 +0200 |
commit | ee3c41f162a9068505efdb5025c415b889cf414d (patch) | |
tree | 472e4949c6e0f22377d4fd5db1d1d5a889a4ed7f /lib/menu.c | |
parent | a3e628f1c9f3e7ddfd447d599611729aefc736bb (diff) | |
download | bemenu-ee3c41f162a9068505efdb5025c415b889cf414d.tar.gz bemenu-ee3c41f162a9068505efdb5025c415b889cf414d.tar.bz2 bemenu-ee3c41f162a9068505efdb5025c415b889cf414d.zip |
Make shift + tab the current tab behavior, and normal tab to cycle.
Diffstat (limited to 'lib/menu.c')
-rw-r--r-- | lib/menu.c | 22 |
1 files changed, 14 insertions, 8 deletions
@@ -485,21 +485,21 @@ bm_menu_poll_key(struct bm_menu *menu, uint32_t *out_unicode) } static void -menu_next(struct bm_menu *menu, uint32_t count) +menu_next(struct bm_menu *menu, uint32_t count, bool wrap) { if (menu->index < count - 1) { menu->index++; - } else if (menu->wrap) { + } else if (wrap) { menu->index = 0; } } static void -menu_prev(struct bm_menu *menu, uint32_t count) +menu_prev(struct bm_menu *menu, uint32_t count, bool wrap) { if (menu->index > 0) { menu->index--; - } else if (menu->wrap) { + } else if (wrap) { menu->index = count - 1; } } @@ -526,7 +526,7 @@ bm_menu_run_with_key(struct bm_menu *menu, enum bm_key key, uint32_t unicode) menu->cursor -= bm_utf8_rune_prev(menu->filter, menu->cursor); menu->curses_cursor -= bm_utf8_rune_width(menu->filter + menu->cursor, oldCursor - menu->cursor); } else if (menu->lines == 0) { - menu_prev(menu, count); + menu_prev(menu, count, menu->wrap); } break; @@ -536,7 +536,7 @@ bm_menu_run_with_key(struct bm_menu *menu, enum bm_key key, uint32_t unicode) menu->cursor += bm_utf8_rune_next(menu->filter, menu->cursor); menu->curses_cursor += bm_utf8_rune_width(menu->filter + oldCursor, menu->cursor - oldCursor); } else if (menu->lines == 0) { - menu_next(menu, count); + menu_next(menu, count, menu->wrap); } break; @@ -550,11 +550,11 @@ bm_menu_run_with_key(struct bm_menu *menu, enum bm_key key, uint32_t unicode) break; case BM_KEY_UP: - menu_prev(menu, count); + menu_prev(menu, count, menu->wrap); break; case BM_KEY_DOWN: - menu_next(menu, count); + menu_next(menu, count, menu->wrap); break; case BM_KEY_PAGE_UP: @@ -631,6 +631,12 @@ bm_menu_run_with_key(struct bm_menu *menu, enum bm_key key, uint32_t unicode) case BM_KEY_TAB: { + menu_next(menu, count, true); + } + break; + + case BM_KEY_SHIFT_TAB: + { const char *text; struct bm_item *highlighted = bm_menu_get_highlighted_item(menu); if (highlighted && (text = bm_item_get_text(highlighted))) { |