mirror of
https://github.com/tmux/tmux.git
synced 2024-12-12 17:38:48 +00:00
Split emacs/vi keys into seperate tables.
This commit is contained in:
parent
089f727f54
commit
892d1b534e
14
CHANGES
14
CHANGES
@ -1,3 +1,15 @@
|
||||
02 July 2008
|
||||
|
||||
* Split vi and emacs mode keys into two tables and add an option (mode-keys)
|
||||
to select between them. Default is emacs, use,
|
||||
|
||||
tmux set mode-keys vi
|
||||
|
||||
to change to vi.
|
||||
|
||||
vi mode uses space to start selection, enter to copy selection and escape
|
||||
to clear selection.
|
||||
|
||||
01 July 2008
|
||||
|
||||
* Protocol versioning. Clients which identify as a different version from the
|
||||
@ -598,4 +610,4 @@
|
||||
(including mutt, emacs). No status bar yet and no key remapping or other
|
||||
customisation.
|
||||
|
||||
$Id: CHANGES,v 1.148 2008-07-01 19:47:02 nicm Exp $
|
||||
$Id: CHANGES,v 1.149 2008-07-02 21:22:57 nicm Exp $
|
||||
|
4
Makefile
4
Makefile
@ -1,4 +1,4 @@
|
||||
# $Id: Makefile,v 1.70 2008-07-01 05:43:00 nicm Exp $
|
||||
# $Id: Makefile,v 1.71 2008-07-02 21:22:57 nicm Exp $
|
||||
|
||||
.SUFFIXES: .c .o .y .h
|
||||
.PHONY: clean update-index.html upload-index.html
|
||||
@ -18,7 +18,7 @@ META?= \002 # C-b
|
||||
SRCS= tmux.c server.c server-msg.c server-fn.c buffer.c buffer-poll.c status.c \
|
||||
xmalloc.c xmalloc-debug.c input.c input-keys.c screen.c screen-display.c \
|
||||
window.c session.c log.c client.c client-msg.c client-fn.c cfg.c \
|
||||
key-string.c key-bindings.c resize.c arg.c \
|
||||
key-string.c key-bindings.c resize.c arg.c mode-key.c \
|
||||
cmd.c cmd-generic.c cmd-string.c \
|
||||
cmd-detach-client.c cmd-list-sessions.c cmd-new-window.c cmd-bind-key.c \
|
||||
cmd-unbind-key.c cmd-previous-window.c cmd-last-window.c cmd-list-keys.c \
|
||||
|
3
TODO
3
TODO
@ -67,6 +67,5 @@
|
||||
- next prev word etc in command prompt
|
||||
- split keys in command prompt/scroll mode/copy mode into vi and emacs and
|
||||
have a "edit-mode" option select which keymap
|
||||
- zombie windows: don't disappear when the command dies. new command
|
||||
respawn-window [command] to restart; ommitting commands uses previous
|
||||
- many more info displays for various things
|
||||
- document mode-keys
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-set-option.c,v 1.38 2008-07-01 19:00:50 nicm Exp $ */
|
||||
/* $Id: cmd-set-option.c,v 1.39 2008-07-02 21:22:57 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -55,14 +55,19 @@ const struct cmd_entry cmd_set_option_entry = {
|
||||
cmd_set_option_print
|
||||
};
|
||||
|
||||
const char *set_option_bell_action_choices[] = { "none", "any", "current", NULL };
|
||||
const char *set_option_bell_action_list[] = {
|
||||
"none", "any", "current", NULL
|
||||
};
|
||||
const char *set_option_mode_keys_list[] = {
|
||||
"emacs", "vi", NULL
|
||||
};
|
||||
const struct set_option_entry set_option_table[NSETOPTION] = {
|
||||
{ "bell-action",
|
||||
SET_OPTION_CHOICE, 0, 0, set_option_bell_action_choices },
|
||||
{ "bell-action", SET_OPTION_CHOICE, 0, 0, set_option_bell_action_list },
|
||||
{ "buffer-limit", SET_OPTION_NUMBER, 1, INT_MAX, NULL },
|
||||
{ "default-command", SET_OPTION_STRING, 0, 0, NULL },
|
||||
{ "display-time", SET_OPTION_NUMBER, 1, INT_MAX, NULL },
|
||||
{ "history-limit", SET_OPTION_NUMBER, 0, SHRT_MAX, NULL },
|
||||
{ "mode-keys", SET_OPTION_CHOICE, 0, 0, set_option_mode_keys_list },
|
||||
{ "prefix", SET_OPTION_KEY, 0, 0, NULL },
|
||||
{ "remain-by-default", SET_OPTION_FLAG, 0, 0, NULL },
|
||||
{ "set-titles", SET_OPTION_FLAG, 0, 0, NULL },
|
||||
|
92
mode-key.c
Normal file
92
mode-key.c
Normal file
@ -0,0 +1,92 @@
|
||||
/* $Id: mode-key.c,v 1.1 2008-07-02 21:22:57 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
*
|
||||
* Permission to use, copy, modify, and distribute this software for any
|
||||
* purpose with or without fee is hereby granted, provided that the above
|
||||
* copyright notice and this permission notice appear in all copies.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||
* WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
|
||||
* OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
|
||||
#include <sys/types.h>
|
||||
|
||||
#include "tmux.h"
|
||||
|
||||
struct mode_key_entry {
|
||||
enum mode_key mkey;
|
||||
int key;
|
||||
};
|
||||
|
||||
const struct mode_key_entry mode_key_table_vi[] = {
|
||||
{ MODEKEY_BOL, '0' },
|
||||
{ MODEKEY_CLEARSEL, '\033' },
|
||||
{ MODEKEY_COPYSEL, '\r' },
|
||||
{ MODEKEY_DOWN, 'j' },
|
||||
{ MODEKEY_DOWN, KEYC_DOWN },
|
||||
{ MODEKEY_EOL, '$' },
|
||||
{ MODEKEY_LEFT, 'h' },
|
||||
{ MODEKEY_LEFT, KEYC_LEFT },
|
||||
{ MODEKEY_NPAGE, '\006' },
|
||||
{ MODEKEY_NPAGE, KEYC_NPAGE },
|
||||
{ MODEKEY_NWORD, 'w' },
|
||||
{ MODEKEY_PPAGE, '\025' },
|
||||
{ MODEKEY_PPAGE, KEYC_PPAGE },
|
||||
{ MODEKEY_PWORD, 'b' },
|
||||
{ MODEKEY_QUIT, 'q' },
|
||||
{ MODEKEY_RIGHT, 'l' },
|
||||
{ MODEKEY_RIGHT, KEYC_RIGHT },
|
||||
{ MODEKEY_STARTSEL, ' ' },
|
||||
{ MODEKEY_UP, 'k' },
|
||||
{ MODEKEY_UP, KEYC_UP },
|
||||
};
|
||||
#define NKEYVI (sizeof mode_key_table_vi / sizeof mode_key_table_vi[0])
|
||||
|
||||
const struct mode_key_entry mode_key_table_emacs[] = {
|
||||
{ MODEKEY_BOL, '\001' },
|
||||
{ MODEKEY_CLEARSEL, '\007' },
|
||||
{ MODEKEY_COPYSEL, '\027' },
|
||||
{ MODEKEY_COPYSEL, KEYC_ADDESCAPE('w') },
|
||||
{ MODEKEY_DOWN, KEYC_DOWN },
|
||||
{ MODEKEY_EOL, '\005' },
|
||||
{ MODEKEY_LEFT, KEYC_LEFT },
|
||||
{ MODEKEY_NPAGE, KEYC_NPAGE },
|
||||
{ MODEKEY_NWORD, KEYC_ADDESCAPE('f') },
|
||||
{ MODEKEY_PPAGE, KEYC_PPAGE },
|
||||
{ MODEKEY_PWORD, KEYC_ADDESCAPE('b') },
|
||||
{ MODEKEY_QUIT, 'q' },
|
||||
{ MODEKEY_QUIT, '\033' },
|
||||
{ MODEKEY_RIGHT, KEYC_RIGHT },
|
||||
{ MODEKEY_STARTSEL, '\000' },
|
||||
{ MODEKEY_UP, KEYC_UP },
|
||||
};
|
||||
#define NKEYEMACS (sizeof mode_key_table_emacs / sizeof mode_key_table_emacs[0])
|
||||
|
||||
enum mode_key
|
||||
mode_key_lookup(int table, int key)
|
||||
{
|
||||
const struct mode_key_entry *ptr;
|
||||
u_int i, n;
|
||||
|
||||
if (table == MODEKEY_EMACS) {
|
||||
ptr = mode_key_table_emacs;
|
||||
n = NKEYEMACS;
|
||||
} else if (table == MODEKEY_VI) {
|
||||
ptr = mode_key_table_vi;
|
||||
n = NKEYVI;
|
||||
} else
|
||||
return (MODEKEY_NONE);
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
if (ptr[i].key == key)
|
||||
return (ptr[i].mkey);
|
||||
}
|
||||
return (MODEKEY_NONE);
|
||||
}
|
3
tmux.c
3
tmux.c
@ -1,4 +1,4 @@
|
||||
/* $Id: tmux.c,v 1.71 2008-06-29 21:03:57 nicm Exp $ */
|
||||
/* $Id: tmux.c,v 1.72 2008-07-02 21:22:57 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -223,6 +223,7 @@ main(int argc, char **argv)
|
||||
options_set_number(&global_options, "set-titles", 1);
|
||||
options_set_number(&global_options, "buffer-limit", 9);
|
||||
options_set_number(&global_options, "remain-by-default", 0);
|
||||
options_set_number(&global_options, "mode-keys", MODEKEY_EMACS);
|
||||
|
||||
if (cfg_file == NULL) {
|
||||
home = getenv("HOME");
|
||||
|
28
tmux.h
28
tmux.h
@ -1,4 +1,4 @@
|
||||
/* $Id: tmux.h,v 1.174 2008-07-01 20:35:16 nicm Exp $ */
|
||||
/* $Id: tmux.h,v 1.175 2008-07-02 21:22:57 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -827,7 +827,28 @@ struct set_option_entry {
|
||||
const char **choices;
|
||||
};
|
||||
extern const struct set_option_entry set_option_table[];
|
||||
#define NSETOPTION 14
|
||||
#define NSETOPTION 15
|
||||
|
||||
/* Edit keys. */
|
||||
enum mode_key {
|
||||
MODEKEY_BOL,
|
||||
MODEKEY_CLEARSEL,
|
||||
MODEKEY_COPYSEL,
|
||||
MODEKEY_DOWN,
|
||||
MODEKEY_EOL,
|
||||
MODEKEY_LEFT,
|
||||
MODEKEY_NONE,
|
||||
MODEKEY_NPAGE,
|
||||
MODEKEY_NWORD,
|
||||
MODEKEY_PPAGE,
|
||||
MODEKEY_PWORD,
|
||||
MODEKEY_QUIT,
|
||||
MODEKEY_RIGHT,
|
||||
MODEKEY_STARTSEL,
|
||||
MODEKEY_UP,
|
||||
};
|
||||
#define MODEKEY_EMACS 0
|
||||
#define MODEKEY_VI 1
|
||||
|
||||
#ifdef NO_STRTONUM
|
||||
/* strtonum.c */
|
||||
@ -879,6 +900,9 @@ void sigreset(void);
|
||||
/* cfg.c */
|
||||
int load_cfg(const char *, char **x);
|
||||
|
||||
/* mode-key.c */
|
||||
enum mode_key mode_key_lookup(int, int);
|
||||
|
||||
/* options.c */
|
||||
int options_cmp(struct options_entry *, struct options_entry *);
|
||||
SPLAY_PROTOTYPE(options_tree, options_entry, entry, options_cmp);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: window-copy.c,v 1.25 2008-06-27 17:41:48 nicm Exp $ */
|
||||
/* $Id: window-copy.c,v 1.26 2008-07-02 21:22:57 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -136,32 +136,26 @@ window_copy_key(struct window *w, struct client *c, int key)
|
||||
{
|
||||
struct window_copy_mode_data *data = w->modedata;
|
||||
struct screen *s = &data->screen;
|
||||
int table;
|
||||
|
||||
switch (key) {
|
||||
case 'Q':
|
||||
case 'q':
|
||||
table = options_get_number(&c->session->options, "mode-keys");
|
||||
switch (mode_key_lookup(table, key)) {
|
||||
case MODEKEY_QUIT:
|
||||
window_reset_mode(w);
|
||||
break;
|
||||
case 'h':
|
||||
case KEYC_LEFT:
|
||||
case MODEKEY_LEFT:
|
||||
window_copy_cursor_left(w);
|
||||
return;
|
||||
case 'l':
|
||||
case KEYC_RIGHT:
|
||||
case MODEKEY_RIGHT:
|
||||
window_copy_cursor_right(w);
|
||||
return;
|
||||
case 'k':
|
||||
case 'K':
|
||||
case KEYC_UP:
|
||||
case MODEKEY_UP:
|
||||
window_copy_cursor_up(w);
|
||||
return;
|
||||
case 'j':
|
||||
case 'J':
|
||||
case KEYC_DOWN:
|
||||
case MODEKEY_DOWN:
|
||||
window_copy_cursor_down(w);
|
||||
return;
|
||||
case '\025': /* C-u */
|
||||
case KEYC_PPAGE:
|
||||
case MODEKEY_PPAGE:
|
||||
if (data->oy + screen_size_y(s) > w->base.hsize)
|
||||
data->oy = w->base.hsize;
|
||||
else
|
||||
@ -169,8 +163,7 @@ window_copy_key(struct window *w, struct client *c, int key)
|
||||
window_copy_update_selection(w);
|
||||
window_copy_redraw_screen(w);
|
||||
break;
|
||||
case '\006': /* C-f */
|
||||
case KEYC_NPAGE:
|
||||
case MODEKEY_NPAGE:
|
||||
if (data->oy < screen_size_y(s))
|
||||
data->oy = 0;
|
||||
else
|
||||
@ -178,38 +171,33 @@ window_copy_key(struct window *w, struct client *c, int key)
|
||||
window_copy_update_selection(w);
|
||||
window_copy_redraw_screen(w);
|
||||
break;
|
||||
case '\000': /* C-space */
|
||||
case ' ':
|
||||
case MODEKEY_STARTSEL:
|
||||
window_copy_start_selection(w);
|
||||
break;
|
||||
case '\033':
|
||||
case MODEKEY_CLEARSEL:
|
||||
screen_clear_selection(&data->screen);
|
||||
window_copy_redraw_screen(w);
|
||||
break;
|
||||
case '\027': /* C-w */
|
||||
case '\r': /* enter */
|
||||
case MODEKEY_COPYSEL:
|
||||
if (c != NULL && c->session != NULL) {
|
||||
window_copy_copy_selection(w, c);
|
||||
window_reset_mode(w);
|
||||
}
|
||||
break;
|
||||
case '0':
|
||||
case '\001': /* C-a */
|
||||
case MODEKEY_BOL:
|
||||
window_copy_cursor_start_of_line(w);
|
||||
break;
|
||||
case '$':
|
||||
case '\005': /* C-e */
|
||||
case MODEKEY_EOL:
|
||||
window_copy_cursor_end_of_line(w);
|
||||
break;
|
||||
case 'w':
|
||||
case KEYC_ADDESCAPE('F'): /* M-F */
|
||||
case KEYC_ADDESCAPE('f'): /* M-f */
|
||||
case MODEKEY_NWORD:
|
||||
window_copy_cursor_next_word(w);
|
||||
break;
|
||||
case 'b':
|
||||
case KEYC_ADDESCAPE('B'): /* M-B */
|
||||
case KEYC_ADDESCAPE('b'): /* M-b */
|
||||
case MODEKEY_PWORD:
|
||||
window_copy_cursor_previous_word(w);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: window-more.c,v 1.14 2008-06-22 16:56:47 nicm Exp $ */
|
||||
/* $Id: window-more.c,v 1.15 2008-07-02 21:22:57 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -123,42 +123,39 @@ window_more_resize(struct window *w, u_int sx, u_int sy)
|
||||
}
|
||||
|
||||
void
|
||||
window_more_key(struct window *w, unused struct client *c, int key)
|
||||
window_more_key(struct window *w, struct client *c, int key)
|
||||
{
|
||||
struct window_more_mode_data *data = w->modedata;
|
||||
struct screen *s = &data->screen;
|
||||
int table;
|
||||
|
||||
switch (key) {
|
||||
case 'Q':
|
||||
case 'q':
|
||||
table = options_get_number(&c->session->options, "mode-keys");
|
||||
switch (mode_key_lookup(table, key)) {
|
||||
case MODEKEY_QUIT:
|
||||
window_reset_mode(w);
|
||||
break;
|
||||
case 'k':
|
||||
case 'K':
|
||||
case KEYC_UP:
|
||||
case MODEKEY_UP:
|
||||
window_more_scroll_up(w);
|
||||
break;
|
||||
case 'j':
|
||||
case 'J':
|
||||
case KEYC_DOWN:
|
||||
case MODEKEY_DOWN:
|
||||
window_more_scroll_down(w);
|
||||
break;
|
||||
case '\025': /* C-u */
|
||||
case KEYC_PPAGE:
|
||||
case MODEKEY_PPAGE:
|
||||
if (data->top < screen_size_y(s))
|
||||
data->top = 0;
|
||||
else
|
||||
data->top -= screen_size_y(s);
|
||||
window_more_redraw_screen(w);
|
||||
break;
|
||||
case '\006': /* C-f */
|
||||
case KEYC_NPAGE:
|
||||
case MODEKEY_NPAGE:
|
||||
if (data->top + screen_size_y(s) > ARRAY_LENGTH(&data->list))
|
||||
data->top = ARRAY_LENGTH(&data->list);
|
||||
else
|
||||
data->top += screen_size_y(s);
|
||||
window_more_redraw_screen(w);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: window-scroll.c,v 1.20 2008-06-22 16:56:47 nicm Exp $ */
|
||||
/* $Id: window-scroll.c,v 1.21 2008-07-02 21:22:57 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -97,50 +97,45 @@ window_scroll_resize(struct window *w, u_int sx, u_int sy)
|
||||
}
|
||||
|
||||
void
|
||||
window_scroll_key(struct window *w, unused struct client *c, int key)
|
||||
window_scroll_key(struct window *w, struct client *c, int key)
|
||||
{
|
||||
struct window_scroll_mode_data *data = w->modedata;
|
||||
struct screen *s = &data->screen;
|
||||
int table;
|
||||
|
||||
switch (key) {
|
||||
case 'Q':
|
||||
case 'q':
|
||||
table = options_get_number(&c->session->options, "mode-keys");
|
||||
switch (mode_key_lookup(table, key)) {
|
||||
case MODEKEY_QUIT:
|
||||
window_reset_mode(w);
|
||||
break;
|
||||
case 'h':
|
||||
case KEYC_LEFT:
|
||||
case MODEKEY_LEFT:
|
||||
window_scroll_scroll_left(w);
|
||||
break;
|
||||
case 'l':
|
||||
case KEYC_RIGHT:
|
||||
case MODEKEY_RIGHT:
|
||||
window_scroll_scroll_right(w);
|
||||
break;
|
||||
case 'k':
|
||||
case 'K':
|
||||
case KEYC_UP:
|
||||
case MODEKEY_UP:
|
||||
window_scroll_scroll_up(w);
|
||||
break;
|
||||
case 'j':
|
||||
case 'J':
|
||||
case KEYC_DOWN:
|
||||
case MODEKEY_DOWN:
|
||||
window_scroll_scroll_down(w);
|
||||
break;
|
||||
case '\025': /* C-u */
|
||||
case KEYC_PPAGE:
|
||||
case MODEKEY_PPAGE:
|
||||
if (data->oy + screen_size_y(s) > w->base.hsize)
|
||||
data->oy = w->base.hsize;
|
||||
else
|
||||
data->oy += screen_size_y(s);
|
||||
window_scroll_redraw_screen(w);
|
||||
break;
|
||||
case '\006': /* C-f */
|
||||
case KEYC_NPAGE:
|
||||
case MODEKEY_NPAGE:
|
||||
if (data->oy < screen_size_y(s))
|
||||
data->oy = 0;
|
||||
else
|
||||
data->oy -= screen_size_y(s);
|
||||
window_scroll_redraw_screen(w);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user