|PatchSet 876

|Date: 2011/03/29 20:30:16
|Author: nicm
|Branch: HEAD
|Tag: (none)
|Log:
|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:
Nicholas Marriott 2011-04-06 22:21:02 +00:00
parent 108fb38cbc
commit ffce6b34b2
6 changed files with 64 additions and 35 deletions

View File

@ -1,4 +1,4 @@
/* $Id: cmd-display-message.c,v 1.8 2011-01-07 14:45:34 tcunha Exp $ */ /* $Id: cmd-display-message.c,v 1.9 2011-04-06 22:21:02 nicm Exp $ */
/* /*
* Copyright (c) 2009 Tiago Cunha <me@tiagocunha.org> * Copyright (c) 2009 Tiago Cunha <me@tiagocunha.org>
@ -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

View File

@ -1,4 +1,4 @@
/* $Id: cmd-pipe-pane.c,v 1.17 2011-01-21 23:44:13 tcunha Exp $ */ /* $Id: cmd-pipe-pane.c,v 1.18 2011-04-06 22:21:02 nicm Exp $ */
/* /*
* Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
@ -112,7 +112,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:

View File

@ -1,4 +1,4 @@
/* $Id: server-client.c,v 1.54 2011-02-15 15:20:03 tcunha Exp $ */ /* $Id: server-client.c,v 1.55 2011-04-06 22:21:02 nicm Exp $ */
/* /*
* Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
@ -613,7 +613,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);

View File

@ -1,4 +1,4 @@
/* $Id: status.c,v 1.156 2011-02-15 15:20:03 tcunha Exp $ */ /* $Id: status.c,v 1.157 2011-04-06 22:21:02 nicm Exp $ */
/* /*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@ -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);
} }

12
tmux.1
View File

@ -1,4 +1,4 @@
.\" $Id: tmux.1,v 1.299 2011-04-06 22:20:16 nicm Exp $ .\" $Id: tmux.1,v 1.300 2011-04-06 22:21:02 nicm Exp $
.\" .\"
.\" Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> .\" Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
.\" .\"
@ -2615,7 +2615,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 )
@ -2629,7 +2630,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

6
tmux.h
View File

@ -1,4 +1,4 @@
/* $Id: tmux.h,v 1.615 2011-04-06 22:18:56 nicm Exp $ */ /* $Id: tmux.h,v 1.616 2011-04-06 22:21:02 nicm Exp $ */
/* /*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@ -1662,8 +1662,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 *);