diff options
author | Justin M. Keyes <justinkz@gmail.com> | 2018-01-27 12:50:10 +0100 |
---|---|---|
committer | Justin M. Keyes <justinkz@gmail.com> | 2019-02-25 23:47:54 +0100 |
commit | 9153062095f34ec8dcdc8862da1ab9abfe560e3f (patch) | |
tree | 04325474ecce6166041f0026e16a917742212167 /src | |
parent | 533d4a36ec03626e9d796ef7e2a9aa3c0e1ce7bf (diff) | |
download | rneovim-9153062095f34ec8dcdc8862da1ab9abfe560e3f.tar.gz rneovim-9153062095f34ec8dcdc8862da1ab9abfe560e3f.tar.bz2 rneovim-9153062095f34ec8dcdc8862da1ab9abfe560e3f.zip |
os_setenv: use _wputenv_s; remove vestigial code #7920
_putenv_s variant was left over from 810d31a43001, should have been
removed in cd5b1315757e.
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/os/env.c | 36 |
1 files changed, 18 insertions, 18 deletions
diff --git a/src/nvim/os/env.c b/src/nvim/os/env.c index c6794e4be5..6cf48eb814 100644 --- a/src/nvim/os/env.c +++ b/src/nvim/os/env.c @@ -52,29 +52,29 @@ int os_setenv(const char *name, const char *value, int overwrite) FUNC_ATTR_NONNULL_ALL { #ifdef WIN32 - size_t envbuflen = strlen(name) + strlen(value) + 2; - char *envbuf = xmalloc(envbuflen); - snprintf(envbuf, envbuflen, "%s=%s", name, value); - - wchar_t *p; - utf8_to_utf16(envbuf, &p); - xfree(envbuf); - if (p == NULL) { + if (!overwrite && os_getenv(name) != NULL) { + return 0; + } + wchar_t *wname; + utf8_to_utf16(name, &wname); + if (wname == NULL) { + return -1; + } + wchar_t *wvalue; + utf8_to_utf16(value, &wvalue); + if (wvalue == NULL) { + return -1; + } + int rv = (int)_wputenv_s(wname, wvalue); + xfree(wname); // Unlike unix putenv(), we can free after _wputenv_s(). + xfree(wvalue); + if (rv != 0) { + ELOG("_wputenv_s failed: %d: %s", rv, uv_strerror(rv)); return -1; } - _wputenv(p); - xfree(p); // Unlike Unix systems, we can free the string for _wputenv(). return 0; #elif defined(HAVE_SETENV) return setenv(name, value, overwrite); -#elif defined(HAVE_PUTENV_S) - if (!overwrite && os_getenv(name) != NULL) { - return 0; - } - if (_putenv_s(name, value) == 0) { - return 0; - } - return -1; #else # error "This system has no implementation available for os_setenv()" #endif |