forked from aniani/vim
patch 8.2.0869: it is not possible to customize the quickfix window contents
Problem: It is not possible to customize the quickfix window contents. Solution: Add 'quickfixtextfunc'. (Yegappan Lakshmanan, closes #5465)
This commit is contained in:
@@ -5508,8 +5508,9 @@ getqflist([{what}]) *getqflist()*
|
||||
id get information for the quickfix list with
|
||||
|quickfix-ID|; zero means the id for the
|
||||
current list or the list specified by "nr"
|
||||
idx index of the current entry in the quickfix
|
||||
list specified by 'id' or 'nr'.
|
||||
idx get information for the quickfix entry at this
|
||||
index in the list specified by 'id' or 'nr'.
|
||||
If set to zero, then uses the current entry.
|
||||
See |quickfix-index|
|
||||
items quickfix list entries
|
||||
lines parse a list of lines using 'efm' and return
|
||||
@@ -5545,7 +5546,7 @@ getqflist([{what}]) *getqflist()*
|
||||
If not present, set to "".
|
||||
id quickfix list ID |quickfix-ID|. If not
|
||||
present, set to 0.
|
||||
idx index of the current entry in the list. If not
|
||||
idx index of the quickfix entry in the list. If not
|
||||
present, set to 0.
|
||||
items quickfix list entries. If not present, set to
|
||||
an empty list.
|
||||
@@ -8841,6 +8842,11 @@ setqflist({list} [, {action} [, {what}]]) *setqflist()*
|
||||
nr list number in the quickfix stack; zero
|
||||
means the current quickfix list and "$" means
|
||||
the last quickfix list.
|
||||
quickfixtextfunc
|
||||
function to get the text to display in the
|
||||
quickfix window. Refer to
|
||||
|quickfix-window-function| for an explanation
|
||||
of how to write the function and an example.
|
||||
title quickfix list title text. See |quickfix-title|
|
||||
Unsupported keys in {what} are ignored.
|
||||
If the "nr" item is not present, then the current quickfix list
|
||||
|
@@ -5898,6 +5898,21 @@ A jump table for the options with a short description can be found at |Q_op|.
|
||||
'pyxversion' has no effect. The pyx* functions and commands are
|
||||
always the same as the compiled version.
|
||||
|
||||
This option cannot be set from a |modeline| or in the |sandbox|, for
|
||||
security reasons.
|
||||
|
||||
*'quickfixtextfunc'* *'qftf'*
|
||||
'quickfixtextfunc' 'qftf' string (default "")
|
||||
global
|
||||
{only available when compiled with the |+quickfix|
|
||||
feature}
|
||||
This option specifies a function to be used to get the text to display
|
||||
in the quickfix and location list windows. This can be used to
|
||||
customize the information displayed in the quickfix or location window
|
||||
for each entry in the corresponding quickfix or location list. See
|
||||
|quickfix-window-function| for an explanation of how to write the
|
||||
function and an example.
|
||||
|
||||
This option cannot be set from a |modeline| or in the |sandbox|, for
|
||||
security reasons.
|
||||
|
||||
|
@@ -15,6 +15,7 @@ This subject is introduced in section |30.1| of the user manual.
|
||||
7. The error format |error-file-format|
|
||||
8. The directory stack |quickfix-directory-stack|
|
||||
9. Specific error file formats |errorformats|
|
||||
10. Customizing the quickfix window |quickfix-window-function|
|
||||
|
||||
The quickfix commands are not available when the |+quickfix| feature was
|
||||
disabled at compile time.
|
||||
@@ -1921,6 +1922,59 @@ error messages into a format that quickfix mode will understand. See the
|
||||
start of the file about how to use it. (This script is deprecated, see
|
||||
|compiler-perl|.)
|
||||
|
||||
=============================================================================
|
||||
10. Customizing the quickfix window *quickfix-window-function*
|
||||
|
||||
The default format for the lines displayed in the quickfix window and location
|
||||
list window is:
|
||||
|
||||
<filename>|<lnum> col <col>|<text>
|
||||
|
||||
The values displayed in each line correspond to the "bufnr", "lnum", "col" and
|
||||
"text" fields returned by the |getqflist()| function.
|
||||
|
||||
For some quickfix/location lists, the displayed text need to be customized.
|
||||
For example, if only the filename is present for a quickfix entry, then the
|
||||
two "|" field separator characters after the filename are not needed. Another
|
||||
use case is to customize the path displayed for a filename. By default, the
|
||||
complete path (which may be too long) is displayed for files which are not
|
||||
under the current directory tree. The file path may need to be simplified to a
|
||||
common parent directory.
|
||||
|
||||
The displayed text can be customized by setting the 'quickfixtextfunc' option
|
||||
to a Vim function. This function will be called with a dict argument for
|
||||
every entry in a quickfix or a location list. The dict argument will have the
|
||||
following fields:
|
||||
|
||||
quickfix set to 1 when called for a quickfix list and 0 when called for
|
||||
a location list.
|
||||
id quickfix or location list identifier
|
||||
idx index of the entry in the quickfix or location list
|
||||
|
||||
The function should return a single line of text to display in the quickfix
|
||||
window for the entry identified by idx. The function can obtain information
|
||||
about the current entry using the |getqflist()| function and specifying the
|
||||
quickfix list identifier "id" and the entry index "idx".
|
||||
|
||||
If a quickfix or location list specific customization is needed, then the
|
||||
'quickfixtextfunc' attribute of the list can be set using the |setqflist()| or
|
||||
|setloclist()| function. This overrides the global 'quickfixtextfunc' option.
|
||||
|
||||
The example below displays the list of old files (|v:oldfiles|) in a quickfix
|
||||
window. As there is no line, column number and error text information
|
||||
associated with each entry, the 'quickfixtextfunc' function returns only the
|
||||
filename.
|
||||
Example: >
|
||||
" create a quickfix list from v:oldfiles
|
||||
call setqflist([], ' ', {'lines' : v:oldfiles, 'efm' : '%f',
|
||||
\ 'quickfixtextfunc' : 'QfOldFiles'})
|
||||
func QfOldFiles(info)
|
||||
" get information about the specific quickfix entry
|
||||
let e = getqflist({'id' : a:info.id, 'idx' : a:info.idx,
|
||||
\ 'items' : 1}).items[0]
|
||||
" return the simplified file name
|
||||
return fnamemodify(bufname(e.bufnr), ':p:.')
|
||||
endfunc
|
||||
<
|
||||
|
||||
vim:tw=78:ts=8:noet:ft=help:norl:
|
||||
|
@@ -820,6 +820,7 @@ EXTERN int p_ru; // 'ruler'
|
||||
EXTERN char_u *p_ruf; // 'rulerformat'
|
||||
#endif
|
||||
EXTERN char_u *p_pp; // 'packpath'
|
||||
EXTERN char_u *p_qftf; // 'quickfixtextfunc'
|
||||
EXTERN char_u *p_rtp; // 'runtimepath'
|
||||
EXTERN long p_sj; // 'scrolljump'
|
||||
#if defined(MSWIN) && defined(FEAT_GUI)
|
||||
|
@@ -2045,6 +2045,15 @@ static struct vimoption options[] =
|
||||
#endif
|
||||
{(char_u *)DEFAULT_PYTHON_VER, (char_u *)0L}
|
||||
SCTX_INIT},
|
||||
{"quickfixtextfunc", "qftf", P_STRING|P_ALLOCED|P_VI_DEF|P_VIM|P_SECURE,
|
||||
#if defined(FEAT_QUICKFIX) && defined(FEAT_EVAL)
|
||||
(char_u *)&p_qftf, PV_NONE,
|
||||
{(char_u *)"", (char_u *)0L}
|
||||
#else
|
||||
(char_u *)NULL, PV_NONE,
|
||||
{(char_u *)NULL, (char_u *)NULL}
|
||||
#endif
|
||||
SCTX_INIT},
|
||||
{"quoteescape", "qe", P_STRING|P_ALLOCED|P_VI_DEF,
|
||||
#ifdef FEAT_TEXTOBJ
|
||||
(char_u *)&p_qe, PV_QE,
|
||||
|
126
src/quickfix.c
126
src/quickfix.c
@@ -82,6 +82,7 @@ typedef struct qf_list_S
|
||||
char_u *qf_title; // title derived from the command that created
|
||||
// the error list or set by setqflist
|
||||
typval_T *qf_ctx; // context set by setqflist/setloclist
|
||||
char_u *qf_qftf; // 'quickfixtextfunc' setting for this list
|
||||
|
||||
struct dir_stack_T *qf_dir_stack;
|
||||
char_u *qf_directory;
|
||||
@@ -2277,6 +2278,10 @@ copy_loclist(qf_list_T *from_qfl, qf_list_T *to_qfl)
|
||||
}
|
||||
else
|
||||
to_qfl->qf_ctx = NULL;
|
||||
if (from_qfl->qf_qftf != NULL)
|
||||
to_qfl->qf_qftf = vim_strsave(from_qfl->qf_qftf);
|
||||
else
|
||||
to_qfl->qf_qftf = NULL;
|
||||
|
||||
if (from_qfl->qf_count)
|
||||
if (copy_loclist_entries(from_qfl, to_qfl) == FAIL)
|
||||
@@ -3812,6 +3817,7 @@ qf_free(qf_list_T *qfl)
|
||||
VIM_CLEAR(qfl->qf_title);
|
||||
free_tv(qfl->qf_ctx);
|
||||
qfl->qf_ctx = NULL;
|
||||
VIM_CLEAR(qfl->qf_qftf);
|
||||
qfl->qf_id = 0;
|
||||
qfl->qf_changedtick = 0L;
|
||||
}
|
||||
@@ -4399,11 +4405,50 @@ qf_update_buffer(qf_info_T *qi, qfline_T *old_last)
|
||||
* Add an error line to the quickfix buffer.
|
||||
*/
|
||||
static int
|
||||
qf_buf_add_line(buf_T *buf, linenr_T lnum, qfline_T *qfp, char_u *dirname)
|
||||
qf_buf_add_line(
|
||||
qf_list_T *qfl, // quickfix list
|
||||
buf_T *buf, // quickfix window buffer
|
||||
linenr_T lnum,
|
||||
qfline_T *qfp,
|
||||
char_u *dirname)
|
||||
{
|
||||
int len;
|
||||
buf_T *errbuf;
|
||||
char_u *qftf;
|
||||
|
||||
// If 'quickfixtextfunc' is set, then use the user-supplied function to get
|
||||
// the text to display
|
||||
qftf = p_qftf;
|
||||
// Use the local value of 'quickfixtextfunc' if it is set.
|
||||
if (qfl->qf_qftf != NULL)
|
||||
qftf = qfl->qf_qftf;
|
||||
if (qftf != NULL && *qftf != NUL)
|
||||
{
|
||||
char_u *qfbuf_text;
|
||||
typval_T args[1];
|
||||
dict_T *d;
|
||||
|
||||
// create 'info' dict argument
|
||||
if ((d = dict_alloc_lock(VAR_FIXED)) == NULL)
|
||||
return FAIL;
|
||||
dict_add_number(d, "quickfix", (long)IS_QF_LIST(qfl));
|
||||
dict_add_number(d, "id", (long)qfl->qf_id);
|
||||
dict_add_number(d, "idx", (long)(lnum + 1));
|
||||
++d->dv_refcount;
|
||||
args[0].v_type = VAR_DICT;
|
||||
args[0].vval.v_dict = d;
|
||||
|
||||
qfbuf_text = call_func_retstr(qftf, 1, args);
|
||||
--d->dv_refcount;
|
||||
|
||||
if (qfbuf_text == NULL)
|
||||
return FAIL;
|
||||
|
||||
vim_strncpy(IObuff, qfbuf_text, IOSIZE - 1);
|
||||
vim_free(qfbuf_text);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (qfp->qf_module != NULL)
|
||||
{
|
||||
vim_strncpy(IObuff, qfp->qf_module, IOSIZE - 1);
|
||||
@@ -4437,7 +4482,8 @@ qf_buf_add_line(buf_T *buf, linenr_T lnum, qfline_T *qfp, char_u *dirname)
|
||||
|
||||
if (qfp->qf_lnum > 0)
|
||||
{
|
||||
vim_snprintf((char *)IObuff + len, IOSIZE - len, "%ld", qfp->qf_lnum);
|
||||
vim_snprintf((char *)IObuff + len, IOSIZE - len, "%ld",
|
||||
qfp->qf_lnum);
|
||||
len += (int)STRLEN(IObuff + len);
|
||||
|
||||
if (qfp->qf_col > 0)
|
||||
@@ -4467,6 +4513,7 @@ qf_buf_add_line(buf_T *buf, linenr_T lnum, qfline_T *qfp, char_u *dirname)
|
||||
// mark a word with ^^^^.
|
||||
qf_fmt_text(len > 3 ? skipwhite(qfp->qf_text) : qfp->qf_text,
|
||||
IObuff + len, IOSIZE - len);
|
||||
}
|
||||
|
||||
if (ml_append_buf(buf, lnum, IObuff,
|
||||
(colnr_T)STRLEN(IObuff) + 1, FALSE) == FAIL)
|
||||
@@ -4522,7 +4569,7 @@ qf_fill_buffer(qf_list_T *qfl, buf_T *buf, qfline_T *old_last)
|
||||
}
|
||||
while (lnum < qfl->qf_count)
|
||||
{
|
||||
if (qf_buf_add_line(buf, lnum, qfp, dirname) == FAIL)
|
||||
if (qf_buf_add_line(qfl, buf, lnum, qfp, dirname) == FAIL)
|
||||
break;
|
||||
|
||||
++lnum;
|
||||
@@ -6369,9 +6416,16 @@ get_qfline_items(qfline_T *qfp, list_T *list)
|
||||
/*
|
||||
* Add each quickfix error to list "list" as a dictionary.
|
||||
* If qf_idx is -1, use the current list. Otherwise, use the specified list.
|
||||
* If eidx is not 0, then return only the specified entry. Otherwise return
|
||||
* all the entries.
|
||||
*/
|
||||
static int
|
||||
get_errorlist(qf_info_T *qi_arg, win_T *wp, int qf_idx, list_T *list)
|
||||
get_errorlist(
|
||||
qf_info_T *qi_arg,
|
||||
win_T *wp,
|
||||
int qf_idx,
|
||||
int eidx,
|
||||
list_T *list)
|
||||
{
|
||||
qf_info_T *qi = qi_arg;
|
||||
qf_list_T *qfl;
|
||||
@@ -6389,6 +6443,9 @@ get_errorlist(qf_info_T *qi_arg, win_T *wp, int qf_idx, list_T *list)
|
||||
}
|
||||
}
|
||||
|
||||
if (eidx < 0)
|
||||
return OK;
|
||||
|
||||
if (qf_idx == INVALID_QFIDX)
|
||||
qf_idx = qi->qf_curlist;
|
||||
|
||||
@@ -6401,7 +6458,12 @@ get_errorlist(qf_info_T *qi_arg, win_T *wp, int qf_idx, list_T *list)
|
||||
|
||||
FOR_ALL_QFL_ITEMS(qfl, qfp, i)
|
||||
{
|
||||
if (get_qfline_items(qfp, list) == FAIL)
|
||||
if (eidx > 0)
|
||||
{
|
||||
if (eidx == i)
|
||||
return get_qfline_items(qfp, list);
|
||||
}
|
||||
else if (get_qfline_items(qfp, list) == FAIL)
|
||||
return FAIL;
|
||||
}
|
||||
|
||||
@@ -6461,7 +6523,7 @@ qf_get_list_from_lines(dict_T *what, dictitem_T *di, dict_T *retdict)
|
||||
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);
|
||||
(void)get_errorlist(qi, NULL, 0, 0, l);
|
||||
qf_free(&qi->qf_lists[0]);
|
||||
}
|
||||
free(qi);
|
||||
@@ -6679,16 +6741,17 @@ qf_getprop_filewinid(win_T *wp, qf_info_T *qi, dict_T *retdict)
|
||||
}
|
||||
|
||||
/*
|
||||
* Return the quickfix list items/entries as 'items' in retdict
|
||||
* Return the quickfix list items/entries as 'items' in retdict.
|
||||
* If eidx is not 0, then return the item at the specified index.
|
||||
*/
|
||||
static int
|
||||
qf_getprop_items(qf_info_T *qi, int qf_idx, dict_T *retdict)
|
||||
qf_getprop_items(qf_info_T *qi, int qf_idx, int eidx, dict_T *retdict)
|
||||
{
|
||||
int status = OK;
|
||||
list_T *l = list_alloc();
|
||||
if (l != NULL)
|
||||
{
|
||||
(void)get_errorlist(qi, NULL, qf_idx, l);
|
||||
(void)get_errorlist(qi, NULL, qf_idx, eidx, l);
|
||||
dict_add_list(retdict, "items", l);
|
||||
}
|
||||
else
|
||||
@@ -6726,16 +6789,20 @@ qf_getprop_ctx(qf_list_T *qfl, dict_T *retdict)
|
||||
}
|
||||
|
||||
/*
|
||||
* Return the current quickfix list index as 'idx' in retdict
|
||||
* Return the current quickfix list index as 'idx' in retdict.
|
||||
* If a specific entry index (eidx) is supplied, then use that.
|
||||
*/
|
||||
static int
|
||||
qf_getprop_idx(qf_list_T *qfl, dict_T *retdict)
|
||||
qf_getprop_idx(qf_list_T *qfl, int eidx, dict_T *retdict)
|
||||
{
|
||||
int curidx = qfl->qf_index;
|
||||
if (eidx == 0)
|
||||
{
|
||||
eidx = qfl->qf_index;
|
||||
if (qf_list_empty(qfl))
|
||||
// For empty lists, current index is set to 0
|
||||
curidx = 0;
|
||||
return dict_add_number(retdict, "idx", curidx);
|
||||
eidx = 0;
|
||||
}
|
||||
return dict_add_number(retdict, "idx", eidx);
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -6750,6 +6817,7 @@ qf_get_properties(win_T *wp, dict_T *what, dict_T *retdict)
|
||||
qf_list_T *qfl;
|
||||
int status = OK;
|
||||
int qf_idx = INVALID_QFIDX;
|
||||
int eidx = 0;
|
||||
dictitem_T *di;
|
||||
int flags = QF_GETLIST_NONE;
|
||||
|
||||
@@ -6770,6 +6838,14 @@ qf_get_properties(win_T *wp, dict_T *what, dict_T *retdict)
|
||||
|
||||
qfl = qf_get_list(qi, qf_idx);
|
||||
|
||||
// If an entry index is specified, use that
|
||||
if ((di = dict_find(what, (char_u *)"idx", -1)) != NULL)
|
||||
{
|
||||
if (di->di_tv.v_type != VAR_NUMBER)
|
||||
return FAIL;
|
||||
eidx = di->di_tv.vval.v_number;
|
||||
}
|
||||
|
||||
if (flags & QF_GETLIST_TITLE)
|
||||
status = qf_getprop_title(qfl, retdict);
|
||||
if ((status == OK) && (flags & QF_GETLIST_NR))
|
||||
@@ -6777,13 +6853,13 @@ qf_get_properties(win_T *wp, dict_T *what, dict_T *retdict)
|
||||
if ((status == OK) && (flags & QF_GETLIST_WINID))
|
||||
status = dict_add_number(retdict, "winid", qf_winid(qi));
|
||||
if ((status == OK) && (flags & QF_GETLIST_ITEMS))
|
||||
status = qf_getprop_items(qi, qf_idx, retdict);
|
||||
status = qf_getprop_items(qi, qf_idx, eidx, retdict);
|
||||
if ((status == OK) && (flags & QF_GETLIST_CONTEXT))
|
||||
status = qf_getprop_ctx(qfl, retdict);
|
||||
if ((status == OK) && (flags & QF_GETLIST_ID))
|
||||
status = dict_add_number(retdict, "id", qfl->qf_id);
|
||||
if ((status == OK) && (flags & QF_GETLIST_IDX))
|
||||
status = qf_getprop_idx(qfl, retdict);
|
||||
status = qf_getprop_idx(qfl, eidx, retdict);
|
||||
if ((status == OK) && (flags & QF_GETLIST_SIZE))
|
||||
status = dict_add_number(retdict, "size", qfl->qf_count);
|
||||
if ((status == OK) && (flags & QF_GETLIST_TICK))
|
||||
@@ -7147,6 +7223,20 @@ qf_setprop_curidx(qf_info_T *qi, qf_list_T *qfl, dictitem_T *di)
|
||||
return OK;
|
||||
}
|
||||
|
||||
/*
|
||||
* Set the current index in the specified quickfix list
|
||||
*/
|
||||
static int
|
||||
qf_setprop_qftf(qf_info_T *qi UNUSED, qf_list_T *qfl, dictitem_T *di)
|
||||
{
|
||||
VIM_CLEAR(qfl->qf_qftf);
|
||||
if (di->di_tv.v_type == VAR_STRING
|
||||
&& di->di_tv.vval.v_string != NULL)
|
||||
qfl->qf_qftf = vim_strsave(di->di_tv.vval.v_string);
|
||||
|
||||
return OK;
|
||||
}
|
||||
|
||||
/*
|
||||
* Set quickfix/location list properties (title, items, context).
|
||||
* Also used to add items from parsing a list of lines.
|
||||
@@ -7186,6 +7276,8 @@ qf_set_properties(qf_info_T *qi, dict_T *what, int action, char_u *title)
|
||||
retval = qf_setprop_context(qfl, di);
|
||||
if ((di = dict_find(what, (char_u *)"idx", -1)) != NULL)
|
||||
retval = qf_setprop_curidx(qi, qfl, di);
|
||||
if ((di = dict_find(what, (char_u *)"quickfixtextfunc", -1)) != NULL)
|
||||
retval = qf_setprop_qftf(qi, qfl, di);
|
||||
|
||||
if (retval == OK)
|
||||
qf_list_changed(qfl);
|
||||
@@ -7900,7 +7992,7 @@ get_qf_loc_list(int is_qf, win_T *wp, typval_T *what_arg, typval_T *rettv)
|
||||
{
|
||||
if (rettv_list_alloc(rettv) == OK)
|
||||
if (is_qf || wp != NULL)
|
||||
(void)get_errorlist(NULL, wp, -1, rettv->vval.v_list);
|
||||
(void)get_errorlist(NULL, wp, -1, 0, rettv->vval.v_list);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@@ -4766,4 +4766,121 @@ func Test_cquit()
|
||||
call assert_fails('-3cquit', 'E16:')
|
||||
endfunc
|
||||
|
||||
" Test for getting a specific item from a quickfix list
|
||||
func Xtest_getqflist_by_idx(cchar)
|
||||
call s:setup_commands(a:cchar)
|
||||
" Empty list
|
||||
call assert_equal([], g:Xgetlist({'idx' : 1, 'items' : 0}).items)
|
||||
Xexpr ['F1:10:L10', 'F1:20:L20']
|
||||
let l = g:Xgetlist({'idx' : 2, 'items' : 0}).items
|
||||
call assert_equal(bufnr('F1'), l[0].bufnr)
|
||||
call assert_equal(20, l[0].lnum)
|
||||
call assert_equal('L20', l[0].text)
|
||||
call assert_equal([], g:Xgetlist({'idx' : -1, 'items' : 0}).items)
|
||||
call assert_equal([], g:Xgetlist({'idx' : 3, 'items' : 0}).items)
|
||||
%bwipe!
|
||||
endfunc
|
||||
|
||||
func Test_getqflist_by_idx()
|
||||
call Xtest_getqflist_by_idx('c')
|
||||
call Xtest_getqflist_by_idx('l')
|
||||
endfunc
|
||||
|
||||
" Test for the 'quickfixtextfunc' setting
|
||||
func Tqfexpr(info)
|
||||
if a:info.quickfix
|
||||
let qfl = getqflist({'id' : a:info.id, 'idx' : a:info.idx,
|
||||
\ 'items' : 1}).items
|
||||
else
|
||||
let qfl = getloclist(0, {'id' : a:info.id, 'idx' : a:info.idx,
|
||||
\ 'items' : 1}).items
|
||||
endif
|
||||
|
||||
let e = qfl[0]
|
||||
let s = ''
|
||||
if e.bufnr != 0
|
||||
let bname = bufname(e.bufnr)
|
||||
let s ..= fnamemodify(bname, ':.')
|
||||
endif
|
||||
let s ..= '-'
|
||||
let s ..= 'L' .. string(e.lnum) .. 'C' .. string(e.col) .. '-'
|
||||
let s ..= e.text
|
||||
|
||||
return s
|
||||
endfunc
|
||||
|
||||
func Xtest_qftextfunc(cchar)
|
||||
call s:setup_commands(a:cchar)
|
||||
|
||||
set efm=%f:%l:%c:%m
|
||||
set quickfixtextfunc=Tqfexpr
|
||||
Xexpr ['F1:10:2:green', 'F1:20:4:blue']
|
||||
Xwindow
|
||||
call assert_equal('F1-L10C2-green', getline(1))
|
||||
call assert_equal('F1-L20C4-blue', getline(2))
|
||||
Xclose
|
||||
set quickfixtextfunc&vim
|
||||
Xwindow
|
||||
call assert_equal('F1|10 col 2| green', getline(1))
|
||||
call assert_equal('F1|20 col 4| blue', getline(2))
|
||||
Xclose
|
||||
set efm&
|
||||
set quickfixtextfunc&
|
||||
|
||||
" Test for per list 'quickfixtextfunc' setting
|
||||
func PerQfText(info)
|
||||
if a:info.quickfix
|
||||
let qfl = getqflist({'id' : a:info.id, 'idx' : a:info.idx,
|
||||
\ 'items' : 1}).items
|
||||
else
|
||||
let qfl = getloclist(0, {'id' : a:info.id, 'idx' : a:info.idx,
|
||||
\ 'items' : 1}).items
|
||||
endif
|
||||
if empty(qfl)
|
||||
return ''
|
||||
endif
|
||||
return 'Line ' .. qfl[0].lnum .. ', Col ' .. qfl[0].col
|
||||
endfunc
|
||||
set quickfixtextfunc=Tqfexpr
|
||||
call g:Xsetlist([], ' ', {'quickfixtextfunc' : "PerQfText"})
|
||||
Xaddexpr ['F1:10:2:green', 'F1:20:4:blue']
|
||||
Xwindow
|
||||
call assert_equal('Line 10, Col 2', getline(1))
|
||||
call assert_equal('Line 20, Col 4', getline(2))
|
||||
Xclose
|
||||
call g:Xsetlist([], 'r', {'quickfixtextfunc' : ''})
|
||||
set quickfixtextfunc&
|
||||
delfunc PerQfText
|
||||
|
||||
" Non-existing function
|
||||
set quickfixtextfunc=Tabc
|
||||
call assert_fails("Xexpr ['F1:10:2:green', 'F1:20:4:blue']", 'E117:')
|
||||
call assert_fails("Xwindow", 'E117:')
|
||||
Xclose
|
||||
set quickfixtextfunc&
|
||||
|
||||
" set option to a non-function
|
||||
set quickfixtextfunc=[10,\ 20]
|
||||
call assert_fails("Xexpr ['F1:10:2:green', 'F1:20:4:blue']", 'E117:')
|
||||
call assert_fails("Xwindow", 'E117:')
|
||||
Xclose
|
||||
set quickfixtextfunc&
|
||||
|
||||
" set option to a function with different set of arguments
|
||||
func Xqftext(a, b, c)
|
||||
return a:a .. a:b .. a:c
|
||||
endfunc
|
||||
set quickfixtextfunc=Xqftext
|
||||
call assert_fails("Xexpr ['F1:10:2:green', 'F1:20:4:blue']", 'E119:')
|
||||
call assert_fails("Xwindow", 'E119:')
|
||||
Xclose
|
||||
set quickfixtextfunc&
|
||||
delfunc Xqftext
|
||||
endfunc
|
||||
|
||||
func Test_qftextfunc()
|
||||
call Xtest_qftextfunc('c')
|
||||
call Xtest_qftextfunc('l')
|
||||
endfunc
|
||||
|
||||
" vim: shiftwidth=2 sts=2 expandtab
|
||||
|
@@ -746,6 +746,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
869,
|
||||
/**/
|
||||
868,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user