NeoMutt  2025-12-11-435-g4ac674
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
init.c File Reference

Set up the key bindings. More...

#include "config.h"
#include <string.h>
#include "mutt/lib.h"
#include "config/lib.h"
#include "core/lib.h"
#include "gui/lib.h"
#include "init.h"
#include "commands.h"
#include "get.h"
#include "keymap.h"
#include "menu.h"
+ Include dependency graph for init.c:

Go to the source code of this file.

Functions

struct SubMenukm_register_submenu (const struct MenuFuncOp functions[])
 Register a submenu.
 
struct MenuDefinitionkm_register_menu (int menu, const char *name)
 Register a menu.
 
void km_menu_add_submenu (struct MenuDefinition *md, struct SubMenu *sm)
 Add a SubMenu to a Menu Definition.
 
void km_menu_add_bindings (struct MenuDefinition *md, const struct MenuOpSeq bindings[])
 Add Keybindings to a Menu.
 
int km_config_observer (struct NotifyCallback *nc)
 Notification that a Config Variable has changed - Implements observer_t -.
 
void km_init (void)
 Initialise all the menu keybindings.
 
static int menu_defs_sort (const void *a, const void *b, void *sdata)
 Compare two MenuDefinitions by their names - Implements sort_t -.
 
void km_sort (void)
 Sort all the menu keybindings.
 
void km_cleanup (void)
 Free the key maps.
 
void km_set_abort_key (void)
 Parse the abort_key config string.
 

Variables

struct MenuDefinitionArray MenuDefs
 All the registered Menus.
 
struct SubMenuArray SubMenus
 All the registered SubMenus.
 
keycode_t AbortKey
 code of key to abort prompts, normally Ctrl-G
 
const struct Command KeyCommands []
 Key Binding Commands.
 

Detailed Description

Set up the key bindings.

Authors
  • Richard Russon

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

Definition in file init.c.

Function Documentation

◆ km_register_submenu()

struct SubMenu * km_register_submenu ( const struct MenuFuncOp functions[])

Register a submenu.

Parameters
functionsFunction definitions
Return values
ptrSubMenu

Register a set of functions. The result can be used in multiple Menus.

Definition at line 91 of file init.c.

92{
93 struct SubMenu sm = { 0 };
96
97 ARRAY_ADD(&SubMenus, sm);
98 return ARRAY_LAST(&SubMenus);
99}
#define ARRAY_ADD(head, elem)
Add an element at the end of the array.
Definition array.h:157
#define ARRAY_LAST(head)
Convenience method to get the last element.
Definition array.h:145
#define ARRAY_INIT(head)
Initialize an array.
Definition array.h:65
struct SubMenuArray SubMenus
All the registered SubMenus.
Definition init.c:45
Collection of related functions.
Definition menu.h:68
const struct MenuFuncOp * functions
All available functions.
Definition menu.h:70
struct KeymapList keymaps
All keybindings.
Definition menu.h:71
+ Here is the caller graph for this function:

◆ km_register_menu()

struct MenuDefinition * km_register_menu ( int menu,
const char * name )

Register a menu.

Parameters
menuMenu Type, e.g. MENU_INDEX
nameMenu name, e.g. "index"
Return values
ptrMenu Definition

Definition at line 107 of file init.c.

108{
109 struct MenuDefinition *md = MUTT_MEM_CALLOC(1, struct MenuDefinition);
110 md->id = menu;
111 md->name = mutt_str_dup(name);
112 ARRAY_INIT(&md->submenus);
113
114 ARRAY_ADD(&MenuDefs, md);
115 return *ARRAY_LAST(&MenuDefs);
116}
struct MenuDefinitionArray MenuDefs
All the registered Menus.
Definition init.c:42
#define MUTT_MEM_CALLOC(n, type)
Definition memory.h:52
char * mutt_str_dup(const char *str)
Copy a string, safely.
Definition string.c:257
Functions for a Dialog or Window.
Definition menu.h:80
const char * name
Menu name, e.g. "alias".
Definition menu.h:82
int id
Menu ID, e.g. MENU_ALIAS.
Definition menu.h:81
struct SubMenuPArray submenus
Parts making up the Menu.
Definition menu.h:83
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ km_menu_add_submenu()

void km_menu_add_submenu ( struct MenuDefinition * md,
struct SubMenu * sm )

Add a SubMenu to a Menu Definition.

Parameters
mdMenu Definition
smSubMenu to add

Definition at line 123 of file init.c.

124{
125 if (!sm->parent)
126 sm->parent = md;
127
128 ARRAY_ADD(&md->submenus, sm);
129}
struct MenuDefinition * parent
Primary parent.
Definition menu.h:69
+ Here is the caller graph for this function:

◆ km_menu_add_bindings()

void km_menu_add_bindings ( struct MenuDefinition * md,
const struct MenuOpSeq bindings[] )

