mirror of
https://github.com/neovim/neovim.git
synced 2025-09-14 15:28:17 +00:00
@@ -15712,6 +15712,9 @@ static void get_xdg_var_list(const XDGVarType xdg, typval_T *rettv)
|
|||||||
rettv->vval.v_list = list;
|
rettv->vval.v_list = list;
|
||||||
tv_list_ref(list);
|
tv_list_ref(list);
|
||||||
char *const dirs = stdpaths_get_xdg_var(xdg);
|
char *const dirs = stdpaths_get_xdg_var(xdg);
|
||||||
|
if (dirs == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
do {
|
do {
|
||||||
size_t dir_len;
|
size_t dir_len;
|
||||||
const char *dir;
|
const char *dir;
|
||||||
|
@@ -1849,6 +1849,7 @@ static void source_startup_scripts(const mparm_T *const parmp)
|
|||||||
/// @return FAIL if the environment variable was not executed,
|
/// @return FAIL if the environment variable was not executed,
|
||||||
/// OK otherwise.
|
/// OK otherwise.
|
||||||
static int process_env(char *env, bool is_viminit)
|
static int process_env(char *env, bool is_viminit)
|
||||||
|
FUNC_ATTR_NONNULL_ALL
|
||||||
{
|
{
|
||||||
const char *initstr = os_getenv(env);
|
const char *initstr = os_getenv(env);
|
||||||
if (initstr != NULL) {
|
if (initstr != NULL) {
|
||||||
|
@@ -6585,7 +6585,7 @@ void vimrc_found(char_u *fname, char_u *envname)
|
|||||||
{
|
{
|
||||||
char_u *p;
|
char_u *p;
|
||||||
|
|
||||||
if (fname != NULL) {
|
if (fname != NULL && envname != NULL) {
|
||||||
p = (char_u *)vim_getenv((char *)envname);
|
p = (char_u *)vim_getenv((char *)envname);
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
/* Set $MYVIMRC to the first vimrc file found. */
|
/* Set $MYVIMRC to the first vimrc file found. */
|
||||||
|
@@ -65,7 +65,7 @@ char *stdpaths_get_xdg_var(const XDGVarType idx)
|
|||||||
const char *env_val = os_getenv(env);
|
const char *env_val = os_getenv(env);
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (env_val == NULL) {
|
if (env_val == NULL && xdg_defaults_env_vars[idx] != NULL) {
|
||||||
env_val = os_getenv(xdg_defaults_env_vars[idx]);
|
env_val = os_getenv(xdg_defaults_env_vars[idx]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@@ -74,7 +74,7 @@ char *stdpaths_get_xdg_var(const XDGVarType idx)
|
|||||||
if (env_val != NULL) {
|
if (env_val != NULL) {
|
||||||
ret = xstrdup(env_val);
|
ret = xstrdup(env_val);
|
||||||
} else if (fallback) {
|
} else if (fallback) {
|
||||||
ret = (char *) expand_env_save((char_u *)fallback);
|
ret = (char *)expand_env_save((char_u *)fallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@@ -10,6 +10,7 @@ local eval = helpers.eval
|
|||||||
local eq = helpers.eq
|
local eq = helpers.eq
|
||||||
local funcs = helpers.funcs
|
local funcs = helpers.funcs
|
||||||
local insert = helpers.insert
|
local insert = helpers.insert
|
||||||
|
local iswin = helpers.iswin
|
||||||
local neq = helpers.neq
|
local neq = helpers.neq
|
||||||
local mkdir = helpers.mkdir
|
local mkdir = helpers.mkdir
|
||||||
local rmdir = helpers.rmdir
|
local rmdir = helpers.rmdir
|
||||||
@@ -170,8 +171,7 @@ describe('startup defaults', function()
|
|||||||
end)
|
end)
|
||||||
|
|
||||||
describe('$NVIM_LOG_FILE', function()
|
describe('$NVIM_LOG_FILE', function()
|
||||||
-- TODO(jkeyes): use stdpath('data') instead.
|
local datasubdir = iswin() and 'nvim-data' or 'nvim'
|
||||||
local datasubdir = helpers.iswin() and 'nvim-data' or 'nvim'
|
|
||||||
local xdgdir = 'Xtest-startup-xdg-logpath'
|
local xdgdir = 'Xtest-startup-xdg-logpath'
|
||||||
local xdgdatadir = xdgdir..'/'..datasubdir
|
local xdgdatadir = xdgdir..'/'..datasubdir
|
||||||
after_each(function()
|
after_each(function()
|
||||||
@@ -428,7 +428,24 @@ end)
|
|||||||
|
|
||||||
|
|
||||||
describe('stdpath()', function()
|
describe('stdpath()', function()
|
||||||
|
-- Windows appends 'nvim-data' instead of just 'nvim' to prevent collisions
|
||||||
|
-- due to XDG_CONFIG_HOME and XDG_DATA_HOME being the same.
|
||||||
|
local datadir = iswin() and 'nvim-data' or 'nvim'
|
||||||
|
|
||||||
|
it('acceptance', function()
|
||||||
|
clear() -- Do not explicitly set any env vars.
|
||||||
|
|
||||||
|
eq('nvim', funcs.fnamemodify(funcs.stdpath('cache'), ':t'))
|
||||||
|
eq('nvim', funcs.fnamemodify(funcs.stdpath('config'), ':t'))
|
||||||
|
eq(datadir, funcs.fnamemodify(funcs.stdpath('data'), ':t'))
|
||||||
|
eq('table', type(funcs.stdpath('config_dirs')))
|
||||||
|
eq('table', type(funcs.stdpath('data_dirs')))
|
||||||
|
-- Check for crash. #8393
|
||||||
|
eq(2, eval('1+1'))
|
||||||
|
end)
|
||||||
|
|
||||||
context('returns a String', function()
|
context('returns a String', function()
|
||||||
|
|
||||||
describe('with "config"' , function ()
|
describe('with "config"' , function ()
|
||||||
it('knows XDG_CONFIG_HOME', function()
|
it('knows XDG_CONFIG_HOME', function()
|
||||||
clear({env={
|
clear({env={
|
||||||
@@ -463,32 +480,20 @@ describe('stdpath()', function()
|
|||||||
end)
|
end)
|
||||||
|
|
||||||
describe('with "data"' , function ()
|
describe('with "data"' , function ()
|
||||||
local appended_dir
|
|
||||||
setup(function()
|
|
||||||
-- Windows appends 'nvim-data' instead of just 'nvim' to
|
|
||||||
-- prevent collisions due to XDG_CONFIG_HOME and XDG_DATA_HOME
|
|
||||||
-- being the same.
|
|
||||||
if helpers.iswin() then
|
|
||||||
appended_dir = '/nvim-data'
|
|
||||||
else
|
|
||||||
appended_dir = '/nvim'
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
|
|
||||||
it('knows XDG_DATA_HOME', function()
|
it('knows XDG_DATA_HOME', function()
|
||||||
clear({env={
|
clear({env={
|
||||||
XDG_DATA_HOME=alter_slashes('/home/docwhat/.local'),
|
XDG_DATA_HOME=alter_slashes('/home/docwhat/.local'),
|
||||||
}})
|
}})
|
||||||
eq(alter_slashes('/home/docwhat/.local' .. appended_dir), funcs.stdpath('data'))
|
eq(alter_slashes('/home/docwhat/.local/'..datadir), funcs.stdpath('data'))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('handles changes during runtime', function()
|
it('handles changes during runtime', function()
|
||||||
clear({env={
|
clear({env={
|
||||||
XDG_DATA_HOME=alter_slashes('/home/original'),
|
XDG_DATA_HOME=alter_slashes('/home/original'),
|
||||||
}})
|
}})
|
||||||
eq(alter_slashes('/home/original' .. appended_dir), funcs.stdpath('data'))
|
eq(alter_slashes('/home/original/'..datadir), funcs.stdpath('data'))
|
||||||
command("let $XDG_DATA_HOME='"..alter_slashes('/home/new').."'")
|
command("let $XDG_DATA_HOME='"..alter_slashes('/home/new').."'")
|
||||||
eq(alter_slashes('/home/new' .. appended_dir), funcs.stdpath('data'))
|
eq(alter_slashes('/home/new/'..datadir), funcs.stdpath('data'))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("doesn't expand $VARIABLES", function()
|
it("doesn't expand $VARIABLES", function()
|
||||||
@@ -496,14 +501,14 @@ describe('stdpath()', function()
|
|||||||
XDG_DATA_HOME='$VARIABLES',
|
XDG_DATA_HOME='$VARIABLES',
|
||||||
VARIABLES='this-should-not-happen',
|
VARIABLES='this-should-not-happen',
|
||||||
}})
|
}})
|
||||||
eq(alter_slashes('$VARIABLES' .. appended_dir), funcs.stdpath('data'))
|
eq(alter_slashes('$VARIABLES/'..datadir), funcs.stdpath('data'))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("doesn't expand ~/", function()
|
it("doesn't expand ~/", function()
|
||||||
clear({env={
|
clear({env={
|
||||||
XDG_DATA_HOME=alter_slashes('~/frobnitz'),
|
XDG_DATA_HOME=alter_slashes('~/frobnitz'),
|
||||||
}})
|
}})
|
||||||
eq(alter_slashes('~/frobnitz' .. appended_dir), funcs.stdpath('data'))
|
eq(alter_slashes('~/frobnitz/'..datadir), funcs.stdpath('data'))
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
@@ -544,7 +549,7 @@ describe('stdpath()', function()
|
|||||||
context('returns a List', function()
|
context('returns a List', function()
|
||||||
-- Some OS specific variables the system would have set.
|
-- Some OS specific variables the system would have set.
|
||||||
local function base_env()
|
local function base_env()
|
||||||
if helpers.iswin() then
|
if iswin() then
|
||||||
return {
|
return {
|
||||||
HOME='C:\\Users\\docwhat', -- technically, is not a usual PATH
|
HOME='C:\\Users\\docwhat', -- technically, is not a usual PATH
|
||||||
HOMEDRIVE='C:',
|
HOMEDRIVE='C:',
|
||||||
|
Reference in New Issue
Block a user