mirror of
				https://github.com/neovim/neovim.git
				synced 2025-11-04 01:34:25 +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>
			
			
This commit is contained in:
		@@ -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