Add Keybindings to a Menu.

Parameters
mdMenu Definition
bindingsKeybindings to add

Definition at line 136 of file init.c.

137{
138 for (int i = 0; bindings[i].op != OP_NULL; i++)
139 {
140 if (bindings[i].seq)
141 {
142 km_bind(md, bindings[i].seq, bindings[i].op, NULL, NULL, NULL);
143 }
144 }
145}
enum CommandResult km_bind(struct MenuDefinition *md, const char *key_str, int op, char *macro, char *desc, struct Buffer *err)
Set up a key binding.
Definition menu.c:51
int op
Operation, e.g. OP_DELETE.
Definition menu.h:49
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ km_init()

void km_init ( void )

Initialise all the menu keybindings.

Definition at line 170 of file init.c.

171{
174
176}
int km_config_observer(struct NotifyCallback *nc)
Notification that a Config Variable has changed - Implements observer_t -.
Definition init.c:150
bool notify_observer_add(struct Notify *notify, enum NotifyType type, observer_t callback, void *global_data)
Add an observer to an object.
Definition notify.c:191
@ NT_CONFIG
Config has changed, NotifyConfig, EventConfig.
Definition notify_type.h:43
struct Notify * notify
Notifications: NotifyConfig, EventConfig.
Definition subset.h:51
Container for Accounts, Notifications.
Definition neomutt.h:41
struct ConfigSubset * sub
Inherited config items.
Definition neomutt.h:49
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ km_sort()

void km_sort ( void )

Sort all the menu keybindings.

Definition at line 192 of file init.c.

193{
195}
#define ARRAY_SORT(head, fn, sdata)
Sort an array.
Definition array.h:373
static int menu_defs_sort(const void *a, const void *b, void *sdata)
Compare two MenuDefinitions by their names - Implements sort_t -.
Definition init.c:181
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ km_cleanup()

void km_cleanup ( void )

Free the key maps.

Definition at line 200 of file init.c.

201{
202 if (NeoMutt && NeoMutt->sub)
204
205 struct MenuDefinition **mdp = NULL;
207 {
208 struct MenuDefinition *md = *mdp;
209
210 FREE(&md->name);
211 ARRAY_FREE(&md->submenus);
212 FREE(&md);
213 }
215
216 struct SubMenu *sm = NULL;
218 {
220 }
222
225}
#define ARRAY_FOREACH(elem, head)
Iterate over all elements of the array.
Definition array.h:223
#define ARRAY_FREE(head)
Release all memory.
Definition array.h:209
struct KeyEventArray MacroEvents
These are used for macros and exec/push commands.
Definition get.c:56
struct KeyEventArray UngetKeyEvents
These are used in all other "normal" situations, and are not ignored when passing GETCH_IGNORE_MACRO.
Definition get.c:60
void keymaplist_free(struct KeymapList *kml)
Free a List of Keymaps.
Definition keymap.c:144
#define FREE(x)
Free memory and set the pointer to NULL.
Definition memory.h:68
bool notify_observer_remove(struct Notify *notify, const observer_t callback, const void *global_data)
Remove an observer from an object.
Definition notify.c:230
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ km_set_abort_key()

void km_set_abort_key ( void )

Parse the abort_key config string.

Parse the string into $abort_key and put the keycode into AbortKey.

Definition at line 232 of file init.c.

233{
234 keycode_t buf[4] = { 0 };
235 const char *const c_abort_key = cs_subset_string(NeoMutt->sub, "abort_key");
236
237 size_t len = parse_keys(c_abort_key, buf, countof(buf));
238 if (len == 0)
239 {
240 mutt_error(_("Abort key is not set, defaulting to Ctrl-G"));
241 AbortKey = ctrl('G');
242 return;
243 }
244
245 if (len > 1)
246 {
247 mutt_warning(_("Specified abort key sequence (%s) will be truncated to first key"),
248 c_abort_key);
249 }
250 AbortKey = buf[0];
251}
const char * cs_subset_string(const struct ConfigSubset *sub, const char *name)
Get a string config item by name.
Definition helpers.c:291
#define mutt_warning(...)
Definition logging2.h:92
#define mutt_error(...)
Definition logging2.h:94
keycode_t AbortKey
code of key to abort prompts, normally Ctrl-G
Definition init.c:47
size_t parse_keys(const char *str, keycode_t *d, size_t max)
Parse a key string into key codes.
Definition keymap.c:318
short keycode_t
Type for key storage, the rest of neomutt works fine with int type.
Definition keymap.h:31
#define countof(x)
Definition memory.h:49
#define _(a)
Definition message.h:28
#define ctrl(ch)
Convert a letter to a control character (e.g., 'A' -> Ctrl-A)
Definition mutt_curses.h:52
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Variable Documentation

◆ MenuDefs

struct MenuDefinitionArray MenuDefs

All the registered Menus.

Definition at line 42 of file init.c.

