diff options
author | zeertzjq <zeertzjq@outlook.com> | 2024-03-10 06:47:09 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-10 06:47:09 +0800 |
commit | 241c16129919e169b71ef1e788420224b358fbb3 (patch) | |
tree | 7f75baccff8e2b4ea96f4d1a033e7d3b628f4575 /src | |
parent | b596732831b5e947ce83c1153f0df10a0553c88d (diff) | |
download | rneovim-241c16129919e169b71ef1e788420224b358fbb3.tar.gz rneovim-241c16129919e169b71ef1e788420224b358fbb3.tar.bz2 rneovim-241c16129919e169b71ef1e788420224b358fbb3.zip |
vim-patch:9.1.0161: expand() removes slash after env variable that ends with colon (#27791)
Problem: expand() removes a slash after an environment variable that
ends with a colon on Windows.
Solution: Check the correct char for a colon (zeertzjq)
closes: vim/vim#14161
Note: Vim still removes the path-separator at the end, if another path separator
follows directly after it, e.g. on:
```
echo $FOO='/usr/'
echo expand('$FOO/bar') == '/usr/bar'
```
see:
,----[ misc1.c:1630 ]
| // if var[] ends in a path separator and tail[] starts
| // with it, skip a character
| if (after_pathsep(dst, dst + c)
| #if defined(BACKSLASH_IN_FILENAME) || defined(AMIGA)
| && (dst == save_dst || dst[-1] != ':')
| #endif
| && vim_ispathsep(*tail))
| ++tail;
`----
https://github.com/vim/vim/commit/13a014452a7a020a119ac555a690c65b41f3126d
Cherry-pick test_expand.vim change from patch 9.0.1257.
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/os/env.c | 5 |
1 files changed, 1 insertions, 4 deletions
diff --git a/src/nvim/os/env.c b/src/nvim/os/env.c index 5b1cb01976..8a81f6e928 100644 --- a/src/nvim/os/env.c +++ b/src/nvim/os/env.c @@ -586,9 +586,6 @@ void expand_env_esc(char *restrict srcp, char *restrict dst, int dstlen, bool es bool copy_char; bool mustfree; // var was allocated, need to free it later bool at_start = true; // at start of a name -#if defined(BACKSLASH_IN_FILENAME) - char *const save_dst = dst; -#endif int prefix_len = (prefix == NULL) ? 0 : (int)strlen(prefix); @@ -729,7 +726,7 @@ void expand_env_esc(char *restrict srcp, char *restrict dst, int dstlen, bool es // with it, skip a character if (after_pathsep(dst, dst + c) #if defined(BACKSLASH_IN_FILENAME) - && (dst == save_dst || dst[-1] != ':') + && dst[c - 1] != ':' #endif && vim_ispathsep(*tail)) { tail++; |