diff options
author | erw7 <erw7.github@gmail.com> | 2019-03-06 14:59:28 +0900 |
---|---|---|
committer | erw7 <erw7.github@gmail.com> | 2019-03-06 18:06:51 +0900 |
commit | 24a56cca308621a5a585f73b22e5421461318b3d (patch) | |
tree | b0fd11598efff79ebf28752471fac5355d79888e /src | |
parent | 299f32dc012929f55e5b6b9aaf7c7aded9e7e489 (diff) | |
download | rneovim-24a56cca308621a5a585f73b22e5421461318b3d.tar.gz rneovim-24a56cca308621a5a585f73b22e5421461318b3d.tar.bz2 rneovim-24a56cca308621a5a585f73b22e5421461318b3d.zip |
Fix environment variable on Windows
Since uv_os_setenv uses SetEnvironmentVariableW, _wenviron is no
updated. As a result, inconsistency occurs in completion of environment
variable names. Change to use GetEnvironmentStaringsW instead of
_wenviron to solve it.
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/os/env.c | 46 |
1 files changed, 30 insertions, 16 deletions
diff --git a/src/nvim/os/env.c b/src/nvim/os/env.c index e7bfbc8240..35b56f9539 100644 --- a/src/nvim/os/env.c +++ b/src/nvim/os/env.c @@ -151,25 +151,39 @@ int os_unsetenv(const char *name) char *os_getenvname_at_index(size_t index) { #ifdef _WIN32 - // Check if index is inside the environ array and is not the last element. - for (size_t i = 0; i <= index; i++) { - if (_wenviron[i] == NULL) { - return NULL; - } - } - wchar_t *utf16_str = _wenviron[index]; - char *utf8_str; - int conversion_result = utf16_to_utf8(utf16_str, &utf8_str); - if (conversion_result != 0) { - EMSG2("utf16_to_utf8 failed: %d", conversion_result); + wchar_t *env = GetEnvironmentStringsW(); + if (!env) { return NULL; } - size_t namesize = 0; - while (utf8_str[namesize] != '=' && utf8_str[namesize] != NUL) { - namesize++; + + // GetEnvironmentStrings return environment block of the following format: + // + // var1=value1\0var2=value2\0...varN=valueN\0\0 + // + char *name = NULL; + size_t current_index = 0; + for (wchar_t *it = env; *it != L'\0' || *(it + 1) != L'\0'; it++) { + if (index == current_index) { + char *utf8_str; + int conversion_result = utf16_to_utf8(it, &utf8_str); + if (conversion_result != 0) { + EMSG2("utf16_to_utf8 failed: %d", conversion_result); + break; + } + size_t namesize = 0; + while (utf8_str[namesize] != '=' && utf8_str[namesize] != NUL) { + namesize++; + } + name = (char *)vim_strnsave((char_u *)utf8_str, namesize); + xfree(utf8_str); + break; + } + if (*it == L'\0') { + current_index++; + } } - char *name = (char *)vim_strnsave((char_u *)utf8_str, namesize); - xfree(utf8_str); + + FreeEnvironmentStringsW(env); return name; #else # if defined(HAVE__NSGETENVIRON) |