summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2012-08-27 21:29:24 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2012-08-27 21:29:24 +0000
commit1eaa35c2618ac9315e7c90c9794ad2886fed5c66 (patch)
treeddf8fd0b2de0cdf40678582e30cea0035db7f0e0
parent1be9091ae6d81c7f6ef2b42de5ca1041a4d5ee07 (diff)
Instead of requiring a prompt to enter all numbers >10, go back to
0-9a-z and add A-Z and enter the prompt when M-0 to M-9 are pressed (like in copy mode). Prompted by request from mcbride@, help from Thomas Adam.
-rw-r--r--usr.bin/tmux/mode-key.c42
-rw-r--r--usr.bin/tmux/window-choose.c129
2 files changed, 107 insertions, 64 deletions
diff --git a/usr.bin/tmux/mode-key.c b/usr.bin/tmux/mode-key.c
index 8e13579e99a..198ff39bb56 100644
--- a/usr.bin/tmux/mode-key.c
+++ b/usr.bin/tmux/mode-key.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mode-key.c,v 1.46 2012/08/11 06:45:33 nicm Exp $ */
+/* $OpenBSD: mode-key.c,v 1.47 2012/08/27 21:29:23 nicm Exp $ */
/*
* Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -192,16 +192,16 @@ struct mode_key_tree mode_key_tree_vi_edit;
/* vi choice selection keys. */
const struct mode_key_entry mode_key_vi_choice[] = {
- { '0', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '1', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '2', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '3', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '4', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '5', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '6', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '7', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '8', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '9', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '0' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '1' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '2' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '3' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '4' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '5' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '6' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '7' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '8' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '9' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
{ '\002' /* C-b */, 0, MODEKEYCHOICE_PAGEUP },
{ '\003' /* C-c */, 0, MODEKEYCHOICE_CANCEL },
{ '\005' /* C-e */, 0, MODEKEYCHOICE_SCROLLDOWN },
@@ -330,16 +330,16 @@ struct mode_key_tree mode_key_tree_emacs_edit;
/* emacs choice selection keys. */
const struct mode_key_entry mode_key_emacs_choice[] = {
- { '0', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '1', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '2', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '3', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '4', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '5', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '6', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '7', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '8', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
- { '9', 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '0' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '1' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '2' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '3' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '4' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '5' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '6' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '7' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '8' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
+ { '9' | KEYC_ESCAPE, 0, MODEKEYCHOICE_STARTNUMBERPREFIX },
{ '\003' /* C-c */, 0, MODEKEYCHOICE_CANCEL },
{ '\016' /* C-n */, 0, MODEKEYCHOICE_DOWN },
{ '\020' /* C-p */, 0, MODEKEYCHOICE_UP },
diff --git a/usr.bin/tmux/window-choose.c b/usr.bin/tmux/window-choose.c
index 7e4f16dbd48..4b18472ae49 100644
--- a/usr.bin/tmux/window-choose.c
+++ b/usr.bin/tmux/window-choose.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: window-choose.c,v 1.24 2012/08/14 09:17:14 nicm Exp $ */
+/* $OpenBSD: window-choose.c,v 1.25 2012/08/27 21:29:23 nicm Exp $ */
/*
* Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -71,7 +71,8 @@ struct window_choose_mode_data {
void (*freefn)(struct window_choose_data *);
};
-int window_choose_index_key(int);
+int window_choose_key_index(struct window_choose_mode_data *, u_int);
+int window_choose_index_key(struct window_choose_mode_data *, int);
void window_choose_prompt_input(enum window_choose_input_type,
const char *, struct window_pane *, int);
@@ -89,7 +90,7 @@ window_choose_add(struct window_pane *wp, struct window_choose_data *wcd)
item->wcd = wcd;
item->pos = ARRAY_LENGTH(&data->list) - 1;
- data->width = snprintf (tmp, sizeof tmp , "%u", item->pos);
+ data->width = xsnprintf (tmp, sizeof tmp , "%u", item->pos);
}
void
@@ -241,27 +242,48 @@ window_choose_key(struct window_pane *wp, unused struct session *sess, int key)
items = ARRAY_LENGTH(&data->list);
- switch (mode_key_lookup(&data->mdata, key)) {
- case MODEKEYCHOICE_CANCEL:
- window_choose_fire_callback(wp, NULL);
- window_pane_reset_mode(wp);
- break;
- case MODEKEYCHOICE_CHOOSE:
- switch (data->input_type) {
- case WINDOW_CHOOSE_NORMAL:
- item = &ARRAY_ITEM(&data->list, data->selected);
- window_choose_fire_callback(wp, item->wcd);
- window_pane_reset_mode(wp);
+ if (data->input_type == WINDOW_CHOOSE_GOTO_ITEM) {
+ switch (mode_key_lookup(&data->mdata, key)) {
+ case MODEKEYCHOICE_CANCEL:
+ data->input_type = WINDOW_CHOOSE_NORMAL;
+ window_choose_redraw_screen(wp);
break;
- case WINDOW_CHOOSE_GOTO_ITEM:
+ case MODEKEYCHOICE_CHOOSE:
n = strtonum(data->input_str, 0, INT_MAX, NULL);
- if (n > items - 1)
+ if (n > items - 1) {
+ data->input_type = WINDOW_CHOOSE_NORMAL;
+ window_choose_redraw_screen(wp);
break;
+ }
item = &ARRAY_ITEM(&data->list, n);
window_choose_fire_callback(wp, item->wcd);
window_pane_reset_mode(wp);
break;
+ case MODEKEYCHOICE_BACKSPACE:
+ input_len = strlen(data->input_str);
+ if (input_len > 0)
+ data->input_str[input_len - 1] = '\0';
+ window_choose_redraw_screen(wp);
+ break;
+ default:
+ if (key < '0' || key > '9')
+ break;
+ window_choose_prompt_input(WINDOW_CHOOSE_GOTO_ITEM,
+ "Goto Item", wp, key);
+ break;
}
+ return;
+ }
+
+ switch (mode_key_lookup(&data->mdata, key)) {
+ case MODEKEYCHOICE_CANCEL:
+ window_choose_fire_callback(wp, NULL);
+ window_pane_reset_mode(wp);
+ break;
+ case MODEKEYCHOICE_CHOOSE:
+ item = &ARRAY_ITEM(&data->list, data->selected);
+ window_choose_fire_callback(wp, item->wcd);
+ window_pane_reset_mode(wp);
break;
case MODEKEYCHOICE_UP:
if (items == 0)
@@ -366,29 +388,21 @@ window_choose_key(struct window_pane *wp, unused struct session *sess, int key)
window_choose_redraw_screen(wp);
break;
case MODEKEYCHOICE_STARTNUMBERPREFIX:
- if (key < '0' && key > '9')
+ key &= KEYC_MASK_KEY;
+ if (key < '0' || key > '9')
break;
-
- /*
- * If there's less than ten items (0-9) then pressing a number
- * will automatically select that item; otherwise, prompt for
- * the item to go to.
- */
- if (ARRAY_LENGTH(&data->list) - 1 <= 9) {
- idx = window_choose_index_key(key);
- if (idx < 0 || (u_int) idx >= ARRAY_LENGTH(&data->list))
- break;
- data->selected = idx;
-
- item = &ARRAY_ITEM(&data->list, data->selected);
- window_choose_fire_callback(wp, item->wcd);
- window_pane_reset_mode(wp);
- } else {
- window_choose_prompt_input(
- WINDOW_CHOOSE_GOTO_ITEM, "Goto item", wp, key);
- }
+ window_choose_prompt_input(WINDOW_CHOOSE_GOTO_ITEM,
+ "Goto Item", wp, key);
break;
default:
+ idx = window_choose_index_key(data, key);
+ if (idx < 0 || (u_int) idx >= ARRAY_LENGTH(&data->list))
+ break;
+ data->selected = idx;
+
+ item = &ARRAY_ITEM(&data->list, data->selected);
+ window_choose_fire_callback(wp, item->wcd);
+ window_pane_reset_mode(wp);
break;
}
}
@@ -430,8 +444,8 @@ window_choose_write_line(
struct screen *s = &data->screen;
struct grid_cell gc;
size_t last, xoff = 0;
- char hdr[32];
- int utf8flag;
+ char hdr[32], label[32];
+ int utf8flag, key;
if (data->callbackfn == NULL)
fatalx("called before callback assigned");
@@ -448,10 +462,14 @@ window_choose_write_line(
if (item->wcd->wl != NULL &&
item->wcd->wl->flags & WINLINK_ALERTFLAGS)
gc.attr |= GRID_ATTR_BRIGHT;
- screen_write_nputs(ctx, screen_size_x(s) - 1,
- &gc, utf8flag, "(%*d) %s", data->width,
- item->pos, item->name);
+ key = window_choose_key_index(data, data->top + py);
+ if (key != -1)
+ xsnprintf (label, sizeof label, "(%c)", key);
+ else
+ xsnprintf (label, sizeof label, "(%d)", item->pos);
+ screen_write_nputs(ctx, screen_size_x(s) - 1, &gc, utf8flag,
+ "%*s %s", data->width + 2, label, item->name);
}
while (s->cx < screen_size_x(s))
screen_write_putc(ctx, &gc, ' ');
@@ -470,13 +488,38 @@ window_choose_write_line(
}
int
-window_choose_index_key(int key)
+window_choose_key_index(struct window_choose_mode_data *data, u_int idx)
+{
+ static const char keys[] = "0123456789"
+ "abcdefghijklmnopqrstuvwxyz"
+ "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
+ const char *ptr;
+ int mkey;
+
+ for (ptr = keys; *ptr != '\0'; ptr++) {
+ mkey = mode_key_lookup(&data->mdata, *ptr);
+ if (mkey != MODEKEY_NONE && mkey != MODEKEY_OTHER)
+ continue;
+ if (idx-- == 0)
+ return (*ptr);
+ }
+ return (-1);
+}
+
+int
+window_choose_index_key(struct window_choose_mode_data *data, int key)
{
- static const char keys[] = "0123456789";
+ static const char keys[] = "0123456789"
+ "abcdefghijklmnopqrstuvwxyz"
+ "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
const char *ptr;
+ int mkey;
u_int idx = 0;
for (ptr = keys; *ptr != '\0'; ptr++) {
+ mkey = mode_key_lookup(&data->mdata, *ptr);
+ if (mkey != MODEKEY_NONE && mkey != MODEKEY_OTHER)
+ continue;
if (key == *ptr)
return (idx);
idx++;