mirror of
https://github.com/tmux/tmux.git
synced 2025-01-07 16:28:48 +00:00
Change -t on display-message to be target-pane for the #[A-Z]
replacements and add -c as target-client.
This commit is contained in:
parent
f19a4bf9d1
commit
d88c20e718
@ -30,8 +30,8 @@ int cmd_display_message_exec(struct cmd *, struct cmd_ctx *);
|
|||||||
|
|
||||||
const struct cmd_entry cmd_display_message_entry = {
|
const struct cmd_entry cmd_display_message_entry = {
|
||||||
"display-message", "display",
|
"display-message", "display",
|
||||||
"pt:", 0, 1,
|
"c:pt:", 0, 1,
|
||||||
"[-p] " CMD_TARGET_CLIENT_USAGE " [message]",
|
"[-p] [-c target-client] [-t target-pane] [message]",
|
||||||
0,
|
0,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
@ -43,18 +43,31 @@ cmd_display_message_exec(struct cmd *self, struct cmd_ctx *ctx)
|
|||||||
{
|
{
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
struct client *c;
|
struct client *c;
|
||||||
|
struct session *s;
|
||||||
|
struct winlink *wl;
|
||||||
|
struct window_pane *wp;
|
||||||
const char *template;
|
const char *template;
|
||||||
char *msg;
|
char *msg;
|
||||||
|
|
||||||
if ((c = cmd_find_client(ctx, args_get(args, 't'))) == NULL)
|
if ((c = cmd_find_client(ctx, args_get(args, 'c'))) == NULL)
|
||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
|
if (args_has(args, 't') != NULL) {
|
||||||
|
wl = cmd_find_pane(ctx, args_get(args, 't'), &s, &wp);
|
||||||
|
if (wl == NULL)
|
||||||
|
return (-1);
|
||||||
|
} else {
|
||||||
|
s = NULL;
|
||||||
|
wl = NULL;
|
||||||
|
wp = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if (args->argc == 0)
|
if (args->argc == 0)
|
||||||
template = "[#S] #I:#W, current pane #P - (%H:%M %d-%b-%y)";
|
template = "[#S] #I:#W, current pane #P - (%H:%M %d-%b-%y)";
|
||||||
else
|
else
|
||||||
template = args->argv[0];
|
template = args->argv[0];
|
||||||
|
|
||||||
msg = status_replace(c, NULL, template, time(NULL), 0);
|
msg = status_replace(c, s, wl, wp, template, time(NULL), 0);
|
||||||
if (args_has(self->args, 'p'))
|
if (args_has(self->args, 'p'))
|
||||||
ctx->print(ctx, "%s", msg);
|
ctx->print(ctx, "%s", msg);
|
||||||
else
|
else
|
||||||
|
@ -113,7 +113,8 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmd_ctx *ctx)
|
|||||||
|
|
||||||
closefrom(STDERR_FILENO + 1);
|
closefrom(STDERR_FILENO + 1);
|
||||||
|
|
||||||
command = status_replace(c, NULL, args->argv[0], time(NULL), 0);
|
command = status_replace(
|
||||||
|
c, NULL, NULL, NULL, args->argv[0], time(NULL), 0);
|
||||||
execl(_PATH_BSHELL, "sh", "-c", command, (char *) NULL);
|
execl(_PATH_BSHELL, "sh", "-c", command, (char *) NULL);
|
||||||
_exit(1);
|
_exit(1);
|
||||||
default:
|
default:
|
||||||
|
@ -614,7 +614,7 @@ server_client_set_title(struct client *c)
|
|||||||
|
|
||||||
template = options_get_string(&s->options, "set-titles-string");
|
template = options_get_string(&s->options, "set-titles-string");
|
||||||
|
|
||||||
title = status_replace(c, NULL, template, time(NULL), 1);
|
title = status_replace(c, NULL, NULL, NULL, template, time(NULL), 1);
|
||||||
if (c->title == NULL || strcmp(title, c->title) != 0) {
|
if (c->title == NULL || strcmp(title, c->title) != 0) {
|
||||||
if (c->title != NULL)
|
if (c->title != NULL)
|
||||||
xfree(c->title);
|
xfree(c->title);
|
||||||
|
47
status.c
47
status.c
@ -38,8 +38,8 @@ void status_job_free(void *);
|
|||||||
void status_job_callback(struct job *);
|
void status_job_callback(struct job *);
|
||||||
char *status_print(
|
char *status_print(
|
||||||
struct client *, struct winlink *, time_t, struct grid_cell *);
|
struct client *, struct winlink *, time_t, struct grid_cell *);
|
||||||
void status_replace1(struct client *,
|
void status_replace1(struct client *, struct session *, struct winlink *,
|
||||||
struct winlink *, char **, char **, char *, size_t, int);
|
struct window_pane *, char **, char **, char *, size_t, int);
|
||||||
void status_message_callback(int, short, void *);
|
void status_message_callback(int, short, void *);
|
||||||
|
|
||||||
const char *status_prompt_up_history(u_int *);
|
const char *status_prompt_up_history(u_int *);
|
||||||
@ -80,8 +80,8 @@ status_redraw_get_left(struct client *c,
|
|||||||
if (attr != 0)
|
if (attr != 0)
|
||||||
gc->attr = attr;
|
gc->attr = attr;
|
||||||
|
|
||||||
left = status_replace(
|
left = status_replace(c, NULL,
|
||||||
c, NULL, options_get_string(&s->options, "status-left"), t, 1);
|
NULL, NULL, options_get_string(&s->options, "status-left"), t, 1);
|
||||||
|
|
||||||
*size = options_get_number(&s->options, "status-left-length");
|
*size = options_get_number(&s->options, "status-left-length");
|
||||||
leftlen = screen_write_cstrlen(utf8flag, "%s", left);
|
leftlen = screen_write_cstrlen(utf8flag, "%s", left);
|
||||||
@ -110,8 +110,8 @@ status_redraw_get_right(struct client *c,
|
|||||||
if (attr != 0)
|
if (attr != 0)
|
||||||
gc->attr = attr;
|
gc->attr = attr;
|
||||||
|
|
||||||
right = status_replace(
|
right = status_replace(c, NULL,
|
||||||
c, NULL, options_get_string(&s->options, "status-right"), t, 1);
|
NULL, NULL, options_get_string(&s->options, "status-right"), t, 1);
|
||||||
|
|
||||||
*size = options_get_number(&s->options, "status-right-length");
|
*size = options_get_number(&s->options, "status-right-length");
|
||||||
rightlen = screen_write_cstrlen(utf8flag, "%s", right);
|
rightlen = screen_write_cstrlen(utf8flag, "%s", right);
|
||||||
@ -347,16 +347,20 @@ out:
|
|||||||
|
|
||||||
/* Replace a single special sequence (prefixed by #). */
|
/* Replace a single special sequence (prefixed by #). */
|
||||||
void
|
void
|
||||||
status_replace1(struct client *c,struct winlink *wl,
|
status_replace1(struct client *c, struct session *s, struct winlink *wl,
|
||||||
char **iptr, char **optr, char *out, size_t outsize, int jobsflag)
|
struct window_pane *wp, char **iptr, char **optr, char *out,
|
||||||
|
size_t outsize, int jobsflag)
|
||||||
{
|
{
|
||||||
struct session *s = c->session;
|
char ch, tmp[256], *ptr, *endptr, *freeptr;
|
||||||
char ch, tmp[256], *ptr, *endptr, *freeptr;
|
size_t ptrlen;
|
||||||
size_t ptrlen;
|
long limit;
|
||||||
long limit;
|
|
||||||
|
|
||||||
|
if (s == NULL)
|
||||||
|
s = c->session;
|
||||||
if (wl == NULL)
|
if (wl == NULL)
|
||||||
wl = s->curw;
|
wl = s->curw;
|
||||||
|
if (wp == NULL)
|
||||||
|
wp = wl->window->active;
|
||||||
|
|
||||||
errno = 0;
|
errno = 0;
|
||||||
limit = strtol(*iptr, &endptr, 10);
|
limit = strtol(*iptr, &endptr, 10);
|
||||||
@ -379,6 +383,10 @@ status_replace1(struct client *c,struct winlink *wl,
|
|||||||
if ((ptr = status_find_job(c, iptr)) == NULL)
|
if ((ptr = status_find_job(c, iptr)) == NULL)
|
||||||
return;
|
return;
|
||||||
goto do_replace;
|
goto do_replace;
|
||||||
|
case 'D':
|
||||||
|
xsnprintf(tmp, sizeof tmp, "%%%u", wp->id);
|
||||||
|
ptr = tmp;
|
||||||
|
goto do_replace;
|
||||||
case 'H':
|
case 'H':
|
||||||
if (gethostname(tmp, sizeof tmp) != 0)
|
if (gethostname(tmp, sizeof tmp) != 0)
|
||||||
fatal("gethostname failed");
|
fatal("gethostname failed");
|
||||||
@ -389,15 +397,15 @@ status_replace1(struct client *c,struct winlink *wl,
|
|||||||
ptr = tmp;
|
ptr = tmp;
|
||||||
goto do_replace;
|
goto do_replace;
|
||||||
case 'P':
|
case 'P':
|
||||||
xsnprintf(tmp, sizeof tmp, "%u",
|
xsnprintf(
|
||||||
window_pane_index(wl->window, wl->window->active));
|
tmp, sizeof tmp, "%u", window_pane_index(wl->window, wp));
|
||||||
ptr = tmp;
|
ptr = tmp;
|
||||||
goto do_replace;
|
goto do_replace;
|
||||||
case 'S':
|
case 'S':
|
||||||
ptr = s->name;
|
ptr = s->name;
|
||||||
goto do_replace;
|
goto do_replace;
|
||||||
case 'T':
|
case 'T':
|
||||||
ptr = wl->window->active->base.title;
|
ptr = wp->base.title;
|
||||||
goto do_replace;
|
goto do_replace;
|
||||||
case 'W':
|
case 'W':
|
||||||
ptr = wl->window->name;
|
ptr = wl->window->name;
|
||||||
@ -449,8 +457,8 @@ skip_to:
|
|||||||
|
|
||||||
/* Replace special sequences in fmt. */
|
/* Replace special sequences in fmt. */
|
||||||
char *
|
char *
|
||||||
status_replace(struct client *c,
|
status_replace(struct client *c, struct session *s, struct winlink *wl,
|
||||||
struct winlink *wl, const char *fmt, time_t t, int jobsflag)
|
struct window_pane *wp, const char *fmt, time_t t, int jobsflag)
|
||||||
{
|
{
|
||||||
static char out[BUFSIZ];
|
static char out[BUFSIZ];
|
||||||
char in[BUFSIZ], ch, *iptr, *optr;
|
char in[BUFSIZ], ch, *iptr, *optr;
|
||||||
@ -470,7 +478,8 @@ status_replace(struct client *c,
|
|||||||
*optr++ = ch;
|
*optr++ = ch;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
status_replace1(c, wl, &iptr, &optr, out, sizeof out, jobsflag);
|
status_replace1(
|
||||||
|
c, s, wl, wp, &iptr, &optr, out, sizeof out, jobsflag);
|
||||||
}
|
}
|
||||||
*optr = '\0';
|
*optr = '\0';
|
||||||
|
|
||||||
@ -657,7 +666,7 @@ status_print(
|
|||||||
gc->attr = attr;
|
gc->attr = attr;
|
||||||
}
|
}
|
||||||
|
|
||||||
text = status_replace(c, wl, fmt, t, 1);
|
text = status_replace(c, NULL, wl, NULL, fmt, t, 1);
|
||||||
return (text);
|
return (text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
10
tmux.1
10
tmux.1
@ -2611,7 +2611,8 @@ This command works only from inside
|
|||||||
.Nm .
|
.Nm .
|
||||||
.It Xo Ic display-message
|
.It Xo Ic display-message
|
||||||
.Op Fl p
|
.Op Fl p
|
||||||
.Op Fl t Ar target-client
|
.Op Fl c Ar target-client
|
||||||
|
.Op Fl t Ar target-pane
|
||||||
.Op Ar message
|
.Op Ar message
|
||||||
.Xc
|
.Xc
|
||||||
.D1 (alias: Ic display )
|
.D1 (alias: Ic display )
|
||||||
@ -2625,7 +2626,12 @@ The format of
|
|||||||
.Ar message
|
.Ar message
|
||||||
is as for
|
is as for
|
||||||
.Ic status-left ,
|
.Ic status-left ,
|
||||||
with the exception that #() are not handled.
|
with the exception that #() are not handled; information is taken from
|
||||||
|
.Ar target-pane
|
||||||
|
if
|
||||||
|
.Fl t
|
||||||
|
is given, otherwise the active pane for the session attached to
|
||||||
|
.Ar target-client .
|
||||||
.El
|
.El
|
||||||
.Sh BUFFERS
|
.Sh BUFFERS
|
||||||
.Nm
|
.Nm
|
||||||
|
4
tmux.h
4
tmux.h
@ -1666,8 +1666,8 @@ RB_PROTOTYPE(status_out_tree, status_out, entry, status_out_cmp);
|
|||||||
void status_free_jobs(struct status_out_tree *);
|
void status_free_jobs(struct status_out_tree *);
|
||||||
void status_update_jobs(struct client *);
|
void status_update_jobs(struct client *);
|
||||||
int status_redraw(struct client *);
|
int status_redraw(struct client *);
|
||||||
char *status_replace(
|
char *status_replace(struct client *, struct session *,
|
||||||
struct client *, struct winlink *, const char *, time_t, int);
|
struct winlink *, struct window_pane *, const char *, time_t, int);
|
||||||
void printflike2 status_message_set(struct client *, const char *, ...);
|
void printflike2 status_message_set(struct client *, const char *, ...);
|
||||||
void status_message_clear(struct client *);
|
void status_message_clear(struct client *);
|
||||||
int status_message_redraw(struct client *);
|
int status_message_redraw(struct client *);
|
||||||
|
Loading…
Reference in New Issue
Block a user