mirror of
https://github.com/neovim/neovim.git
synced 2025-09-06 03:18:16 +00:00
vim-patch:8.2.3388: fnamemodify('path/..', ':p') differs from using 'path/../' (#29667)
Problem: fnamemodify('path/..', ':p') differs from using 'path/../'. Solution: Include the "/.." in the directory name. (closes vim/vim#8808)4eaef9979f
Co-authored-by: Bram Moolenaar <Bram@vim.org> (cherry picked from commit31d53cbb0f
)
This commit is contained in:

committed by
github-actions[bot]
![github-actions[bot]](/assets/img/avatar_default.png)
parent
113e5a91de
commit
7c055bd74b
@@ -2385,10 +2385,14 @@ static int path_to_absolute(const char *fname, char *buf, size_t len, int force)
|
||||
}
|
||||
#endif
|
||||
if (p != NULL) {
|
||||
if (strcmp(p + 1, "..") == 0) {
|
||||
// for "/path/dir/.." include the "/.."
|
||||
p += 3;
|
||||
}
|
||||
assert(p >= fname);
|
||||
memcpy(relative_directory, fname, (size_t)(p - fname + 1));
|
||||
relative_directory[p - fname + 1] = NUL;
|
||||
end_of_path = p + 1;
|
||||
end_of_path = (vim_ispathsep_nocolon(*p) ? p + 1 : p);
|
||||
} else {
|
||||
relative_directory[0] = NUL;
|
||||
}
|
||||
|
@@ -12,6 +12,8 @@ func Test_fnamemodify()
|
||||
call assert_equal('r', fnamemodify('.', ':p:h')[-1:])
|
||||
call assert_equal('t', fnamemodify('test.out', ':p')[-1:])
|
||||
call assert_equal($HOME .. "/foo" , fnamemodify('~/foo', ':p'))
|
||||
call assert_equal(fnamemodify('.', ':p:h:h:h') .. '/', fnamemodify($HOME .. '/../', ':p'))
|
||||
call assert_equal(fnamemodify('.', ':p:h:h:h') .. '/', fnamemodify($HOME .. '/..', ':p'))
|
||||
call assert_equal('test.out', fnamemodify('test.out', ':.'))
|
||||
call assert_equal('a', fnamemodify('../testdir/a', ':.'))
|
||||
call assert_equal('~/testdir/test.out', fnamemodify('test.out', ':~'))
|
||||
|
Reference in New Issue
Block a user