mirror of
https://github.com/tmux/tmux.git
synced 2025-01-07 16:28:48 +00:00
Use a fixed buffer for strftime() because there is no portable way to
tell if the buffer is too small, and an expanding buffer is overkill anyway.
This commit is contained in:
parent
e81a92449e
commit
95a4cc3bce
17
format.c
17
format.c
@ -850,27 +850,18 @@ fail:
|
|||||||
char *
|
char *
|
||||||
format_expand_time(struct format_tree *ft, const char *fmt, time_t t)
|
format_expand_time(struct format_tree *ft, const char *fmt, time_t t)
|
||||||
{
|
{
|
||||||
char *tmp, *expanded;
|
|
||||||
size_t tmplen;
|
|
||||||
struct tm *tm;
|
struct tm *tm;
|
||||||
|
char s[2048];
|
||||||
|
|
||||||
if (fmt == NULL || *fmt == '\0')
|
if (fmt == NULL || *fmt == '\0')
|
||||||
return (xstrdup(""));
|
return (xstrdup(""));
|
||||||
|
|
||||||
tm = localtime(&t);
|
tm = localtime(&t);
|
||||||
|
|
||||||
tmp = NULL;
|
if (strftime(s, sizeof s, fmt, tm) == 0)
|
||||||
tmplen = strlen(fmt);
|
return (xstrdup(""));
|
||||||
|
|
||||||
do {
|
return (format_expand(ft, s));
|
||||||
tmp = xreallocarray(tmp, 2, tmplen);
|
|
||||||
tmplen *= 2;
|
|
||||||
} while (strftime(tmp, tmplen, fmt, tm) == 0);
|
|
||||||
|
|
||||||
expanded = format_expand(ft, tmp);
|
|
||||||
free(tmp);
|
|
||||||
|
|
||||||
return (expanded);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Expand keys in a template. */
|
/* Expand keys in a template. */
|
||||||
|
Loading…
Reference in New Issue
Block a user