mirror of
https://github.com/tmux/tmux.git
synced 2025-01-23 06:03:43 +00:00
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:
parent
8d94bb67ab
commit
313f2263f8
43
status.c
43
status.c
@ -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
2
tmux.h
@ -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 *);
|
||||||
|
Loading…
Reference in New Issue
Block a user