mirror of
https://github.com/tmux/tmux.git
synced 2025-01-23 06:03:43 +00:00
Add P key to paste tagged in buffer mode, and trim some code that should
no longer be necessary.
This commit is contained in:
parent
26f1857154
commit
8dd776106d
@ -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
4
tmux.1
@ -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
2
tmux.h
@ -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 *,
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user