mirror of
https://github.com/neovim/neovim.git
synced 2025-10-15 22:36:09 +00:00
os_setenv: use _wputenv_s; remove vestigial code #7920
_putenv_s variant was left over from810d31a430
, should have been removed incd5b131575
.
This commit is contained in:
@@ -27,7 +27,6 @@
|
|||||||
#cmakedefine HAVE_LOCALE_H
|
#cmakedefine HAVE_LOCALE_H
|
||||||
#cmakedefine HAVE_NL_LANGINFO_CODESET
|
#cmakedefine HAVE_NL_LANGINFO_CODESET
|
||||||
#cmakedefine HAVE_NL_MSG_CAT_CNTR
|
#cmakedefine HAVE_NL_MSG_CAT_CNTR
|
||||||
#cmakedefine HAVE_PUTENV_S
|
|
||||||
#cmakedefine HAVE_PWD_H
|
#cmakedefine HAVE_PWD_H
|
||||||
#cmakedefine HAVE_READLINK
|
#cmakedefine HAVE_READLINK
|
||||||
#cmakedefine HAVE_UV_TRANSLATE_SYS_ERROR
|
#cmakedefine HAVE_UV_TRANSLATE_SYS_ERROR
|
||||||
|
@@ -52,29 +52,29 @@ int os_setenv(const char *name, const char *value, int overwrite)
|
|||||||
FUNC_ATTR_NONNULL_ALL
|
FUNC_ATTR_NONNULL_ALL
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#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) {
|
|
||||||
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) {
|
if (!overwrite && os_getenv(name) != NULL) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (_putenv_s(name, value) == 0) {
|
wchar_t *wname;
|
||||||
return 0;
|
utf8_to_utf16(name, &wname);
|
||||||
|
if (wname == NULL) {
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
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;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
#elif defined(HAVE_SETENV)
|
||||||
|
return setenv(name, value, overwrite);
|
||||||
#else
|
#else
|
||||||
# error "This system has no implementation available for os_setenv()"
|
# error "This system has no implementation available for os_setenv()"
|
||||||
#endif
|
#endif
|
||||||
|
@@ -2,13 +2,15 @@ local helpers = require('test.functional.helpers')(after_each)
|
|||||||
|
|
||||||
local eq = helpers.eq
|
local eq = helpers.eq
|
||||||
local clear = helpers.clear
|
local clear = helpers.clear
|
||||||
|
local command = helpers.command
|
||||||
|
local eval = helpers.eval
|
||||||
local meths = helpers.meths
|
local meths = helpers.meths
|
||||||
local redir_exec = helpers.redir_exec
|
local redir_exec = helpers.redir_exec
|
||||||
local source = helpers.source
|
local source = helpers.source
|
||||||
|
|
||||||
before_each(clear)
|
before_each(clear)
|
||||||
|
|
||||||
describe(':let command', function()
|
describe(':let', function()
|
||||||
it('correctly lists variables with curly-braces', function()
|
it('correctly lists variables with curly-braces', function()
|
||||||
meths.set_var('v', {0})
|
meths.set_var('v', {0})
|
||||||
eq('\nv [0]', redir_exec('let {"v"}'))
|
eq('\nv [0]', redir_exec('let {"v"}'))
|
||||||
@@ -42,4 +44,16 @@ describe(':let command', function()
|
|||||||
call feedkeys(":\e:echo l1 l3\n:echo 42\n:cq\n", "t")
|
call feedkeys(":\e:echo l1 l3\n:echo 42\n:cq\n", "t")
|
||||||
]=])
|
]=])
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
it("sets environment variables", function()
|
||||||
|
local multibyte_multiline = [[\p* .ม .ม .ม .ม่ .ม่ .ม่ ֹ ֹ ֹ .ֹ .ֹ .ֹ ֹֻ ֹֻ ֹֻ
|
||||||
|
.ֹֻ .ֹֻ .ֹֻ ֹֻ ֹֻ ֹֻ .ֹֻ .ֹֻ .ֹֻ ֹ ֹ ֹ .ֹ .ֹ .ֹ ֹ ֹ ֹ .ֹ .ֹ .ֹ ֹֻ ֹֻ
|
||||||
|
.ֹֻ .ֹֻ .ֹֻ a a a ca ca ca à à à]]
|
||||||
|
command("let $NVIM_TEST1 = 'AìaB'")
|
||||||
|
command("let $NVIM_TEST2 = 'AaあB'")
|
||||||
|
command("let $NVIM_TEST3 = '"..multibyte_multiline.."'")
|
||||||
|
eq('AìaB', eval('$NVIM_TEST1'))
|
||||||
|
eq('AaあB', eval('$NVIM_TEST2'))
|
||||||
|
eq(multibyte_multiline, eval('$NVIM_TEST3'))
|
||||||
|
end)
|
||||||
end)
|
end)
|
||||||
|
Reference in New Issue
Block a user