Allowing only those menus where the bound function is actually present,
when rebinding keys. git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@5022 35c25a1d-7b9e-4130-9fde-d3aeb78583b8master
parent
a8c13d79fe
commit
4651f49fca
|
@ -2,6 +2,11 @@
|
||||||
* src/global.c (shortcut_init): Add default keybindings for Cut,
|
* src/global.c (shortcut_init): Add default keybindings for Cut,
|
||||||
PrevWord and NextWord in the prompt input lines; the code for those
|
PrevWord and NextWord in the prompt input lines; the code for those
|
||||||
special operations already exists, just the shortcuts were missing.
|
special operations already exists, just the shortcuts were missing.
|
||||||
|
* src/rcfile.c (parse_binding): When binding keys, only allow those
|
||||||
|
menus where the bound function is actually present. This reduces
|
||||||
|
the meaning of 'all' to "all menus where the function exists".
|
||||||
|
* src/rcfile.c (is_universal): New function, returning TRUE for the
|
||||||
|
functions that are present in most menus but only listed in MMAIN.
|
||||||
|
|
||||||
2014-06-25 Benno Schulenberg <bensberg@justemail.net>
|
2014-06-25 Benno Schulenberg <bensberg@justemail.net>
|
||||||
* src/browser.c (do_browser): Allow 'firstfile' and 'lastfile' to be
|
* src/browser.c (do_browser): Allow 'firstfile' and 'lastfile' to be
|
||||||
|
|
36
src/rcfile.c
36
src/rcfile.c
|
@ -397,6 +397,22 @@ int check_bad_binding(sc *s)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check whether the given executable function is "universal" (meaning
|
||||||
|
* any horizontal movement or deletion) and thus is present in almost
|
||||||
|
* all menus. */
|
||||||
|
bool is_universal(void (*func))
|
||||||
|
{
|
||||||
|
if (func == do_left || func == do_right ||
|
||||||
|
func == do_home || func == do_end ||
|
||||||
|
func == do_prev_word_void || func == do_next_word_void ||
|
||||||
|
func == do_verbatim_input || func == do_cut_text_void ||
|
||||||
|
func == do_delete || func == do_backspace ||
|
||||||
|
func == do_tab || func == do_enter)
|
||||||
|
return TRUE;
|
||||||
|
else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
/* Bind or unbind a key combo, to or from a function. */
|
/* Bind or unbind a key combo, to or from a function. */
|
||||||
void parse_binding(char *ptr, bool dobind)
|
void parse_binding(char *ptr, bool dobind)
|
||||||
{
|
{
|
||||||
|
@ -487,6 +503,26 @@ void parse_binding(char *ptr, bool dobind)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (dobind) {
|
if (dobind) {
|
||||||
|
subnfunc *f;
|
||||||
|
int mask = 0;
|
||||||
|
|
||||||
|
/* Tally up the menus where the function exists. */
|
||||||
|
for (f = allfuncs; f != NULL; f = f->next)
|
||||||
|
if (f->scfunc == newsc->scfunc)
|
||||||
|
mask = mask | f->menus;
|
||||||
|
|
||||||
|
/* Now limit the given menu to those where the function exists. */
|
||||||
|
if (is_universal(newsc->scfunc))
|
||||||
|
menu = menu & MMOST;
|
||||||
|
else
|
||||||
|
menu = menu & mask;
|
||||||
|
|
||||||
|
if (!menu) {
|
||||||
|
rcfile_error(N_("Function '%s' does not exist in menu '%s'"), funcptr, menuptr);
|
||||||
|
free(newsc);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
newsc->keystr = keycopy;
|
newsc->keystr = keycopy;
|
||||||
newsc->menu = menu;
|
newsc->menu = menu;
|
||||||
newsc->type = strtokeytype(newsc->keystr);
|
newsc->type = strtokeytype(newsc->keystr);
|
||||||
|
|
Loading…
Reference in New Issue