Add P key to paste tagged in buffer mode, and trim some code that should

no longer be necessary.
This commit is contained in:
nicm 2017-10-25 11:26:11 +00:00
parent 26f1857154
commit 8dd776106d
6 changed files with 61 additions and 84 deletions

View File

@ -266,7 +266,7 @@ mode_tree_count_tagged(struct mode_tree_data *mtd)
void void
mode_tree_each_tagged(struct mode_tree_data *mtd, void (*cb)(void *, void *, mode_tree_each_tagged(struct mode_tree_data *mtd, void (*cb)(void *, void *,
key_code), key_code key, int current) struct client *, key_code), struct client *c, key_code key, int current)
{ {
struct mode_tree_item *mti; struct mode_tree_item *mti;
u_int i; u_int i;
@ -277,12 +277,12 @@ mode_tree_each_tagged(struct mode_tree_data *mtd, void (*cb)(void *, void *,
mti = mtd->line_list[i].item; mti = mtd->line_list[i].item;
if (mti->tagged) { if (mti->tagged) {
fired = 1; fired = 1;
cb(mtd->modedata, mti->itemdata, key); cb(mtd->modedata, mti->itemdata, c, key);
} }
} }
if (!fired && current) { if (!fired && current) {
mti = mtd->line_list[mtd->current].item; mti = mtd->line_list[mtd->current].item;
cb(mtd->modedata, mti->itemdata, key); cb(mtd->modedata, mti->itemdata, c, key);
} }
} }

4
tmux.1
View File

@ -4098,7 +4098,7 @@ a list.
The following keys may be used in buffer mode: The following keys may be used in buffer mode:
.Bl -column "Key" "Function" -offset indent .Bl -column "Key" "Function" -offset indent
.It Sy "Key" Ta Sy "Function" .It Sy "Key" Ta Sy "Function"
.It Li "Enter" Ta "Choose selected buffer" .It Li "Enter" Ta "Paste selected buffer"
.It Li "Up" Ta "Select previous buffer" .It Li "Up" Ta "Select previous buffer"
.It Li "Down" Ta "Select next buffer" .It Li "Down" Ta "Select next buffer"
.It Li "C-s" Ta "Search by name or content" .It Li "C-s" Ta "Search by name or content"
@ -4106,6 +4106,8 @@ The following keys may be used in buffer mode:
.It Li "t" Ta "Toggle if buffer is tagged" .It Li "t" Ta "Toggle if buffer is tagged"
.It Li "T" Ta "Tag no buffers" .It Li "T" Ta "Tag no buffers"
.It Li "C-t" Ta "Tag all buffers" .It Li "C-t" Ta "Tag all buffers"
.It Li "p" Ta "Paste selected buffer"
.It Li "P" Ta "Paste tagged buffers"
.It Li "d" Ta "Delete selected buffer" .It Li "d" Ta "Delete selected buffer"
.It Li "D" Ta "Delete tagged buffers" .It Li "D" Ta "Delete tagged buffers"
.It Li "f" Ta "Enter a format to filter items" .It Li "f" Ta "Enter a format to filter items"

2
tmux.h
View File

