]> granicus.if.org Git - vim/commitdiff
patch 8.0.1426: "gf" and <cfile> don't accept ? and & in URL v8.0.1426
authorBram Moolenaar <Bram@vim.org>
Mon, 25 Dec 2017 13:29:18 +0000 (14:29 +0100)
committerBram Moolenaar <Bram@vim.org>
Mon, 25 Dec 2017 13:29:18 +0000 (14:29 +0100)
Problem:    "gf" and <cfile> don't accept ? and & in URL. (Dmitrii Tcyganok)
Solution:   Check for a URL and allow for extra characters. (closes #2493)

src/testdir/test_gf.vim
src/version.c
src/window.c

index ef1bf1075bbb6f627497017639b667681ae787d0..c3523796972da6a7d8f2cf279fef236cd55c4d8a 100644 (file)
@@ -7,7 +7,8 @@ func Test_gf_url()
       \ "first test for URL://machine.name/tmp/vimtest2a and other text",
       \ "second test for URL://machine.name/tmp/vimtest2b. And other text",
       \ "third test for URL:\\\\machine.name\\vimtest2c and other text",
-      \ "fourth test for URL:\\\\machine.name\\tmp\\vimtest2d, and other text"
+      \ "fourth test for URL:\\\\machine.name\\tmp\\vimtest2d, and other text",
+      \ "fifth test for URL://machine.name/tmp?q=vim&opt=yes and other text",
       \ ])
   call cursor(1,1)
   call search("^first")
@@ -28,6 +29,10 @@ func Test_gf_url()
   call search("URL")
   call assert_equal("URL:\\\\machine.name\\tmp\\vimtest2d", expand("<cfile>"))
 
+  call search("^fifth")
+  call search("URL")
+  call assert_equal("URL://machine.name/tmp?q=vim&opt=yes", expand("<cfile>"))
+
   set isf&vim
   enew!
 endfunc
index f62287b5b2512ca43debee799ddffdec5e77f4b8..17547222f8ef7f0595b0cd21e4aaa6dd01da7445 100644 (file)
@@ -771,6 +771,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1426,
 /**/
     1425,
 /**/
index ffe4e38f877784abb4cd3c8c646f0b3e63001fa3..a58fbbd7b7c4f24d93135c8e52522041d6258b2a 100644 (file)
@@ -6081,7 +6081,6 @@ grab_file_name(long count, linenr_T *file_lnum)
                                                     count, curbuf->b_ffname);
     }
     return file_name_at_cursor(options | FNAME_HYP, count, file_lnum);
-
 }
 
 /*
@@ -6120,6 +6119,8 @@ file_name_in_line(
 {
     char_u     *ptr;
     int                len;
+    int                in_type = TRUE;
+    int                is_url = FALSE;
 
     /*
      * search forward for what could be the start of a file name
@@ -6158,8 +6159,19 @@ file_name_in_line(
      */
     len = 0;
     while (vim_isfilec(ptr[len]) || (ptr[len] == '\\' && ptr[len + 1] == ' ')
-                        || ((options & FNAME_HYP) && path_is_url(ptr + len)))
+                        || ((options & FNAME_HYP) && path_is_url(ptr + len))
+                        || (is_url && vim_strchr((char_u *)"?&=", ptr[len]) != NULL))
     {
+       /* After type:// we also include ?, & and = as valid characters, so that
+        * http://google.com?q=this&that=ok works. */
+       if ((ptr[len] >= 'A' && ptr[len] <= 'Z') || (ptr[len] >= 'a' && ptr[len] <= 'z'))
+       {
+           if (in_type && path_is_url(ptr + len + 1))
+               is_url = TRUE;
+       }
+       else
+           in_type = FALSE;
+
        if (ptr[len] == '\\')
            /* Skip over the "\" in "\ ". */
            ++len;