◆ SubMenus

struct SubMenuArray SubMenus

All the registered SubMenus.

Definition at line 45 of file init.c.

◆ AbortKey

keycode_t AbortKey

code of key to abort prompts, normally Ctrl-G

key to abort edits etc, normally Ctrl-G

Definition at line 47 of file init.c.

◆ KeyCommands

const struct Command KeyCommands[]
Initial value:
= {
{ "bind", CMD_BIND, parse_bind,
N_("Bind a key to a function"),
N_("bind <map>[,<map> ... ] <key> <function>"),
"configuration.html#bind" },
{ "exec", CMD_EXEC, parse_exec,
N_("Execute a function"),
N_("exec <function> [ <function> ... ]"),
"configuration.html#exec" },
{ "macro", CMD_MACRO, parse_macro,
N_("Define a keyboard macro"),
N_("macro <map>[,<map> ... ] <key> <sequence> [ <description> ]"),
"configuration.html#macro" },
{ "push", CMD_PUSH, parse_push,
N_("Push a string into NeoMutt's input queue (simulate typing)"),
N_("push <string>"),
"configuration.html#push" },
{ "unbind", CMD_UNBIND, parse_unbind,
N_("Remove a key binding"),
N_("unbind { * | <map>[,<map> ... ] } [ <key> ]"),
"configuration.html#unbind" },
{ "unmacro", CMD_UNMACRO, parse_unbind,
N_("Remove a keyboard `macro`"),
N_("unmacro { * | <map>[,<map> ... ] } [ <key> ]"),
"configuration.html#unmacro" },
{ NULL, CMD_NONE, NULL, NULL, NULL, NULL, CF_NO_FLAGS },
}
#define CF_NO_FLAGS
No flags are set.
Definition command.h:48
@ CMD_EXEC
:exec
Definition command.h:74
@ CMD_UNMACRO
:unmacro
Definition command.h:135
@ CMD_MACRO
:macro
Definition command.h:90
@ CMD_PUSH
:push
Definition command.h:101
@ CMD_NONE
No Command.
Definition command.h:59
@ CMD_BIND
:bind
Definition command.h:67
@ CMD_UNBIND
:unbind
Definition command.h:128
enum CommandResult parse_bind(const struct Command *cmd, struct Buffer *line, const struct ParseContext *pc, struct ParseError *pe)
Parse the 'bind' command - Implements Command::parse() -.
Definition commands.c:241
enum CommandResult parse_exec(const struct Command *cmd, struct Buffer *line, const struct ParseContext *pc, struct ParseError *pe)
Parse the 'exec' command - Implements Command::parse() -.
Definition commands.c:778
enum CommandResult parse_macro(const struct Command *cmd, struct Buffer *line, const struct ParseContext *pc, struct ParseError *pe)
Parse the 'macro' command - Implements Command::parse() -.
Definition commands.c:671
enum CommandResult parse_push(const struct Command *cmd, struct Buffer *line, const struct ParseContext *pc, struct ParseError *pe)
Parse the 'push' command - Implements Command::parse() -.
Definition commands.c:204
enum CommandResult parse_unbind(const struct Command *cmd, struct Buffer *line, const struct ParseContext *pc, struct ParseError *pe)
Parse the 'unbind' and 'unmacro' commands - Implements Command::parse() -.
Definition commands.c:644
#define N_(a)
Definition message.h:32

Key Binding Commands.

Definition at line 52 of file init.c.

52 {
53 // clang-format off
54 { "bind", CMD_BIND, parse_bind,
55 N_("Bind a key to a function"),
56 N_("bind <map>[,<map> ... ] <key> <function>"),
57 "configuration.html#bind" },
58 { "exec", CMD_EXEC, parse_exec,
59 N_("Execute a function"),
60 N_("exec <function> [ <function> ... ]"),
61 "configuration.html#exec" },
62 { "macro", CMD_MACRO, parse_macro,
63 N_("Define a keyboard macro"),
64 N_("macro <map>[,<map> ... ] <key> <sequence> [ <description> ]"),
65 "configuration.html#macro" },
66 { "push", CMD_PUSH, parse_push,
67 N_("Push a string into NeoMutt's input queue (simulate typing)"),
68 N_("push <string>"),
69 "configuration.html#push" },
70 { "unbind", CMD_UNBIND, parse_unbind,
71 N_("Remove a key binding"),
72 N_("unbind { * | <map>[,<map> ... ] } [ <key> ]"),
73 "configuration.html#unbind" },
74 { "unmacro", CMD_UNMACRO, parse_unbind,
75 N_("Remove a keyboard `macro`"),
76 N_("unmacro { * | <map>[,<map> ... ] } [ <key> ]"),
77 "configuration.html#unmacro" },
78
79 { NULL, CMD_NONE, NULL, NULL, NULL, NULL, CF_NO_FLAGS },
80 // clang-format on
81};