]> granicus.if.org Git - vim/commitdiff
patch 9.0.0231: expanding "**" may loop forever with directory links v9.0.0231
authorBram Moolenaar <Bram@vim.org>
Sat, 20 Aug 2022 18:26:14 +0000 (19:26 +0100)
committerBram Moolenaar <Bram@vim.org>
Sat, 20 Aug 2022 18:26:14 +0000 (19:26 +0100)
Problem:    Expanding "**" may loop forever with directory links.
Solution:   Check for being interrupted. (closes #10946)

src/cmdexpand.c
src/filepath.c
src/version.c

index ff6aa0d0339e782660541a1e627b6e4c6197131e..fb329a57d7f22318e90cfc8e51d5b62ddfab7103 100644 (file)
@@ -722,8 +722,9 @@ ExpandOne(
        findex = -1;                        // next p_wc gets first one
     }
 
-    // Concatenate all matching names
-    if (mode == WILD_ALL && xp->xp_numfiles > 0)
+    // Concatenate all matching names.  Unless interrupted, this can be slow
+    // and the result probably won't be used.
+    if (mode == WILD_ALL && xp->xp_numfiles > 0 && !got_int)
     {
        len = 0;
        for (i = 0; i < xp->xp_numfiles; ++i)
index 0867a518102871e4665ffe7054b720c9127d73c7..ecee8db8b1d420efcd0d695e237c98ffe7b3b63b 100644 (file)
@@ -3180,8 +3180,9 @@ expand_wildcards(
 
     /*
      * Move the names where 'suffixes' match to the end.
+     * Skip when interrupted, the result probably won't be used.
      */
-    if (*num_files > 1)
+    if (*num_files > 1 && !got_int)
     {
        non_suf_match = 0;
        for (i = 0; i < *num_files; ++i)
@@ -3719,7 +3720,7 @@ unix_expandpath(
     // Find all matching entries
     if (dirp != NULL)
     {
-       for (;;)
+       while (!got_int)
        {
            dp = readdir(dirp);
            if (dp == NULL)
@@ -3789,8 +3790,10 @@ unix_expandpath(
     vim_free(buf);
     vim_regfree(regmatch.regprog);
 
+    // When interrupted the matches probably won't be used and sorting can be
+    // slow, thus skip it.
     matches = gap->ga_len - start_len;
-    if (matches > 0)
+    if (matches > 0 && !got_int)
        qsort(((char_u **)gap->ga_data) + start_len, matches,
                                                   sizeof(char_u *), pstrcmp);
     return matches;
@@ -3918,7 +3921,7 @@ gen_expand_wildcards(
      */
     ga_init2(&ga, sizeof(char_u *), 30);
 
-    for (i = 0; i < num_pat; ++i)
+    for (i = 0; i < num_pat && !got_int; ++i)
     {
        add_pat = -1;
        p = pat[i];
index 9ce33cdbc83b22fee050d2be804894d2686945c9..9b98edcc6beb4bc7920c316f69e2a14532c4b1fb 100644 (file)
@@ -731,6 +731,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    231,
 /**/
     230,
 /**/