forked from aniani/vim
patch 8.0.1040: cannot use another error format in getqflist()
Problem: Cannot use another error format in getqflist(). Solution: Add the "efm" argument to getqflist(). (Yegappan Lakshmanan)
This commit is contained in:
@@ -4635,16 +4635,19 @@ getqflist([{what}]) *getqflist()*
|
|||||||
returns only the items listed in {what} as a dictionary. The
|
returns only the items listed in {what} as a dictionary. The
|
||||||
following string items are supported in {what}:
|
following string items are supported in {what}:
|
||||||
context get the context stored with |setqflist()|
|
context get the context stored with |setqflist()|
|
||||||
|
efm errorformat to use when parsing "lines". If
|
||||||
|
not present, then the 'erroformat' option
|
||||||
|
value is used.
|
||||||
id get information for the quickfix list with
|
id get information for the quickfix list with
|
||||||
|quickfix-ID|; zero means the id for the
|
|quickfix-ID|; zero means the id for the
|
||||||
current list or the list specifed by 'nr'
|
current list or the list specifed by "nr"
|
||||||
items quickfix list entries
|
items quickfix list entries
|
||||||
lines use 'errorformat' to extract items from a list
|
lines use 'errorformat' to extract items from a list
|
||||||
of lines and return the resulting entries.
|
of lines and return the resulting entries.
|
||||||
Only a |List| type is accepted. The current
|
Only a |List| type is accepted. The current
|
||||||
quickfix list is not modified.
|
quickfix list is not modified.
|
||||||
nr get information for this quickfix list; zero
|
nr get information for this quickfix list; zero
|
||||||
means the current quickfix list and '$' means
|
means the current quickfix list and "$" means
|
||||||
the last quickfix list
|
the last quickfix list
|
||||||
title get the list title
|
title get the list title
|
||||||
winid get the |window-ID| (if opened)
|
winid get the |window-ID| (if opened)
|
||||||
@@ -7086,13 +7089,16 @@ setqflist({list} [, {action}[, {what}]]) *setqflist()*
|
|||||||
is created. The new quickfix list is added after the current
|
is created. The new quickfix list is added after the current
|
||||||
quickfix list in the stack and all the following lists are
|
quickfix list in the stack and all the following lists are
|
||||||
freed. To add a new quickfix list at the end of the stack,
|
freed. To add a new quickfix list at the end of the stack,
|
||||||
set "nr" in {what} to '$'.
|
set "nr" in {what} to "$".
|
||||||
|
|
||||||
If the optional {what} dictionary argument is supplied, then
|
If the optional {what} dictionary argument is supplied, then
|
||||||
only the items listed in {what} are set. The first {list}
|
only the items listed in {what} are set. The first {list}
|
||||||
argument is ignored. The following items can be specified in
|
argument is ignored. The following items can be specified in
|
||||||
{what}:
|
{what}:
|
||||||
context any Vim type can be stored as a context
|
context any Vim type can be stored as a context
|
||||||
|
efm errorformat to use when parsing text from
|
||||||
|
"lines". If this is not present, then the
|
||||||
|
'errorformat' option value is used.
|
||||||
id quickfix list identifier |quickfix-ID|
|
id quickfix list identifier |quickfix-ID|
|
||||||
items list of quickfix entries. Same as the {list}
|
items list of quickfix entries. Same as the {list}
|
||||||
argument.
|
argument.
|
||||||
@@ -7100,7 +7106,7 @@ setqflist({list} [, {action}[, {what}]]) *setqflist()*
|
|||||||
add the resulting entries to the quickfix list
|
add the resulting entries to the quickfix list
|
||||||
{nr} or {id}. Only a |List| value is supported.
|
{nr} or {id}. Only a |List| value is supported.
|
||||||
nr list number in the quickfix stack; zero
|
nr list number in the quickfix stack; zero
|
||||||
means the current quickfix list and '$' means
|
means the current quickfix list and "$" means
|
||||||
the last quickfix list
|
the last quickfix list
|
||||||
title quickfix list title text
|
title quickfix list title text
|
||||||
Unsupported keys in {what} are ignored.
|
Unsupported keys in {what} are ignored.
|
||||||
@@ -7108,7 +7114,7 @@ setqflist({list} [, {action}[, {what}]]) *setqflist()*
|
|||||||
is modified. When creating a new quickfix list, "nr" can be
|
is modified. When creating a new quickfix list, "nr" can be
|
||||||
set to a value one greater than the quickfix stack size.
|
set to a value one greater than the quickfix stack size.
|
||||||
When modifying a quickfix list, to guarantee that the correct
|
When modifying a quickfix list, to guarantee that the correct
|
||||||
list is modified, 'id' should be used instead of 'nr' to
|
list is modified, "id" should be used instead of "nr" to
|
||||||
specify the list.
|
specify the list.
|
||||||
|
|
||||||
Examples: >
|
Examples: >
|
||||||
|
@@ -4643,16 +4643,29 @@ enum {
|
|||||||
* Parse text from 'di' and return the quickfix list items
|
* Parse text from 'di' and return the quickfix list items
|
||||||
*/
|
*/
|
||||||
static int
|
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;
|
int status = FAIL;
|
||||||
qf_info_T *qi;
|
qf_info_T *qi;
|
||||||
|
char_u *errorformat = p_efm;
|
||||||
|
dictitem_T *efm_di;
|
||||||
|
list_T *l;
|
||||||
|
|
||||||
/* Only a List value is supported */
|
/* Only a List value is supported */
|
||||||
if (di->di_tv.v_type == VAR_LIST && di->di_tv.vval.v_list != NULL)
|
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)
|
if (l == NULL)
|
||||||
return FAIL;
|
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)));
|
vim_memset(qi, 0, (size_t)(sizeof(qf_info_T)));
|
||||||
qi->qf_refcount++;
|
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)
|
TRUE, (linenr_T)0, (linenr_T)0, NULL, NULL) > 0)
|
||||||
{
|
{
|
||||||
(void)get_errorlist(qi, NULL, 0, l);
|
(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;
|
int flags = QF_GETLIST_NONE;
|
||||||
|
|
||||||
if ((di = dict_find(what, (char_u *)"lines", -1)) != NULL)
|
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)
|
if (wp != NULL)
|
||||||
qi = GET_LOC_LIST(wp);
|
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 retval = FAIL;
|
||||||
int qf_idx;
|
int qf_idx;
|
||||||
int newlist = FALSE;
|
int newlist = FALSE;
|
||||||
|
char_u *errorformat = p_efm;
|
||||||
|
|
||||||
if (action == ' ' || qi->qf_curlist == qi->qf_listcount)
|
if (action == ' ' || qi->qf_curlist == qi->qf_listcount)
|
||||||
newlist = TRUE;
|
newlist = TRUE;
|
||||||
@@ -5039,6 +5053,7 @@ qf_set_properties(qf_info_T *qi, dict_T *what, int action, char_u *title)
|
|||||||
retval = OK;
|
retval = OK;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((di = dict_find(what, (char_u *)"items", -1)) != NULL)
|
if ((di = dict_find(what, (char_u *)"items", -1)) != NULL)
|
||||||
{
|
{
|
||||||
if (di->di_tv.v_type == VAR_LIST)
|
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)
|
if ((di = dict_find(what, (char_u *)"lines", -1)) != NULL)
|
||||||
{
|
{
|
||||||
/* Only a List value is supported */
|
/* 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')
|
if (action == 'r')
|
||||||
qf_free_items(qi, qf_idx);
|
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)
|
FALSE, (linenr_T)0, (linenr_T)0, NULL, NULL) > 0)
|
||||||
retval = OK;
|
retval = OK;
|
||||||
}
|
}
|
||||||
|
@@ -2321,6 +2321,17 @@ func Xsetexpr_tests(cchar)
|
|||||||
call g:Xsetlist([], 'a', {'nr' : 2, 'lines' : ["File2:25:Line25"]})
|
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('Line15', g:Xgetlist({'nr':1, 'items':1}).items[1].text)
|
||||||
call assert_equal('Line25', g:Xgetlist({'nr':2, '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
|
endfunc
|
||||||
|
|
||||||
func Test_setexpr()
|
func Test_setexpr()
|
||||||
@@ -2537,6 +2548,17 @@ func XgetListFromLines(cchar)
|
|||||||
call assert_equal([], g:Xgetlist({'lines' : []}).items)
|
call assert_equal([], g:Xgetlist({'lines' : []}).items)
|
||||||
call assert_equal([], g:Xgetlist({'lines' : [10, 20]}).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
|
" Make sure that the quickfix stack is not modified
|
||||||
call assert_equal(0, g:Xgetlist({'nr' : '$'}).nr)
|
call assert_equal(0, g:Xgetlist({'nr' : '$'}).nr)
|
||||||
endfunc
|
endfunc
|
||||||
|
@@ -769,6 +769,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1040,
|
||||||
/**/
|
/**/
|
||||||
1039,
|
1039,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user