diff options
author | Bram Moolenaar <Bram@vim.org> | 2017-09-02 19:51:44 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2017-09-02 19:51:44 +0200 |
commit | 3653822546fb0f1005c32bb5b70dc9bfacdfc954 (patch) | |
tree | ddc4623400cf61b1d224e7e43db1e8ee929cc8c5 /src | |
parent | b31cf2bb0be95d106bd8eef93cc07550591c1d0d (diff) | |
download | vim-git-3653822546fb0f1005c32bb5b70dc9bfacdfc954.tar.gz |
patch 8.0.1040: cannot use another error format in getqflist()v8.0.1040
Problem: Cannot use another error format in getqflist().
Solution: Add the "efm" argument to getqflist(). (Yegappan Lakshmanan)
Diffstat (limited to 'src')
-rw-r--r-- | src/quickfix.c | 32 | ||||
-rw-r--r-- | src/testdir/test_quickfix.vim | 22 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 51 insertions, 5 deletions
diff --git a/src/quickfix.c b/src/quickfix.c index 5cbb1519a..ee871fc46 100644 --- a/src/quickfix.c +++ b/src/quickfix.c @@ -4643,16 +4643,29 @@ enum { * Parse text from 'di' and return the quickfix list items */ static int -qf_get_list_from_lines(dictitem_T *di, dict_T *retdict) +qf_get_list_from_lines(dict_T *what, dictitem_T *di, dict_T *retdict) { int status = FAIL; qf_info_T *qi; + char_u *errorformat = p_efm; + dictitem_T *efm_di; + list_T *l; /* Only a List value is supported */ if (di->di_tv.v_type == VAR_LIST && di->di_tv.vval.v_list != NULL) { - list_T *l = list_alloc(); + /* If errorformat is supplied then use it, otherwise use the 'efm' + * option setting + */ + if ((efm_di = dict_find(what, (char_u *)"efm", -1)) != NULL) + { + if (efm_di->di_tv.v_type != VAR_STRING || + efm_di->di_tv.vval.v_string == NULL) + return FAIL; + errorformat = efm_di->di_tv.vval.v_string; + } + l = list_alloc(); if (l == NULL) return FAIL; @@ -4662,7 +4675,7 @@ qf_get_list_from_lines(dictitem_T *di, dict_T *retdict) vim_memset(qi, 0, (size_t)(sizeof(qf_info_T))); qi->qf_refcount++; - if (qf_init_ext(qi, 0, NULL, NULL, &di->di_tv, p_efm, + if (qf_init_ext(qi, 0, NULL, NULL, &di->di_tv, errorformat, TRUE, (linenr_T)0, (linenr_T)0, NULL, NULL) > 0) { (void)get_errorlist(qi, NULL, 0, l); @@ -4692,7 +4705,7 @@ get_errorlist_properties(win_T *wp, dict_T *what, dict_T *retdict) int flags = QF_GETLIST_NONE; if ((di = dict_find(what, (char_u *)"lines", -1)) != NULL) - return qf_get_list_from_lines(di, retdict); + return qf_get_list_from_lines(what, di, retdict); if (wp != NULL) qi = GET_LOC_LIST(wp); @@ -4962,6 +4975,7 @@ qf_set_properties(qf_info_T *qi, dict_T *what, int action, char_u *title) int retval = FAIL; int qf_idx; int newlist = FALSE; + char_u *errorformat = p_efm; if (action == ' ' || qi->qf_curlist == qi->qf_listcount) newlist = TRUE; @@ -5039,6 +5053,7 @@ qf_set_properties(qf_info_T *qi, dict_T *what, int action, char_u *title) retval = OK; } } + if ((di = dict_find(what, (char_u *)"items", -1)) != NULL) { if (di->di_tv.v_type == VAR_LIST) @@ -5051,6 +5066,13 @@ qf_set_properties(qf_info_T *qi, dict_T *what, int action, char_u *title) } } + if ((di = dict_find(what, (char_u *)"efm", -1)) != NULL) + { + if (di->di_tv.v_type != VAR_STRING || di->di_tv.vval.v_string == NULL) + return FAIL; + errorformat = di->di_tv.vval.v_string; + } + if ((di = dict_find(what, (char_u *)"lines", -1)) != NULL) { /* Only a List value is supported */ @@ -5058,7 +5080,7 @@ qf_set_properties(qf_info_T *qi, dict_T *what, int action, char_u *title) { if (action == 'r') qf_free_items(qi, qf_idx); - if (qf_init_ext(qi, qf_idx, NULL, NULL, &di->di_tv, p_efm, + if (qf_init_ext(qi, qf_idx, NULL, NULL, &di->di_tv, errorformat, FALSE, (linenr_T)0, (linenr_T)0, NULL, NULL) > 0) retval = OK; } diff --git a/src/testdir/test_quickfix.vim b/src/testdir/test_quickfix.vim index 64f1baea2..6a8d0e7bf 100644 --- a/src/testdir/test_quickfix.vim +++ b/src/testdir/test_quickfix.vim @@ -2321,6 +2321,17 @@ func Xsetexpr_tests(cchar) call g:Xsetlist([], 'a', {'nr' : 2, 'lines' : ["File2:25:Line25"]}) call assert_equal('Line15', g:Xgetlist({'nr':1, 'items':1}).items[1].text) call assert_equal('Line25', g:Xgetlist({'nr':2, 'items':1}).items[1].text) + + " Adding entries using a custom efm + set efm& + call g:Xsetlist([], ' ', {'efm' : '%f#%l#%m', + \ 'lines' : ["F1#10#L10", "F2#20#L20"]}) + call assert_equal(20, g:Xgetlist({'items':1}).items[1].lnum) + call g:Xsetlist([], 'a', {'efm' : '%f#%l#%m', 'lines' : ["F3:30:L30"]}) + call assert_equal('F3:30:L30', g:Xgetlist({'items':1}).items[2].text) + call assert_equal(20, g:Xgetlist({'items':1}).items[1].lnum) + call assert_equal(-1, g:Xsetlist([], 'a', {'efm' : [], + \ 'lines' : ['F1:10:L10']})) endfunc func Test_setexpr() @@ -2537,6 +2548,17 @@ func XgetListFromLines(cchar) call assert_equal([], g:Xgetlist({'lines' : []}).items) call assert_equal([], g:Xgetlist({'lines' : [10, 20]}).items) + " Parse text using a custom efm + set efm& + let l = g:Xgetlist({'lines':['File3#30#Line30'], 'efm' : '%f#%l#%m'}).items + call assert_equal('Line30', l[0].text) + let l = g:Xgetlist({'lines':['File3:30:Line30'], 'efm' : '%f-%l-%m'}).items + call assert_equal('File3:30:Line30', l[0].text) + let l = g:Xgetlist({'lines':['File3:30:Line30'], 'efm' : [1,2]}) + call assert_equal({}, l) + call assert_fails("call g:Xgetlist({'lines':['abc'], 'efm':'%2'})", 'E376:') + call assert_fails("call g:Xgetlist({'lines':['abc'], 'efm':''})", 'E378:') + " Make sure that the quickfix stack is not modified call assert_equal(0, g:Xgetlist({'nr' : '$'}).nr) endfunc diff --git a/src/version.c b/src/version.c index 8bc6d72be..ee6e91ce7 100644 --- a/src/version.c +++ b/src/version.c @@ -770,6 +770,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1040, +/**/ 1039, /**/ 1038, |