Clean up shortcuts

This commit is contained in:
Moritz Lipp 2010-06-19 10:33:36 +02:00
parent fcceffa973
commit d631c27f8c
2 changed files with 71 additions and 69 deletions

View file

@ -63,37 +63,42 @@ int adjust_open = ADJUST_BESTFIT;
/* shortcuts */ /* shortcuts */
Shortcut shortcuts[] = { Shortcut shortcuts[] = {
/* mask, key, function, mode, argument */ /* mask, key, function, mode, argument */
{GDK_CONTROL_MASK, GDK_n, sc_toggle_statusbar, NORMAL, {0} }, {GDK_CONTROL_MASK, GDK_c, sc_abort, ALL, {0} },
{GDK_CONTROL_MASK, GDK_m, sc_toggle_inputbar, NORMAL, {0} }, {0, GDK_a, sc_adjust_window, NORMAL, { ADJUST_BESTFIT } },
{0, GDK_F5, sc_toggle_fullscreen, NORMAL, {0} }, {0, GDK_s, sc_adjust_window, NORMAL, { ADJUST_WIDTH } },
{GDK_CONTROL_MASK, GDK_q, sc_quit, -1, {0} }, {0, GDK_Escape, sc_abort, ALL, {0} },
{GDK_CONTROL_MASK, GDK_c, sc_abort, -1, {0} }, {0, GDK_BackSpace, sc_change_buffer, ALL, { DELETE_LAST } },
{GDK_CONTROL_MASK, GDK_i, sc_recolor, NORMAL, {0} },
{GDK_CONTROL_MASK, GDK_d, sc_scroll, NORMAL, { HALF_DOWN } },
{GDK_CONTROL_MASK, GDK_u, sc_scroll, NORMAL, { HALF_UP } },
{GDK_CONTROL_MASK, GDK_f, sc_scroll, NORMAL, { FULL_DOWN } },
{GDK_CONTROL_MASK, GDK_b, sc_scroll, NORMAL, { FULL_UP } },
{0, GDK_slash, sc_focus_inputbar, NORMAL, { .data = "/" } },
{GDK_SHIFT_MASK, GDK_slash, sc_focus_inputbar, NORMAL, { .data = "/" } },
{GDK_SHIFT_MASK, GDK_question, sc_focus_inputbar, NORMAL, { .data = "?" } },
{0, GDK_Tab, sc_toggle_index, NORMAL, {0} },
{0, GDK_Tab, sc_toggle_index, INDEX, {0} },
{0, GDK_J, sc_navigate, NORMAL, { NEXT } },
{0, GDK_K, sc_navigate, NORMAL, { PREVIOUS } },
{GDK_MOD1_MASK, GDK_Right, sc_navigate, NORMAL, { NEXT } },
{GDK_MOD1_MASK, GDK_Left, sc_navigate, NORMAL, { PREVIOUS } },
{0, GDK_O, sc_switch_goto_mode, NORMAL, {0} },
{0, GDK_space, sc_navigate, NORMAL, { NEXT } },
{0, GDK_Escape, sc_abort, -1, {0} },
{0, GDK_i, sc_change_mode, NORMAL, { INSERT } }, {0, GDK_i, sc_change_mode, NORMAL, { INSERT } },
{0, GDK_v, sc_change_mode, NORMAL, { VISUAL } }, {0, GDK_v, sc_change_mode, NORMAL, { VISUAL } },
{0, GDK_m, sc_change_mode, NORMAL, { ADD_MARKER } }, {0, GDK_m, sc_change_mode, NORMAL, { ADD_MARKER } },
{0, GDK_apostrophe, sc_change_mode, NORMAL, { EVAL_MARKER } }, {0, GDK_apostrophe, sc_change_mode, NORMAL, { EVAL_MARKER } },
{0, GDK_slash, sc_focus_inputbar, NORMAL, { .data = "/" } },
{GDK_SHIFT_MASK, GDK_slash, sc_focus_inputbar, NORMAL, { .data = "/" } },
{GDK_SHIFT_MASK, GDK_question, sc_focus_inputbar, NORMAL, { .data = "?" } },
{0, GDK_colon, sc_focus_inputbar, NORMAL, { .data = ":" } }, {0, GDK_colon, sc_focus_inputbar, NORMAL, { .data = ":" } },
{0, GDK_o, sc_focus_inputbar, NORMAL, { .data = ":open " } }, {0, GDK_o, sc_focus_inputbar, NORMAL, { .data = ":open " } },
{0, GDK_f, sc_follow, NORMAL, {0} }, {0, GDK_f, sc_follow, NORMAL, {0} },
{0, GDK_r, sc_rotate, NORMAL, {0} }, {0, GDK_J, sc_navigate, NORMAL, { NEXT } },
{0, GDK_K, sc_navigate, NORMAL, { PREVIOUS } },
{GDK_MOD1_MASK, GDK_Right, sc_navigate, NORMAL, { NEXT } },
{GDK_MOD1_MASK, GDK_Left, sc_navigate, NORMAL, { PREVIOUS } },
{0, GDK_space, sc_navigate, NORMAL, { NEXT } },
{0, GDK_Left, sc_navigate, FULLSCREEN, { PREVIOUS } },
{0, GDK_Up, sc_navigate, FULLSCREEN, { PREVIOUS } },
{0, GDK_Down, sc_navigate, FULLSCREEN, { NEXT } },
{0, GDK_Right, sc_navigate, FULLSCREEN, { NEXT } },
{0, GDK_space, sc_navigate, FULLSCREEN, { NEXT } },
{0, GDK_k, sc_navigate_index, INDEX, { UP } },
{0, GDK_j, sc_navigate_index, INDEX, { DOWN } },
{0, GDK_h, sc_navigate_index, INDEX, { COLLAPSE } },
{0, GDK_l, sc_navigate_index, INDEX, { EXPAND } },
{0, GDK_space, sc_navigate_index, INDEX, { SELECT } },
{0, GDK_Return, sc_navigate_index, INDEX, { SELECT } },
{GDK_CONTROL_MASK, GDK_i, sc_recolor, NORMAL, {0} },
{0, GDK_R, sc_reload, NORMAL, {0} }, {0, GDK_R, sc_reload, NORMAL, {0} },
{0, GDK_r, sc_rotate, NORMAL, {0} },
{0, GDK_n, sc_search, NORMAL, { FORWARD } },
{0, GDK_N, sc_search, NORMAL, { BACKWARD } },
{0, GDK_h, sc_scroll, NORMAL, { LEFT } }, {0, GDK_h, sc_scroll, NORMAL, { LEFT } },
{0, GDK_j, sc_scroll, NORMAL, { DOWN } }, {0, GDK_j, sc_scroll, NORMAL, { DOWN } },
{0, GDK_k, sc_scroll, NORMAL, { UP } }, {0, GDK_k, sc_scroll, NORMAL, { UP } },
@ -102,23 +107,16 @@ Shortcut shortcuts[] = {
{0, GDK_Up, sc_scroll, NORMAL, { UP } }, {0, GDK_Up, sc_scroll, NORMAL, { UP } },
{0, GDK_Down, sc_scroll, NORMAL, { DOWN } }, {0, GDK_Down, sc_scroll, NORMAL, { DOWN } },
{0, GDK_Right, sc_scroll, NORMAL, { RIGHT } }, {0, GDK_Right, sc_scroll, NORMAL, { RIGHT } },
{0, GDK_n, sc_search, NORMAL, { FORWARD } }, {GDK_CONTROL_MASK, GDK_d, sc_scroll, NORMAL, { HALF_DOWN } },
{0, GDK_N, sc_search, NORMAL, { BACKWARD } }, {GDK_CONTROL_MASK, GDK_u, sc_scroll, NORMAL, { HALF_UP } },
{0, GDK_a, sc_adjust_window, NORMAL, { ADJUST_BESTFIT } }, {GDK_CONTROL_MASK, GDK_f, sc_scroll, NORMAL, { FULL_DOWN } },
{0, GDK_s, sc_adjust_window, NORMAL, { ADJUST_WIDTH } }, {GDK_CONTROL_MASK, GDK_b, sc_scroll, NORMAL, { FULL_UP } },
{0, GDK_BackSpace, sc_change_buffer, -1, { DELETE_LAST } }, {0, GDK_O, sc_switch_goto_mode, NORMAL, {0} },
{0, GDK_k, sc_navigate_index, INDEX, { UP } }, {0, GDK_F5, sc_toggle_fullscreen, NORMAL | FULLSCREEN, {0} },
{0, GDK_j, sc_navigate_index, INDEX, { DOWN } }, {0, GDK_Tab, sc_toggle_index, NORMAL | INDEX, {0} },
{0, GDK_h, sc_navigate_index, INDEX, { COLLAPSE } }, {GDK_CONTROL_MASK, GDK_m, sc_toggle_inputbar, NORMAL, {0} },
{0, GDK_l, sc_navigate_index, INDEX, { EXPAND } }, {GDK_CONTROL_MASK, GDK_n, sc_toggle_statusbar, NORMAL, {0} },
{0, GDK_space, sc_navigate_index, INDEX, { SELECT } }, {GDK_CONTROL_MASK, GDK_q, sc_quit, ALL, {0} },
{0, GDK_Return, sc_navigate_index, INDEX, { SELECT } },
{0, GDK_F5, sc_toggle_fullscreen, FULLSCREEN, {0} },
{0, GDK_Left, sc_navigate, FULLSCREEN, { PREVIOUS } },
{0, GDK_Up, sc_navigate, FULLSCREEN, { PREVIOUS } },
{0, GDK_Down, sc_navigate, FULLSCREEN, { NEXT } },
{0, GDK_Right, sc_navigate, FULLSCREEN, { NEXT } },
{0, GDK_space, sc_navigate, FULLSCREEN, { NEXT } },
}; };
/* inputbar shortcuts */ /* inputbar shortcuts */
@ -279,7 +277,7 @@ ArgumentName argument_names[] = {
/* mode names */ /* mode names */
ModeName mode_names[] = { ModeName mode_names[] = {
{"all", -1}, {"all", ALL},
{"fullscreen", FULLSCREEN}, {"fullscreen", FULLSCREEN},
{"index", INDEX}, {"index", INDEX},
{"insert", INSERT}, {"insert", INSERT},

View file

@ -19,16 +19,20 @@
#define LENGTH(x) sizeof(x)/sizeof((x)[0]) #define LENGTH(x) sizeof(x)/sizeof((x)[0])
/* enums */ /* enums */
enum { NEXT, PREVIOUS, LEFT, RIGHT, UP, DOWN, enum { NEXT, PREVIOUS, LEFT, RIGHT, UP, DOWN, BOTTOM, TOP, HIDE, HIGHLIGHT,
BOTTOM, TOP, HIDE, NORMAL, HIGHLIGHT, DELETE_LAST_WORD, DEFAULT, ERROR, WARNING, NEXT_GROUP, PREVIOUS_GROUP,
INSERT, VISUAL, DELETE_LAST_WORD, DEFAULT, ZOOM_IN, ZOOM_OUT, ZOOM_ORIGINAL, ZOOM_SPECIFIC, FORWARD, BACKWARD,
ERROR, WARNING, NEXT_GROUP, PREVIOUS_GROUP, ADJUST_BESTFIT, ADJUST_WIDTH, ADJUST_NONE, CONTINUOUS, DELETE_LAST,
ZOOM_IN, ZOOM_OUT, ZOOM_ORIGINAL, ZOOM_SPECIFIC, ADD_MARKER, EVAL_MARKER, EXPAND, COLLAPSE, SELECT, GOTO_DEFAULT, GOTO_LABELS,
FORWARD, BACKWARD, ADJUST_BESTFIT, ADJUST_WIDTH, GOTO_OFFSET, HALF_UP, HALF_DOWN, FULL_UP, FULL_DOWN };
ADJUST_NONE, CONTINUOUS, DELETE_LAST, ADD_MARKER,
EVAL_MARKER, INDEX, EXPAND, COLLAPSE, SELECT, /* define modes */
GOTO_DEFAULT, GOTO_LABELS, GOTO_OFFSET, FULLSCREEN, #define ALL (1 << 0)
HALF_UP, HALF_DOWN, FULL_UP, FULL_DOWN }; #define FULLSCREEN (1 << 1)
#define INDEX (1 << 2)
#define INSERT (1 << 3)
#define NORMAL (1 << 4)
#define VISUAL (1 << 5)
/* typedefs */ /* typedefs */
struct CElement struct CElement
@ -3876,7 +3880,7 @@ cb_view_kb_pressed(GtkWidget *widget, GdkEventKey *event, gpointer data)
if( event->keyval == sc->element.key && if( event->keyval == sc->element.key &&
((event->state == sc->element.mask) || ((event->state == sc->element.mask) ||
((sc->element.mask == 0) && (sc->element.key >= 20 && sc->element.key <= 126))) && ((sc->element.mask == 0) && (sc->element.key >= 20 && sc->element.key <= 126))) &&
(Zathura.Global.mode == sc->element.mode || sc->element.mode == -1) && (Zathura.Global.mode & sc->element.mode || sc->element.mode == ALL) &&
sc->element.function sc->element.function
) )
{ {