patch 8.2.2894: MS-Windows: using enc_locale() for strftime() might not work
Problem: MS-Windows: using enc_locale() for strftime() might not work.
Solution: Use wcsftime(). (Ken Takata, closes #8271)
diff --git a/src/time.c b/src/time.c
index c5ab693..a28708f 100644
--- a/src/time.c
+++ b/src/time.c
@@ -252,7 +252,6 @@
void
f_strftime(typval_T *argvars, typval_T *rettv)
{
- char_u result_buf[256];
struct tm tmval;
struct tm *curtime;
time_t seconds;
@@ -271,6 +270,20 @@
rettv->vval.v_string = vim_strsave((char_u *)_("(Invalid)"));
else
{
+# ifdef MSWIN
+ WCHAR result_buf[256];
+ WCHAR *wp;
+
+ wp = enc_to_utf16(p, NULL);
+ if (wp != NULL)
+ (void)wcsftime(result_buf, sizeof(result_buf) / sizeof(WCHAR),
+ wp, curtime);
+ else
+ result_buf[0] = NUL;
+ rettv->vval.v_string = utf16_to_enc(result_buf, NULL);
+ vim_free(wp);
+# else
+ char_u result_buf[256];
vimconv_T conv;
char_u *enc;
@@ -296,6 +309,7 @@
// Release conversion descriptors
convert_setup(&conv, NULL, NULL);
vim_free(enc);
+# endif
}
}
# endif
diff --git a/src/version.c b/src/version.c
index 2dedcbf..4cf2c3e 100644
--- a/src/version.c
+++ b/src/version.c
@@ -751,6 +751,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 2894,
+/**/
2893,
/**/
2892,