diff options
author | Bram Moolenaar <bram@vim.org> | 2013-12-11 18:18:06 +0100 |
---|---|---|
committer | Bram Moolenaar <bram@vim.org> | 2013-12-11 18:18:06 +0100 |
commit | f849550bc7a72ae61df4e79663c7441bacb67895 (patch) | |
tree | ba3444ff74fa41ef610401d723aecb168980cc1c | |
parent | f276c743ba9a3bd03026e1be238cb0b236791b69 (diff) | |
download | vim-f849550bc7a72ae61df4e79663c7441bacb67895.tar.gz |
Problem: Win32: Getting user name does not use wide function.
Solution: Use GetUserNameW() if possible. (Ken Takata)
-rw-r--r-- | src/os_win32.c | 20 | ||||
-rw-r--r-- | src/version.c | 2 |
2 files changed, 22 insertions, 0 deletions
diff --git a/src/os_win32.c b/src/os_win32.c index 2d5544b4..06cc315e 100644 --- a/src/os_win32.c +++ b/src/os_win32.c @@ -2768,6 +2768,26 @@ mch_get_user_name( char szUserName[256 + 1]; /* UNLEN is 256 */ DWORD cch = sizeof szUserName; +#ifdef FEAT_MBYTE + if (enc_codepage >= 0 && (int)GetACP() != enc_codepage) + { + WCHAR wszUserName[256 + 1]; /* UNLEN is 256 */ + DWORD wcch = sizeof(wszUserName) / sizeof(WCHAR); + + if (GetUserNameW(wszUserName, &wcch)) + { + char_u *p = utf16_to_enc(wszUserName, NULL); + + if (p != NULL) + { + vim_strncpy(s, p, len - 1); + vim_free(p); + return OK; + } + } + /* Retry with non-wide function (for Windows 98). */ + } +#endif if (GetUserName(szUserName, &cch)) { vim_strncpy(s, szUserName, len - 1); diff --git a/src/version.c b/src/version.c index 4bfd68ff..8a44a1c5 100644 --- a/src/version.c +++ b/src/version.c @@ -739,6 +739,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 123, +/**/ 122, /**/ 121, |