Blame SOURCES/0058-Fix-os.date-for-wider-libc-strftime-compatibility.patch
|
 |
006bc1 |
From fc63c938b522e147ea728b75f385728bf4a8fc35 Mon Sep 17 00:00:00 2001
|
|
 |
006bc1 |
From: Mike Pall <mike>
|
|
 |
006bc1 |
Date: Thu, 10 Jan 2019 12:47:28 +0100
|
|
 |
006bc1 |
Subject: [PATCH 58/72] Fix os.date() for wider libc strftime() compatibility.
|
|
 |
006bc1 |
|
|
 |
006bc1 |
Thanks to Jesper Lundgren.
|
|
 |
006bc1 |
---
|
|
 |
006bc1 |
src/lib_os.c | 4 ++--
|
|
 |
006bc1 |
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
 |
006bc1 |
|
|
 |
006bc1 |
diff --git a/src/lib_os.c b/src/lib_os.c
|
|
 |
006bc1 |
index 9e78d49..ffbc3fd 100644
|
|
 |
006bc1 |
--- a/src/lib_os.c
|
|
 |
006bc1 |
+++ b/src/lib_os.c
|
|
 |
006bc1 |
@@ -205,12 +205,12 @@ LJLIB_CF(os_date)
|
|
 |
006bc1 |
setboolfield(L, "isdst", stm->tm_isdst);
|
|
 |
006bc1 |
} else if (*s) {
|
|
 |
006bc1 |
SBuf *sb = &G(L)->tmpbuf;
|
|
 |
006bc1 |
- MSize sz = 0;
|
|
 |
006bc1 |
+ MSize sz = 0, retry = 4;
|
|
 |
006bc1 |
const char *q;
|
|
 |
006bc1 |
for (q = s; *q; q++)
|
|
 |
006bc1 |
sz += (*q == '%') ? 30 : 1; /* Overflow doesn't matter. */
|
|
 |
006bc1 |
setsbufL(sb, L);
|
|
 |
006bc1 |
- for (;;) {
|
|
 |
006bc1 |
+ while (retry--) { /* Limit growth for invalid format or empty result. */
|
|
 |
006bc1 |
char *buf = lj_buf_need(sb, sz);
|
|
 |
006bc1 |
size_t len = strftime(buf, sbufsz(sb), s, stm);
|
|
 |
006bc1 |
if (len) {
|
|
 |
006bc1 |
--
|
|
 |
006bc1 |
2.20.1
|
|
 |
006bc1 |
|