mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-01 00:54:24 +03:00
Ticket #212: implement keybinding for menu.
Signed-off-by: Ilia Maslakov <il.smind@gmail.com> Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
71c0f7640d
commit
f5f78ea658
@ -13,6 +13,7 @@
|
|||||||
#define KEYMAP_SECTION_MAIN_EXT "main:xmap"
|
#define KEYMAP_SECTION_MAIN_EXT "main:xmap"
|
||||||
#define KEYMAP_SECTION_PANEL "panel"
|
#define KEYMAP_SECTION_PANEL "panel"
|
||||||
#define KEYMAP_SECTION_DIALOG "dialog"
|
#define KEYMAP_SECTION_DIALOG "dialog"
|
||||||
|
#define KEYMAP_SECTION_MENU "menu"
|
||||||
#define KEYMAP_SECTION_INPUT "input"
|
#define KEYMAP_SECTION_INPUT "input"
|
||||||
#define KEYMAP_SECTION_LISTBOX "listbox"
|
#define KEYMAP_SECTION_LISTBOX "listbox"
|
||||||
#define KEYMAP_SECTION_TREE "tree"
|
#define KEYMAP_SECTION_TREE "tree"
|
||||||
|
@ -39,12 +39,15 @@
|
|||||||
#include "lib/tty/tty.h"
|
#include "lib/tty/tty.h"
|
||||||
#include "lib/skin.h"
|
#include "lib/skin.h"
|
||||||
#include "lib/tty/key.h" /* key macros */
|
#include "lib/tty/key.h" /* key macros */
|
||||||
|
#include "lib/keybind.h" /* global_keymap_t */
|
||||||
#include "lib/strutil.h"
|
#include "lib/strutil.h"
|
||||||
#include "lib/widget.h"
|
#include "lib/widget.h"
|
||||||
#include "lib/event.h" /* mc_event_raise() */
|
#include "lib/event.h" /* mc_event_raise() */
|
||||||
|
|
||||||
/*** global variables ****************************************************************************/
|
/*** global variables ****************************************************************************/
|
||||||
|
|
||||||
|
const global_keymap_t *menu_map;
|
||||||
|
|
||||||
/*** file scope macro definitions ****************************************************************/
|
/*** file scope macro definitions ****************************************************************/
|
||||||
|
|
||||||
#define MENUENTRY(x) ((menu_entry_t *)(x))
|
#define MENUENTRY(x) ((menu_entry_t *)(x))
|
||||||
@ -449,23 +452,14 @@ menubar_last (WMenuBar * menubar)
|
|||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static int
|
static cb_ret_t
|
||||||
menubar_handle_key (WMenuBar * menubar, int key)
|
menubar_execute_cmd (WMenuBar * menubar, unsigned long command, int key)
|
||||||
{
|
{
|
||||||
/* Lowercase */
|
cb_ret_t ret = MSG_HANDLED;
|
||||||
if (isascii (key))
|
|
||||||
key = g_ascii_tolower (key);
|
|
||||||
|
|
||||||
if (is_abort_char (key))
|
switch (command)
|
||||||
{
|
{
|
||||||
menubar_finish (menubar);
|
case CK_Help:
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* menubar help or menubar navigation */
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case KEY_F (1):
|
|
||||||
{
|
{
|
||||||
ev_help_t event_data = { NULL, NULL };
|
ev_help_t event_data = { NULL, NULL };
|
||||||
|
|
||||||
@ -477,98 +471,64 @@ menubar_handle_key (WMenuBar * menubar, int key)
|
|||||||
|
|
||||||
mc_event_raise (MCEVENT_GROUP_CORE, "help", &event_data);
|
mc_event_raise (MCEVENT_GROUP_CORE, "help", &event_data);
|
||||||
menubar_draw (menubar);
|
menubar_draw (menubar);
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
case KEY_LEFT:
|
|
||||||
case XCTRL ('b'):
|
|
||||||
menubar_left (menubar);
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
case KEY_RIGHT:
|
|
||||||
case XCTRL ('f'):
|
|
||||||
menubar_right (menubar);
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
default:
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
if (!menubar->is_dropped)
|
case CK_Left:
|
||||||
{
|
menubar_left (menubar);
|
||||||
GList *i;
|
break;
|
||||||
|
case CK_Right:
|
||||||
/* drop menu by hotkey */
|
menubar_right (menubar);
|
||||||
for (i = menubar->menu; i != NULL; i = g_list_next (i))
|
break;
|
||||||
{
|
case CK_Up:
|
||||||
menu_t *menu = MENU (i->data);
|
if (menubar->is_dropped)
|
||||||
|
menubar_up (menubar);
|
||||||
if ((menu->text.hotkey != NULL) && (key == g_ascii_tolower (menu->text.hotkey[0])))
|
break;
|
||||||
{
|
case CK_Down:
|
||||||
menubar_drop (menubar, g_list_position (menubar->menu, i));
|
if (menubar->is_dropped)
|
||||||
return 1;
|
menubar_down (menubar);
|
||||||
}
|
else
|
||||||
}
|
|
||||||
|
|
||||||
/* drop menu by Enter or Dowwn key */
|
|
||||||
if (key == KEY_ENTER || key == XCTRL ('n') || key == KEY_DOWN || key == '\n')
|
|
||||||
menubar_drop (menubar, menubar->selected);
|
menubar_drop (menubar, menubar->selected);
|
||||||
|
break;
|
||||||
return 1;
|
case CK_Home:
|
||||||
}
|
if (menubar->is_dropped)
|
||||||
|
|
||||||
{
|
|
||||||
menu_t *menu = MENU (g_list_nth_data (menubar->menu, menubar->selected));
|
|
||||||
GList *i;
|
|
||||||
|
|
||||||
/* execute menu command by hotkey */
|
|
||||||
for (i = menu->entries; i != NULL; i = g_list_next (i))
|
|
||||||
{
|
|
||||||
const menu_entry_t *entry = MENUENTRY (i->data);
|
|
||||||
|
|
||||||
if ((entry != NULL) && (entry->command != CK_IgnoreKey)
|
|
||||||
&& (entry->text.hotkey != NULL) && (key == g_ascii_tolower (entry->text.hotkey[0])))
|
|
||||||
{
|
|
||||||
menu->selected = g_list_position (menu->entries, i);
|
|
||||||
menubar_execute (menubar);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* menu execute by Enter or menu navigation */
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case KEY_ENTER:
|
|
||||||
case '\n':
|
|
||||||
menubar_execute (menubar);
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
case KEY_HOME:
|
|
||||||
case ALT ('<'):
|
|
||||||
menubar_first (menubar);
|
menubar_first (menubar);
|
||||||
break;
|
break;
|
||||||
|
case CK_End:
|
||||||
case KEY_END:
|
if (menubar->is_dropped)
|
||||||
case ALT ('>'):
|
|
||||||
menubar_last (menubar);
|
menubar_last (menubar);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KEY_DOWN:
|
case CK_Enter:
|
||||||
case XCTRL ('n'):
|
if (menubar->is_dropped)
|
||||||
menubar_down (menubar);
|
menubar_execute (menubar);
|
||||||
|
else
|
||||||
|
menubar_drop (menubar, menubar->selected);
|
||||||
break;
|
break;
|
||||||
|
case CK_Quit:
|
||||||
case KEY_UP:
|
menubar_finish (menubar);
|
||||||
case XCTRL ('p'):
|
|
||||||
menubar_up (menubar);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
ret = MSG_NOT_HANDLED;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
static int
|
||||||
|
menubar_handle_key (WMenuBar * menubar, int key)
|
||||||
|
{
|
||||||
|
unsigned long cmd;
|
||||||
|
|
||||||
|
cmd = keybind_lookup_keymap_command (menu_map, key);
|
||||||
|
|
||||||
|
return (cmd == CK_IgnoreKey
|
||||||
|
|| menubar_execute_cmd (menubar, cmd,
|
||||||
|
key) == MSG_NOT_HANDLED) ? MSG_NOT_HANDLED : MSG_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
@ -143,6 +143,17 @@ ScreenList = alt-prime
|
|||||||
ScreenNext = alt-rbrace
|
ScreenNext = alt-rbrace
|
||||||
ScreenPrev = alt-lbrace
|
ScreenPrev = alt-lbrace
|
||||||
|
|
||||||
|
[menu]
|
||||||
|
Help = f1
|
||||||
|
Left = left; ctrl-b
|
||||||
|
Right = right; ctrl-f
|
||||||
|
Up = up; ctrl-p
|
||||||
|
Down = down; ctrl-n
|
||||||
|
Home = home; alt-lt; ctr-a
|
||||||
|
End = end; alt-gt ctrl-e
|
||||||
|
Enter = enter
|
||||||
|
Quit = F10; esc; ctrl-g
|
||||||
|
|
||||||
[input]
|
[input]
|
||||||
Home = ctrl-a; alt-lt; home; a1
|
Home = ctrl-a; alt-lt; home; a1
|
||||||
End = ctrl-e; alt-gt; end; c1
|
End = ctrl-e; alt-gt; end; c1
|
||||||
|
@ -143,6 +143,17 @@ ScreenList = alt-prime
|
|||||||
ScreenNext = alt-rbrace
|
ScreenNext = alt-rbrace
|
||||||
ScreenPrev = alt-lbrace
|
ScreenPrev = alt-lbrace
|
||||||
|
|
||||||
|
[menu]
|
||||||
|
Help = f1
|
||||||
|
Left = left; ctrl-b
|
||||||
|
Right = right; ctrl-f
|
||||||
|
Up = up; ctrl-p
|
||||||
|
Down = down; ctrl-n
|
||||||
|
Home = home; alt-lt; ctr-a
|
||||||
|
End = end; alt-gt ctrl-e
|
||||||
|
Enter = enter
|
||||||
|
Quit = F10; esc; ctrl-g
|
||||||
|
|
||||||
[input]
|
[input]
|
||||||
Home = ctrl-a; alt-lt; home; a1
|
Home = ctrl-a; alt-lt; home; a1
|
||||||
End = ctrl-e; alt-gt; end; c1
|
End = ctrl-e; alt-gt; end; c1
|
||||||
|
@ -38,6 +38,7 @@ GArray *main_keymap = NULL;
|
|||||||
GArray *main_x_keymap = NULL;
|
GArray *main_x_keymap = NULL;
|
||||||
GArray *panel_keymap = NULL;
|
GArray *panel_keymap = NULL;
|
||||||
GArray *dialog_keymap = NULL;
|
GArray *dialog_keymap = NULL;
|
||||||
|
GArray *menu_keymap = NULL;
|
||||||
GArray *input_keymap = NULL;
|
GArray *input_keymap = NULL;
|
||||||
GArray *listbox_keymap = NULL;
|
GArray *listbox_keymap = NULL;
|
||||||
GArray *tree_keymap = NULL;
|
GArray *tree_keymap = NULL;
|
||||||
@ -55,6 +56,7 @@ GArray *diff_keymap = NULL;
|
|||||||
const global_keymap_t *main_map = NULL;
|
const global_keymap_t *main_map = NULL;
|
||||||
const global_keymap_t *main_x_map = NULL;
|
const global_keymap_t *main_x_map = NULL;
|
||||||
const global_keymap_t *panel_map = NULL;
|
const global_keymap_t *panel_map = NULL;
|
||||||
|
const global_keymap_t *menu_map = NULL;
|
||||||
const global_keymap_t *tree_map = NULL;
|
const global_keymap_t *tree_map = NULL;
|
||||||
const global_keymap_t *help_map = NULL;
|
const global_keymap_t *help_map = NULL;
|
||||||
|
|
||||||
@ -225,6 +227,20 @@ static const global_keymap_ini_t default_dialog_keymap[] = {
|
|||||||
{NULL, NULL}
|
{NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* menubar */
|
||||||
|
static const global_keymap_ini_t default_menu_keymap[] = {
|
||||||
|
{"Help", "f1"},
|
||||||
|
{"Left", "left; ctrl-b"},
|
||||||
|
{"Right", "right; ctrl-f"},
|
||||||
|
{"Up", "up; ctrl-p"},
|
||||||
|
{"Down", "down; enter; ctrl-n"},
|
||||||
|
{"Home", "home; alt-lt; ctrl-a"},
|
||||||
|
{"End", "end; alt-gt; ctrl-e"},
|
||||||
|
{"Enter", "enter"},
|
||||||
|
{"Quit", "f10; ctrl-g; esc"},
|
||||||
|
{NULL, NULL}
|
||||||
|
};
|
||||||
|
|
||||||
/* input line */
|
/* input line */
|
||||||
static const global_keymap_ini_t default_input_keymap[] = {
|
static const global_keymap_ini_t default_input_keymap[] = {
|
||||||
/* Motion */
|
/* Motion */
|
||||||
@ -590,6 +606,7 @@ create_default_keymap (void)
|
|||||||
create_default_keymap_section (keymap, KEYMAP_SECTION_MAIN_EXT, default_main_x_keymap);
|
create_default_keymap_section (keymap, KEYMAP_SECTION_MAIN_EXT, default_main_x_keymap);
|
||||||
create_default_keymap_section (keymap, KEYMAP_SECTION_PANEL, default_panel_keymap);
|
create_default_keymap_section (keymap, KEYMAP_SECTION_PANEL, default_panel_keymap);
|
||||||
create_default_keymap_section (keymap, KEYMAP_SECTION_DIALOG, default_dialog_keymap);
|
create_default_keymap_section (keymap, KEYMAP_SECTION_DIALOG, default_dialog_keymap);
|
||||||
|
create_default_keymap_section (keymap, KEYMAP_SECTION_MENU, default_menu_keymap);
|
||||||
create_default_keymap_section (keymap, KEYMAP_SECTION_INPUT, default_input_keymap);
|
create_default_keymap_section (keymap, KEYMAP_SECTION_INPUT, default_input_keymap);
|
||||||
create_default_keymap_section (keymap, KEYMAP_SECTION_LISTBOX, default_listbox_keymap);
|
create_default_keymap_section (keymap, KEYMAP_SECTION_LISTBOX, default_listbox_keymap);
|
||||||
create_default_keymap_section (keymap, KEYMAP_SECTION_TREE, default_tree_keymap);
|
create_default_keymap_section (keymap, KEYMAP_SECTION_TREE, default_tree_keymap);
|
||||||
|
@ -17,6 +17,7 @@ extern GArray *main_keymap;
|
|||||||
extern GArray *main_x_keymap;
|
extern GArray *main_x_keymap;
|
||||||
extern GArray *panel_keymap;
|
extern GArray *panel_keymap;
|
||||||
extern GArray *dialog_keymap;
|
extern GArray *dialog_keymap;
|
||||||
|
extern GArray *menu_keymap;
|
||||||
extern GArray *input_keymap;
|
extern GArray *input_keymap;
|
||||||
extern GArray *listbox_keymap;
|
extern GArray *listbox_keymap;
|
||||||
extern GArray *tree_keymap;
|
extern GArray *tree_keymap;
|
||||||
@ -31,10 +32,10 @@ extern GArray *viewer_hex_keymap;
|
|||||||
extern GArray *diff_keymap;
|
extern GArray *diff_keymap;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
extern const global_keymap_t *main_map;
|
extern const global_keymap_t *main_map;
|
||||||
extern const global_keymap_t *main_x_map;
|
extern const global_keymap_t *main_x_map;
|
||||||
extern const global_keymap_t *panel_map;
|
extern const global_keymap_t *panel_map;
|
||||||
|
extern const global_keymap_t *menu_map;
|
||||||
extern const global_keymap_t *tree_map;
|
extern const global_keymap_t *tree_map;
|
||||||
extern const global_keymap_t *help_map;
|
extern const global_keymap_t *help_map;
|
||||||
|
|
||||||
|
@ -1365,6 +1365,9 @@ load_keymap_defs (gboolean load_from_file)
|
|||||||
dialog_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
dialog_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
||||||
load_keymap_from_section (KEYMAP_SECTION_DIALOG, dialog_keymap, mc_global_keymap);
|
load_keymap_from_section (KEYMAP_SECTION_DIALOG, dialog_keymap, mc_global_keymap);
|
||||||
|
|
||||||
|
menu_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
||||||
|
load_keymap_from_section (KEYMAP_SECTION_MENU, menu_keymap, mc_global_keymap);
|
||||||
|
|
||||||
input_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
input_keymap = g_array_new (TRUE, FALSE, sizeof (global_keymap_t));
|
||||||
load_keymap_from_section (KEYMAP_SECTION_INPUT, input_keymap, mc_global_keymap);
|
load_keymap_from_section (KEYMAP_SECTION_INPUT, input_keymap, mc_global_keymap);
|
||||||
|
|
||||||
@ -1401,6 +1404,7 @@ load_keymap_defs (gboolean load_from_file)
|
|||||||
main_x_map = (global_keymap_t *) main_x_keymap->data;
|
main_x_map = (global_keymap_t *) main_x_keymap->data;
|
||||||
panel_map = (global_keymap_t *) panel_keymap->data;
|
panel_map = (global_keymap_t *) panel_keymap->data;
|
||||||
dialog_map = (global_keymap_t *) dialog_keymap->data;
|
dialog_map = (global_keymap_t *) dialog_keymap->data;
|
||||||
|
menu_map = (global_keymap_t *) menu_keymap->data;
|
||||||
input_map = (global_keymap_t *) input_keymap->data;
|
input_map = (global_keymap_t *) input_keymap->data;
|
||||||
listbox_map = (global_keymap_t *) listbox_keymap->data;
|
listbox_map = (global_keymap_t *) listbox_keymap->data;
|
||||||
tree_map = (global_keymap_t *) tree_keymap->data;
|
tree_map = (global_keymap_t *) tree_keymap->data;
|
||||||
|
Loading…
Reference in New Issue
Block a user