# HG changeset patch # User Bram Moolenaar # Date 1622210404 -7200 # Node ID 788d7e3ade7ce00ca315aac6ade9f24903a3fbe4 # Parent 8e69a6ba0341119bc8803e4b50eadb63c20c8bd3 patch 8.2.2894: MS-Windows: using enc_locale() for strftime() might not work Commit: https://github.com/vim/vim/commit/2c4a1d0a619b0f1e0f7dac98681da6fee58c6a44 Author: K.Takata Date: Fri May 28 15:49:34 2021 +0200 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 https://github.com/vim/vim/issues/8271) diff --git a/src/time.c b/src/time.c --- a/src/time.c +++ b/src/time.c @@ -252,7 +252,6 @@ f_reltimestr(typval_T *argvars UNUSED, t 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 @@ f_strftime(typval_T *argvars, typval_T * 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 @@ f_strftime(typval_T *argvars, typval_T * // Release conversion descriptors convert_setup(&conv, NULL, NULL); vim_free(enc); +# endif } } # endif diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -751,6 +751,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 2894, +/**/ 2893, /**/ 2892,