blob: da6c1f8a5e90f42b7ab2e10b8e1cdc11cd5f3088 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
#include <wchar.h>
#include <time.h>
#include <string.h>
size_t wcsftime(wchar_t *restrict wcs, size_t n, const wchar_t *restrict f, const struct tm *restrict tm)
{
size_t k, n0=n;
char out[100], in[4];
while (*f) {
if (!n) return 0;
if (*f != '%') {
*wcs++ = *f++;
n--;
continue;
}
in[2] = in[3] = 0;
in[0] = *f++;
if (strchr("EO", (in[1]=*f++)))
in[2] = *f++;
k = strftime(out, sizeof out, in, tm);
if (!k) return 0;
k = mbsrtowcs(wcs, (const char *[]){out}, n, 0);
if (k==(size_t)-1) return 0;
wcs += k;
n -= k;
}
if (!n) return 0;
*wcs++ = 0;
return n0-n;
}
|