status_replace can now become local to status.c and it no longer needs

the jobsflag argument. While here there is no need to repeat work that
format_defaults already does.
This commit is contained in:
nicm 2015-02-06 17:21:08 +00:00
parent 8d94bb67ab
commit 313f2263f8
2 changed files with 15 additions and 30 deletions

View File

@ -29,16 +29,17 @@
#include "tmux.h" #include "tmux.h"
char *status_redraw_get_left( char *status_redraw_get_left(struct client *, time_t, int, struct grid_cell *,
struct client *, time_t, int, struct grid_cell *, size_t *); size_t *);
char *status_redraw_get_right( char *status_redraw_get_right(struct client *, time_t, int,
struct client *, time_t, int, struct grid_cell *, size_t *); struct grid_cell *, size_t *);
char *status_find_job(struct client *, char **); char *status_find_job(struct client *, char **);
void status_job_free(void *); 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 client *, struct winlink *, time_t, struct grid_cell *); struct grid_cell *);
void status_replace1(struct client *, char **, char **, char *, size_t, int); char *status_replace(struct client *, struct winlink *, const char *, time_t);
void status_replace1(struct client *, char **, char **, char *, size_t);
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 *);
@ -86,7 +87,7 @@ status_redraw_get_left(struct client *c, time_t t, int utf8flag,
style_apply_update(gc, &s->options, "status-left-style"); style_apply_update(gc, &s->options, "status-left-style");
template = options_get_string(&s->options, "status-left"); template = options_get_string(&s->options, "status-left");
left = status_replace(c, NULL, template , t, 1); left = status_replace(c, NULL, template, t);
*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);
@ -108,7 +109,7 @@ status_redraw_get_right(struct client *c, time_t t, int utf8flag,
style_apply_update(gc, &s->options, "status-right-style"); style_apply_update(gc, &s->options, "status-right-style");
template = options_get_string(&s->options, "status-right"); template = options_get_string(&s->options, "status-right");
right = status_replace(c, NULL, template, t, 1); right = status_replace(c, NULL, template, t);
*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);
@ -364,7 +365,7 @@ out:
/* Replace a single special sequence (prefixed by #). */ /* Replace a single special sequence (prefixed by #). */
void void
status_replace1(struct client *c, char **iptr, char **optr, char *out, status_replace1(struct client *c, char **iptr, char **optr, char *out,
size_t outsize, int jobsflag) size_t outsize)
{ {
char ch, tmp[256], *ptr, *endptr; char ch, tmp[256], *ptr, *endptr;
size_t ptrlen; size_t ptrlen;
@ -382,10 +383,6 @@ status_replace1(struct client *c, char **iptr, char **optr, char *out,
switch (*(*iptr)++) { switch (*(*iptr)++) {
case '(': case '(':
if (!jobsflag) {
ch = ')';
goto skip_to;
}
if ((ptr = status_find_job(c, iptr)) == NULL) if ((ptr = status_find_job(c, iptr)) == NULL)
return; return;
goto do_replace; goto do_replace;
@ -434,11 +431,8 @@ skip_to:
/* Replace special sequences in fmt. */ /* Replace special sequences in fmt. */
char * char *
status_replace(struct client *c, struct winlink *wl, const char *fmt, time_t t, status_replace(struct client *c, struct winlink *wl, const char *fmt, time_t t)
int jobsflag)
{ {
struct session *s = NULL;
struct window_pane *wp = NULL;
static char out[BUFSIZ]; static char out[BUFSIZ];
char in[BUFSIZ], ch, *iptr, *optr, *expanded; char in[BUFSIZ], ch, *iptr, *optr, *expanded;
size_t len; size_t len;
@ -447,13 +441,6 @@ status_replace(struct client *c, struct winlink *wl, const char *fmt, time_t t,
if (fmt == NULL) if (fmt == NULL)
return (xstrdup("")); return (xstrdup(""));
if (c != NULL)
s = c->session;
if (wl == NULL && s != NULL)
wl = s->curw;
if (wl != NULL)
wp = wl->window->active;
len = strftime(in, sizeof in, fmt, localtime(&t)); len = strftime(in, sizeof in, fmt, localtime(&t));
in[len] = '\0'; in[len] = '\0';
@ -469,12 +456,12 @@ status_replace(struct client *c, struct winlink *wl, const char *fmt, time_t t,
*optr++ = ch; *optr++ = ch;
continue; continue;
} }
status_replace1(c, &iptr, &optr, out, sizeof out, jobsflag); status_replace1(c, &iptr, &optr, out, sizeof out);
} }
*optr = '\0'; *optr = '\0';
ft = format_create(); ft = format_create();
format_defaults(ft, c, s, wl, wp); format_defaults(ft, c, NULL, wl, NULL);
expanded = format_expand(ft, out); expanded = format_expand(ft, out);
format_free(ft); format_free(ft);
return (expanded); return (expanded);
@ -639,7 +626,7 @@ status_print(struct client *c, struct winlink *wl, time_t t,
else if (wl->flags & (WINLINK_ACTIVITY|WINLINK_SILENCE)) else if (wl->flags & (WINLINK_ACTIVITY|WINLINK_SILENCE))
style_apply_update(gc, oo, "window-status-activity-style"); style_apply_update(gc, oo, "window-status-activity-style");
text = status_replace(c, wl, fmt, t, 1); text = status_replace(c, wl, fmt, t);
return (text); return (text);
} }

2
tmux.h
View File

@ -1925,8 +1925,6 @@ void status_free_jobs(struct status_out_tree *);
void status_update_jobs(struct client *); void status_update_jobs(struct client *);
void status_set_window_at(struct client *, u_int); void status_set_window_at(struct client *, u_int);
int status_redraw(struct client *); int status_redraw(struct client *);
char *status_replace(struct client *, struct winlink *, const char *, time_t,
int);
void printflike(2, 3) status_message_set(struct client *, const char *, ...); void printflike(2, 3) 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 *);