-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkeymap.h
124 lines (97 loc) · 3.05 KB
/
keymap.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
/*
* Copyright (C) 1996-2000,2 Michael R. Elkins <[email protected]>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* 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, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifndef KEYMAP_H
#define KEYMAP_H
#include "mapping.h"
/* maximal length of a key binding sequence used for buffer in km_bindkey */
#define MAX_SEQ 8
/* type for key storage, the rest of mutt works fine with int type */
typedef short keycode_t;
void km_bind (char *, int, int, char *, char *);
void km_bindkey (char *, int, int);
int km_dokey (int);
void init_extended_keys(void);
/* entry in the keymap tree */
struct keymap_t
{
char *macro; /* macro expansion (op == OP_MACRO) */
char *descr; /* description of a macro for the help menu */
struct keymap_t *next; /* next key in map */
short op; /* operation to perform */
short eq; /* number of leading keys equal to next entry */
short len; /* length of key sequence (unit: sizeof (keycode_t)) */
keycode_t *keys; /* key sequence */
};
char *km_keyname (int);
int km_expand_key (char *, size_t, struct keymap_t *);
struct keymap_t *km_find_func (int, int);
void km_init (void);
void km_error_key (int);
void mutt_what_key (void);
enum
{
MENU_ALIAS,
MENU_ATTACH,
MENU_COMPOSE,
MENU_EDITOR,
MENU_FOLDER,
MENU_GENERIC,
MENU_MAIN,
MENU_PAGER,
MENU_POST,
MENU_QUERY,
MENU_PGP,
MENU_SMIME,
#ifdef CRYPT_BACKEND_GPGME
MENU_KEY_SELECT_PGP,
MENU_KEY_SELECT_SMIME,
#endif
#ifdef MIXMASTER
MENU_MIX,
#endif
MENU_MAX
};
/* the keymap trees (one for each menu) */
extern struct keymap_t *Keymaps[];
/* dokey() records the last real key pressed */
extern int LastKey;
extern struct mapping_t Menus[];
struct binding_t
{
char *name; /* name of the function */
int op; /* function id number */
char *seq; /* default key binding */
};
struct binding_t *km_get_table (int menu);
extern struct binding_t OpGeneric[];
extern struct binding_t OpPost[];
extern struct binding_t OpMain[];
extern struct binding_t OpAttach[];
extern struct binding_t OpPager[];
extern struct binding_t OpCompose[];
extern struct binding_t OpBrowser[];
extern struct binding_t OpEditor[];
extern struct binding_t OpQuery[];
extern struct binding_t OpAlias[];
extern struct binding_t OpPgp[];
extern struct binding_t OpSmime[];
#ifdef MIXMASTER
extern struct binding_t OpMix[];
#endif
#include "keymap_defs.h"
#endif /* KEYMAP_H */