mirror of
https://github.com/tmux/tmux.git
synced 2025-01-07 16:28:48 +00:00
Allow a custom time format to be given to the t format modifier.
This commit is contained in:
parent
367b4e4e0f
commit
daa95810b5
55
format.c
55
format.c
@ -44,7 +44,6 @@ typedef void (*format_cb)(struct format_tree *, struct format_entry *);
|
|||||||
static char *format_job_get(struct format_tree *, const char *);
|
static char *format_job_get(struct format_tree *, const char *);
|
||||||
static void format_job_timer(int, short, void *);
|
static void format_job_timer(int, short, void *);
|
||||||
|
|
||||||
static char *format_find(struct format_tree *, const char *, int);
|
|
||||||
static void format_add_cb(struct format_tree *, const char *, format_cb);
|
static void format_add_cb(struct format_tree *, const char *, format_cb);
|
||||||
static int format_replace(struct format_tree *, const char *, size_t,
|
static int format_replace(struct format_tree *, const char *, size_t,
|
||||||
char **, size_t *, size_t *);
|
char **, size_t *, size_t *);
|
||||||
@ -122,8 +121,8 @@ struct format_tree {
|
|||||||
|
|
||||||
struct cmdq_item *item;
|
struct cmdq_item *item;
|
||||||
struct client *client;
|
struct client *client;
|
||||||
u_int tag;
|
|
||||||
int flags;
|
int flags;
|
||||||
|
u_int tag;
|
||||||
time_t time;
|
time_t time;
|
||||||
u_int loop;
|
u_int loop;
|
||||||
|
|
||||||
@ -1369,16 +1368,17 @@ format_pretty_time(time_t t)
|
|||||||
|
|
||||||
/* Find a format entry. */
|
/* Find a format entry. */
|
||||||
static char *
|
static char *
|
||||||
format_find(struct format_tree *ft, const char *key, int modifiers)
|
format_find(struct format_tree *ft, const char *key, int modifiers,
|
||||||
|
const char *time_format)
|
||||||
{
|
{
|
||||||
struct format_entry *fe, fe_find;
|
struct format_entry *fe, fe_find;
|
||||||
struct environ_entry *envent;
|
struct environ_entry *envent;
|
||||||
static char s[64];
|
|
||||||
struct options_entry *o;
|
struct options_entry *o;
|
||||||
int idx;
|
int idx;
|
||||||
char *found = NULL, *saved;
|
char *found = NULL, *saved, s[512];
|
||||||
const char *errstr;
|
const char *errstr;
|
||||||
time_t t = 0;
|
time_t t = 0;
|
||||||
|
struct tm tm;
|
||||||
|
|
||||||
o = options_parse_get(global_options, key, &idx, 0);
|
o = options_parse_get(global_options, key, &idx, 0);
|
||||||
if (o == NULL && ft->wp != NULL)
|
if (o == NULL && ft->wp != NULL)
|
||||||
@ -1438,8 +1438,13 @@ found:
|
|||||||
if (modifiers & FORMAT_PRETTY)
|
if (modifiers & FORMAT_PRETTY)
|
||||||
found = format_pretty_time(t);
|
found = format_pretty_time(t);
|
||||||
else {
|
else {
|
||||||
ctime_r(&t, s);
|
if (time_format != NULL) {
|
||||||
s[strcspn(s, "\n")] = '\0';
|
localtime_r(&t, &tm);
|
||||||
|
strftime(s, sizeof s, time_format, &tm);
|
||||||
|
} else {
|
||||||
|
ctime_r(&t, s);
|
||||||
|
s[strcspn(s, "\n")] = '\0';
|
||||||
|
}
|
||||||
found = xstrdup(s);
|
found = xstrdup(s);
|
||||||
}
|
}
|
||||||
return (found);
|
return (found);
|
||||||
@ -1467,6 +1472,30 @@ found:
|
|||||||
return (found);
|
return (found);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Remove escaped characters from string. */
|
||||||
|
static char *
|
||||||
|
format_strip(const char *s)
|
||||||
|
{
|
||||||
|
char *out, *cp;
|
||||||
|
int brackets = 0;
|
||||||
|
|
||||||
|
cp = out = xmalloc(strlen(s) + 1);
|
||||||
|
for (; *s != '\0'; s++) {
|
||||||
|
if (*s == '#' && s[1] == '{')
|
||||||
|
brackets++;
|
||||||
|
if (*s == '#' && strchr(",#{}:", s[1]) != NULL) {
|
||||||
|
if (brackets != 0)
|
||||||
|
*cp++ = *s;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (*s == '}')
|
||||||
|
brackets--;
|
||||||
|
*cp++ = *s;
|
||||||
|
}
|
||||||
|
*cp = '\0';
|
||||||
|
return (out);
|
||||||
|
}
|
||||||
|
|
||||||
/* Skip until end. */
|
/* Skip until end. */
|
||||||
const char *
|
const char *
|
||||||
format_skip(const char *s, const char *end)
|
format_skip(const char *s, const char *end)
|
||||||
@ -1476,7 +1505,7 @@ format_skip(const char *s, const char *end)
|
|||||||
for (; *s != '\0'; s++) {
|
for (; *s != '\0'; s++) {
|
||||||
if (*s == '#' && s[1] == '{')
|
if (*s == '#' && s[1] == '{')
|
||||||
brackets++;
|
brackets++;
|
||||||
if (*s == '#' && strchr(",#{}", s[1]) != NULL) {
|
if (*s == '#' && strchr(",#{}:", s[1]) != NULL) {
|
||||||
s++;
|
s++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -1584,7 +1613,7 @@ format_build_modifiers(struct format_tree *ft, const char **s, u_int *count)
|
|||||||
*count = 0;
|
*count = 0;
|
||||||
|
|
||||||
while (*cp != '\0' && *cp != ':') {
|
while (*cp != '\0' && *cp != ':') {
|
||||||
/* Skip and separator character. */
|
/* Skip any separator character. */
|
||||||
if (*cp == ';')
|
if (*cp == ';')
|
||||||
cp++;
|
cp++;
|
||||||
|
|
||||||
@ -1975,6 +2004,7 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
|
|||||||
{
|
{
|
||||||
struct window_pane *wp = ft->wp;
|
struct window_pane *wp = ft->wp;
|
||||||
const char *errptr, *copy, *cp, *marker = NULL;
|
const char *errptr, *copy, *cp, *marker = NULL;
|
||||||
|
const char *time_format = NULL;
|
||||||
char *copy0, *condition, *found, *new;
|
char *copy0, *condition, *found, *new;
|
||||||
char *value, *left, *right;
|
char *value, *left, *right;
|
||||||
size_t valuelen;
|
size_t valuelen;
|
||||||
@ -2052,6 +2082,9 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
|
|||||||
break;
|
break;
|
||||||
if (strchr(fm->argv[0], 'p') != NULL)
|
if (strchr(fm->argv[0], 'p') != NULL)
|
||||||
modifiers |= FORMAT_PRETTY;
|
modifiers |= FORMAT_PRETTY;
|
||||||
|
else if (fm->argc >= 2 &&
|
||||||
|
strchr(fm->argv[0], 'f') != NULL)
|
||||||
|
time_format = format_strip(fm->argv[1]);
|
||||||
break;
|
break;
|
||||||
case 'q':
|
case 'q':
|
||||||
modifiers |= FORMAT_QUOTE;
|
modifiers |= FORMAT_QUOTE;
|
||||||
@ -2178,7 +2211,7 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
|
|||||||
condition = xstrndup(copy + 1, cp - (copy + 1));
|
condition = xstrndup(copy + 1, cp - (copy + 1));
|
||||||
format_log(ft, "condition is: %s", condition);
|
format_log(ft, "condition is: %s", condition);
|
||||||
|
|
||||||
found = format_find(ft, condition, modifiers);
|
found = format_find(ft, condition, modifiers, time_format);
|
||||||
if (found == NULL) {
|
if (found == NULL) {
|
||||||
/*
|
/*
|
||||||
* If the condition not found, try to expand it. If
|
* If the condition not found, try to expand it. If
|
||||||
@ -2223,7 +2256,7 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
|
|||||||
value = xstrdup("");
|
value = xstrdup("");
|
||||||
} else {
|
} else {
|
||||||
/* Neither: look up directly. */
|
/* Neither: look up directly. */
|
||||||
value = format_find(ft, copy, modifiers);
|
value = format_find(ft, copy, modifiers, time_format);
|
||||||
if (value == NULL) {
|
if (value == NULL) {
|
||||||
format_log(ft, "format '%s' not found", copy);
|
format_log(ft, "format '%s' not found", copy);
|
||||||
value = xstrdup("");
|
value = xstrdup("");
|
||||||
|
15
tmux.1
15
tmux.1
@ -4407,6 +4407,21 @@ Adding
|
|||||||
.Ql p (
|
.Ql p (
|
||||||
.Ql `t/p` )
|
.Ql `t/p` )
|
||||||
will use shorter but less accurate time format for times in the past.
|
will use shorter but less accurate time format for times in the past.
|
||||||
|
A custom format may be given using an
|
||||||
|
.Ql f
|
||||||
|
suffix (note that
|
||||||
|
.Ql %
|
||||||
|
must be escaped as
|
||||||
|
.Ql %%
|
||||||
|
if the format is separately being passed through
|
||||||
|
.Xr strftime 3 ,
|
||||||
|
for example in the
|
||||||
|
.Ic status-left
|
||||||
|
option):
|
||||||
|
.Ql #{t/f/%%H#:%%M:window_activity} ,
|
||||||
|
see
|
||||||
|
.Xr strftime 3 .
|
||||||
|
.Pp
|
||||||
The
|
The
|
||||||
.Ql b:\&
|
.Ql b:\&
|
||||||
and
|
and
|
||||||
|
Loading…
Reference in New Issue
Block a user