@ -2226,7 +2226,7 @@ u_int layout_set_previous(struct window *);
u_int mode_tree_count_tagged(struct mode_tree_data *); u_int mode_tree_count_tagged(struct mode_tree_data *);
void *mode_tree_get_current(struct mode_tree_data *); void *mode_tree_get_current(struct mode_tree_data *);
void mode_tree_each_tagged(struct mode_tree_data *, void (*)(void *, void *, void mode_tree_each_tagged(struct mode_tree_data *, void (*)(void *, void *,
key_code), key_code, int); struct client *, key_code), struct client *, key_code, int);
void mode_tree_up(struct mode_tree_data *, int); void mode_tree_up(struct mode_tree_data *, int);
void mode_tree_down(struct mode_tree_data *, int); void mode_tree_down(struct mode_tree_data *, int);
struct mode_tree_data *mode_tree_start(struct window_pane *, struct args *, struct mode_tree_data *mode_tree_start(struct window_pane *, struct args *,

View File

@ -319,7 +319,8 @@ window_buffer_resize(struct window_pane *wp, u_int sx, u_int sy)
} }
static void static void
window_buffer_do_delete(void* modedata, void *itemdata, __unused key_code key) window_buffer_do_delete(void* modedata, void *itemdata,
__unused struct client *c, __unused key_code key)
{ {
struct window_buffer_modedata *data = modedata; struct window_buffer_modedata *data = modedata;
struct window_buffer_itemdata *item = itemdata; struct window_buffer_itemdata *item = itemdata;
@ -331,53 +332,53 @@ window_buffer_do_delete(void* modedata, void *itemdata, __unused key_code key)
paste_free(pb); paste_free(pb);
} }
static void
window_buffer_do_paste(void* modedata, void *itemdata, struct client *c,
__unused key_code key)
{
struct window_buffer_modedata *data = modedata;
struct window_buffer_itemdata *item = itemdata;
struct paste_buffer *pb;
if ((pb = paste_get_name(item->name)) != NULL)
mode_tree_run_command(c, NULL, data->command, item->name);
}
static void static void
window_buffer_key(struct window_pane *wp, struct client *c, window_buffer_key(struct window_pane *wp, struct client *c,
__unused struct session *s, key_code key, struct mouse_event *m) __unused struct session *s, key_code key, struct mouse_event *m)
{ {
struct window_buffer_modedata *data = wp->modedata; struct window_buffer_modedata *data = wp->modedata;
struct mode_tree_data *mtd = data->data;
struct window_buffer_itemdata *item; struct window_buffer_itemdata *item;
char *command, *name;
int finished; int finished;
/* finished = mode_tree_key(mtd, c, &key, m);
* t = toggle tag
* T = tag none
* C-t = tag all
* q = exit
* O = change sort order
*
* d = delete buffer
* D = delete tagged buffers
* Enter = paste buffer
*/
finished = mode_tree_key(data->data, c, &key, m);
switch (key) { switch (key) {
case 'd': case 'd':
item = mode_tree_get_current(data->data); item = mode_tree_get_current(mtd);
window_buffer_do_delete(data, item, key); window_buffer_do_delete(data, item, c, key);
mode_tree_build(data->data); mode_tree_build(mtd);
break; break;
case 'D': case 'D':
mode_tree_each_tagged(data->data, window_buffer_do_delete, key, mode_tree_each_tagged(mtd, window_buffer_do_delete, c, key, 0);
0); mode_tree_build(mtd);
mode_tree_build(data->data);
break; break;
case 'P':
mode_tree_each_tagged(mtd, window_buffer_do_paste, c, key, 0);
finished = 1;
break;
case 'p':
case '\r': case '\r':
item = mode_tree_get_current(data->data); item = mode_tree_get_current(mtd);
command = xstrdup(data->command); window_buffer_do_paste(data, item, c, key);
name = xstrdup(item->name); finished = 1;
window_pane_reset_mode(wp); break;
mode_tree_run_command(c, NULL, command, name);
free(name);
free(command);
return;
} }
if (finished || paste_get_top(NULL) == NULL) if (finished || paste_get_top(NULL) == NULL)
window_pane_reset_mode(wp); window_pane_reset_mode(wp);
else { else {
mode_tree_draw(data->data); mode_tree_draw(mtd);
wp->flags |= PANE_REDRAW; wp->flags |= PANE_REDRAW;
} }
} }

View File

