]> granicus.if.org Git - vim/commitdiff
patch 7.4.2264 v7.4.2264
authorBram Moolenaar <Bram@vim.org>
Sat, 27 Aug 2016 11:35:35 +0000 (13:35 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 27 Aug 2016 11:35:35 +0000 (13:35 +0200)
Problem:    When adding entries to an empty quickfix list the title is reset.
Solution:   Improve handling of the title. (Yegappan Lakshmanan)

src/quickfix.c
src/testdir/test_quickfix.vim
src/version.c

index f808da49950f751938bb1a9d372b9317c0a11522..23cabb2988e7598c3432d8d645737ab79dcf9979 100644 (file)
@@ -4753,11 +4753,15 @@ qf_add_entries(
 }
 
     static int
-qf_set_properties(qf_info_T *qi, dict_T *what)
+qf_set_properties(qf_info_T *qi, dict_T *what, int action)
 {
     dictitem_T *di;
     int                retval = FAIL;
     int                qf_idx;
+    int                newlist = FALSE;
+
+    if (action == ' ' || qi->qf_curlist == qi->qf_listcount)
+       newlist = TRUE;
 
     qf_idx = qi->qf_curlist;           /* default is the current list */
     if ((di = dict_find(what, (char_u *)"nr", -1)) != NULL)
@@ -4771,6 +4775,13 @@ qf_set_properties(qf_info_T *qi, dict_T *what)
        }
        else
            return FAIL;
+       newlist = FALSE;        /* use the specified list */
+    }
+
+    if (newlist)
+    {
+       qf_new_list(qi, NULL);
+       qf_idx = qi->qf_curlist;
     }
 
     if ((di = dict_find(what, (char_u *)"title", -1)) != NULL)
@@ -4813,7 +4824,7 @@ set_errorlist(
     }
 
     if (what != NULL)
-       retval = qf_set_properties(qi, what);
+       retval = qf_set_properties(qi, what, action);
     else
        retval = qf_add_entries(qi, list, title, action);
 
index b7d985d0dff637b231b4014cf2fedae543b7756e..5c514776a05a95aa5da4ba9ab11719d27989ba52 100644 (file)
@@ -1527,6 +1527,16 @@ function Xproperty_tests(cchar)
     call assert_equal('Sample', w:quickfix_title)
     Xclose
 
+    " Tests for action argument
+    silent! Xolder 999
+    let qfnr = g:Xgetlist({'all':1}).nr
+    call g:Xsetlist([], 'r', {'title' : 'N1'})
+    call assert_equal('N1', g:Xgetlist({'all':1}).title)
+    call g:Xsetlist([], ' ', {'title' : 'N2'})
+    call assert_equal(qfnr + 1, g:Xgetlist({'all':1}).nr)
+    call g:Xsetlist([], ' ', {'title' : 'N3'})
+    call assert_equal('N2', g:Xgetlist({'nr':2, 'title':1}).title)
+
     " Invalid arguments
     call assert_fails('call g:Xgetlist([])', 'E715')
     call assert_fails('call g:Xsetlist([], "a", [])', 'E715')
index 934eecb29047c5d07b81bbb10e95fb8b3c244c2b..abf86a63481c1a4eb8f5c53ecdce9ab0d335fd91 100644 (file)
@@ -763,6 +763,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2264,
 /**/
     2263,
 /**/