]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0161: expand() removes slash after env variable that ends with colon v9.1.0161
authorzeertzjq <zeertzjq@outlook.com>
Sat, 9 Mar 2024 16:44:46 +0000 (17:44 +0100)
committerChristian Brabandt <cb@256bit.org>
Sat, 9 Mar 2024 16:44:46 +0000 (17:44 +0100)
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: #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;
`----

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/misc1.c
src/testdir/test_expand.vim
src/version.c

index bf70e3847885ce31d4d3c3c1ef719c2d6114ce87..3085fc77fb5bb24f48573f659f011ba48d75aebc 100644 (file)
@@ -1404,9 +1404,6 @@ expand_env_esc(
     int                mustfree;       // var was allocated, need to free it later
     int                at_start = TRUE; // at start of a name
     int                startstr_len = 0;
-#if defined(BACKSLASH_IN_FILENAME) || defined(AMIGA)
-    char_u     *save_dst = dst;
-#endif
 
     if (startstr != NULL)
        startstr_len = (int)STRLEN(startstr);
@@ -1631,7 +1628,7 @@ expand_env_esc(
                // with it, skip a character
                if (after_pathsep(dst, dst + c)
 #if defined(BACKSLASH_IN_FILENAME) || defined(AMIGA)
-                       && (dst == save_dst || dst[-1] != ':')
+                       && dst[c - 1] != ':'
 #endif
                        && vim_ispathsep(*tail))
                    ++tail;
index d7c393a04e6efded01829310e15aa9bc9e66d95a..bebe13868faf32280cb70b446bc40c1dcf54a3b7 100644 (file)
@@ -51,6 +51,19 @@ func Test_expand_tilde_filename()
   bwipe!
 endfunc
 
+func Test_expand_env_pathsep()
+  let $FOO = './foo'
+  call assert_equal('./foo/bar', expand('$FOO/bar'))
+  let $FOO = './foo/'
+  call assert_equal('./foo/bar', expand('$FOO/bar'))
+  let $FOO = 'C:'
+  call assert_equal('C:/bar', expand('$FOO/bar'))
+  let $FOO = 'C:/'
+  call assert_equal('C:/bar', expand('$FOO/bar'))
+
+  unlet $FOO
+endfunc
+
 func Test_expandcmd()
   let $FOO = 'Test'
   call assert_equal('e x/Test/y', expandcmd('e x/$FOO/y'))
index 507c4591a3b84f43c54b274eeea503e0384175cb..8f28596f05bcd50cedd647f009ac9bd63dedf7cc 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    161,
 /**/
     160,
 /**/