@ -301,7 +301,8 @@ window_client_resize(struct window_pane *wp, u_int sx, u_int sy)
} }
static void static void
window_client_do_detach(void* modedata, void *itemdata, key_code key) window_client_do_detach(void* modedata, void *itemdata,
__unused struct client *c, key_code key)
{ {
struct window_client_modedata *data = modedata; struct window_client_modedata *data = modedata;
struct window_client_itemdata *item = itemdata; struct window_client_itemdata *item = itemdata;
@ -321,56 +322,35 @@ window_client_key(struct window_pane *wp, struct client *c,
__unused struct session *s, key_code key, struct mouse_event *m) __unused struct session *s, key_code key, struct mouse_event *m)
{ {
struct window_client_modedata *data = wp->modedata; struct window_client_modedata *data = wp->modedata;
struct mode_tree_data *mtd = data->data;
struct window_client_itemdata *item; struct window_client_itemdata *item;
char *command, *name;
int finished; int finished;
/* finished = mode_tree_key(mtd, c, &key, m);
* t = toggle tag
* T = tag none
* C-t = tag all
* q = exit
* O = change sort order
*
* d = detach client
* D = detach tagged clients
* x = detach and kill client
* X = detach and kill tagged clients
* z = suspend client
* Z = suspend tagged clients
* Enter = detach client
*/
finished = mode_tree_key(data->data, c, &key, m);
switch (key) { switch (key) {
case 'd': case 'd':
case 'x': case 'x':
case 'z': case 'z':
item = mode_tree_get_current(data->data); item = mode_tree_get_current(mtd);
window_client_do_detach(data, item, key); window_client_do_detach(data, item, c, key);
mode_tree_build(data->data); mode_tree_build(mtd);
break; break;
case 'D': case 'D':
case 'X': case 'X':
case 'Z': case 'Z':
mode_tree_each_tagged(data->data, window_client_do_detach, key, mode_tree_each_tagged(mtd, window_client_do_detach, c, key, 0);
0); mode_tree_build(mtd);
mode_tree_build(data->data);
break; break;
case '\r': case '\r':
item = mode_tree_get_current(data->data); item = mode_tree_get_current(mtd);
command = xstrdup(data->command); mode_tree_run_command(c, NULL, data->command, item->c->ttyname);
name = xstrdup(item->c->ttyname); finished = 1;
window_pane_reset_mode(wp); break;
mode_tree_run_command(c, NULL, command, name);
free(name);
free(command);
return;
} }
if (finished || server_client_how_many() == 0) if (finished || server_client_how_many() == 0)
window_pane_reset_mode(wp); window_pane_reset_mode(wp);
else { else {
mode_tree_draw(data->data); mode_tree_draw(mtd);
wp->flags |= PANE_REDRAW; wp->flags |= PANE_REDRAW;
} }
} }

View File

@ -95,7 +95,6 @@ struct window_tree_modedata {
struct window_tree_itemdata **item_list; struct window_tree_itemdata **item_list;
u_int item_size; u_int item_size;
struct client *client;
const char *entered; const char *entered;
struct cmd_find_state fs; struct cmd_find_state fs;
@ -898,7 +897,8 @@ window_tree_get_target(struct window_tree_itemdata *item,
} }
static void static void
window_tree_command_each(void* modedata, void* itemdata, __unused key_code key) window_tree_command_each(void* modedata, void* itemdata, struct client *c,
__unused key_code key)
{ {
struct window_tree_modedata *data = modedata; struct window_tree_modedata *data = modedata;
struct window_tree_itemdata *item = itemdata; struct window_tree_itemdata *item = itemdata;
@ -907,7 +907,7 @@ window_tree_command_each(void* modedata, void* itemdata, __unused key_code key)
name = window_tree_get_target(item, &fs); name = window_tree_get_target(item, &fs);
if (name != NULL) if (name != NULL)
mode_tree_run_command(data->client, &fs, data->entered, name); mode_tree_run_command(c, &fs, data->entered, name);
free(name); free(name);
} }
@ -934,13 +934,9 @@ window_tree_command_callback(struct client *c, void *modedata, const char *s,
if (data->dead) if (data->dead)
return (0); return (0);
data->client = c;
data->entered = s; data->entered = s;
mode_tree_each_tagged(data->data, window_tree_command_each, c,
mode_tree_each_tagged(data->data, window_tree_command_each, KEYC_NONE, KEYC_NONE, 1);
1);
data->client = NULL;
data->entered = NULL; data->entered = NULL;
data->references++; data->references++;
@ -963,7 +959,7 @@ window_tree_key(struct window_pane *wp, struct client *c,
{ {
struct window_tree_modedata *data = wp->modedata; struct window_tree_modedata *data = wp->modedata;
struct window_tree_itemdata *item; struct window_tree_itemdata *item;
char *command, *name, *prompt; char *name, *prompt;
struct cmd_find_state fs; struct cmd_find_state fs;
int finished; int finished;
u_int tagged; u_int tagged;
@ -992,14 +988,12 @@ window_tree_key(struct window_pane *wp, struct client *c,
break; break;
case '\r': case '\r':
item = mode_tree_get_current(data->data); item = mode_tree_get_current(data->data);
command = xstrdup(data->command);
name = window_tree_get_target(item, &fs); name = window_tree_get_target(item, &fs);
window_pane_reset_mode(wp);
if (name != NULL) if (name != NULL)
mode_tree_run_command(c, NULL, command, name); mode_tree_run_command(c, NULL, data->command, name);
finished = 1;
free(name); free(name);
free(command); break;
return;
} }
if (finished) if (finished)
window_pane_reset_mode(wp); window_pane_reset_mode(wp);