aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2018-01-27 12:50:10 +0100
committerJustin M. Keyes <justinkz@gmail.com>2019-02-25 23:47:54 +0100
commit9153062095f34ec8dcdc8862da1ab9abfe560e3f (patch)
tree04325474ecce6166041f0026e16a917742212167 /src
parent533d4a36ec03626e9d796ef7e2a9aa3c0e1ce7bf (diff)
downloadrneovim-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.c36
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