patch 9.1.1287: quickfix code can be further improved

Problem:  quickfix code can be further improved (after v9.1.1283)
Solution: slightly refactor quickfix.c (Hirohito Higashi)

- remove error message output
- adjust comments
- rename functions:
  - qf_init_quickfix_stack() --> qf_init_stack()
  - qf_resize_quickfix_stack() --> qf_resize_stack()
  - qf_resize_stack() --> qf_resize_stack_base()

Now qf_alloc_stack() can handle both quickfix/location lists.

closes: #17068

Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Hirohito Higashi
2025-04-07 21:19:07 +02:00
committed by Christian Brabandt
parent e370141bf4
commit adcfb6caeb
5 changed files with 39 additions and 46 deletions

View File

@ -1026,10 +1026,10 @@ common_init_2(mparm_T *paramp)
#endif #endif
#ifdef FEAT_QUICKFIX #ifdef FEAT_QUICKFIX
// initialize global quickfix list // initialize quickfix list
// don't send an error message when memory allocation fails // don't send an error message when memory allocation fails
// do it when the user tries to access the quickfix list // do it when the user tries to access the quickfix list
qf_init_quickfix_stack(); qf_init_stack();
#endif #endif
} }

View File

@ -4762,7 +4762,7 @@ did_set_xhistory(optset_T *args)
} }
if (is_p_chi) if (is_p_chi)
err = qf_resize_quickfix_stack(*arg); err = qf_resize_stack(*arg);
else else
err = ll_resize_stack(curwin, *arg); err = ll_resize_stack(curwin, *arg);

View File

@ -3,9 +3,9 @@ int qf_init(win_T *wp, char_u *efile, char_u *errorformat, int newlist, char_u *
int qf_stack_get_bufnr(void); int qf_stack_get_bufnr(void);
void qf_free_all(win_T *wp); void qf_free_all(win_T *wp);
void check_quickfix_busy(void); void check_quickfix_busy(void);
int qf_resize_quickfix_stack(int n); int qf_resize_stack(int n);
int ll_resize_stack(win_T *wp, int n); int ll_resize_stack(win_T *wp, int n);
int qf_init_quickfix_stack(void); void qf_init_stack(void);
void copy_loclist_stack(win_T *from, win_T *to); void copy_loclist_stack(win_T *from, win_T *to);
void qf_jump(qf_info_T *qi, int dir, int errornr, int forceit); void qf_jump(qf_info_T *qi, int dir, int errornr, int forceit);
void qf_list(exarg_T *eap); void qf_list(exarg_T *eap);

View File

@ -174,7 +174,7 @@ static callback_T qftf_cb;
static void qf_pop_stack(qf_info_T *qi, int adjust); static void qf_pop_stack(qf_info_T *qi, int adjust);
static void qf_new_list(qf_info_T *qi, char_u *qf_title); static void qf_new_list(qf_info_T *qi, char_u *qf_title);
static int qf_add_entry(qf_list_T *qfl, char_u *dir, char_u *fname, char_u *module, int bufnum, char_u *mesg, long lnum, long end_lnum, int col, int end_col, int vis_col, char_u *pattern, int nr, int type, typval_T *user_data, int valid); static int qf_add_entry(qf_list_T *qfl, char_u *dir, char_u *fname, char_u *module, int bufnum, char_u *mesg, long lnum, long end_lnum, int col, int end_col, int vis_col, char_u *pattern, int nr, int type, typval_T *user_data, int valid);
static int qf_resize_stack(qf_info_T *qi, int n); static int qf_resize_stack_base(qf_info_T *qi, int n);
static void qf_sync_llw_to_win(win_T *llw); static void qf_sync_llw_to_win(win_T *llw);
static void qf_sync_win_to_llw(win_T *pwp); static void qf_sync_win_to_llw(win_T *pwp);
static qf_info_T *qf_alloc_stack(qfltype_T qfltype, int n); static qf_info_T *qf_alloc_stack(qfltype_T qfltype, int n);
@ -2343,19 +2343,16 @@ qf_add_entry(
} }
/* /*
* Resize global quickfix stack to be able to hold n amount of lists. * Resize quickfix stack to be able to hold n amount of lists.
* returns FAIL on failure and OK on success. * returns FAIL on failure and OK on success.
*/ */
int int
qf_resize_quickfix_stack(int n) qf_resize_stack(int n)
{ {
if (ql_info == NULL) if (ql_info == NULL)
{
emsg(_(e_no_quickfix_stack));
return FAIL; return FAIL;
}
if (qf_resize_stack(ql_info, n) == FAIL) if (qf_resize_stack_base(ql_info, n) == FAIL)
return FAIL; return FAIL;
return OK; return OK;
@ -2376,22 +2373,28 @@ ll_resize_stack(win_T *wp, int n)
qf_sync_win_to_llw(wp); qf_sync_win_to_llw(wp);
qf_info_T *qi = ll_get_or_alloc_list(wp); qf_info_T *qi = ll_get_or_alloc_list(wp);
if (qi == NULL)
return FAIL;
if (qf_resize_stack(qi, n) == FAIL) if (qf_resize_stack_base(qi, n) == FAIL)
return FAIL; return FAIL;
return OK; return OK;
} }
/* /*
* Resize quickfix stack to be able to hold n amount of quickfix lists. * Resize quickfix/location lists stack to be able to hold n amount of lists.
* Returns FAIL on failure and OK on success. * Returns FAIL on failure and OK on success.
*/ */
static int static int
qf_resize_stack(qf_info_T *qi, int n) qf_resize_stack_base(qf_info_T *qi, int n)
{ {
qf_list_T *new; qf_list_T *new;
int amount_to_rm = 0, i; int amount_to_rm = 0, i;
if (qi == NULL)
return FAIL;
size_t lsz = sizeof(*qi->qf_lists); size_t lsz = sizeof(*qi->qf_lists);
if (n == qi->qf_maxcount) if (n == qi->qf_maxcount)
@ -2424,21 +2427,12 @@ qf_resize_stack(qf_info_T *qi, int n)
} }
/* /*
* Initialize global quickfix list, should only be called once. * Initialize quickfix list, should only be called once.
* Returns FAIL on failure and OK on success.
*/ */
int void
qf_init_quickfix_stack(void) qf_init_stack(void)
{ {
ql_info_actual.qf_lists = qf_alloc_list_stack(p_chi); ql_info = qf_alloc_stack(QFLT_QUICKFIX, p_chi);
if (ql_info_actual.qf_lists == NULL)
return FAIL;
ql_info = &ql_info_actual;
ql_info->qfl_type = QFLT_QUICKFIX;
ql_info->qf_maxcount = p_chi;
return OK;
} }
/* /*
@ -2480,22 +2474,24 @@ qf_alloc_stack(qfltype_T qfltype, int n)
{ {
qf_info_T *qi; qf_info_T *qi;
qi = ALLOC_CLEAR_ONE_ID(qf_info_T, aid_qf_qfinfo); if (qfltype == QFLT_QUICKFIX)
if (qi == NULL) qi = &ql_info_actual;
return NULL; else
{
qi->qf_refcount++; qi = ALLOC_CLEAR_ONE_ID(qf_info_T, aid_qf_qfinfo);
if (qi == NULL)
return NULL;
qi->qf_refcount++;
}
qi->qfl_type = qfltype; qi->qfl_type = qfltype;
qi->qf_bufnr = INVALID_QFBUFNR; qi->qf_bufnr = INVALID_QFBUFNR;
qi->qf_lists = qf_alloc_list_stack(n); qi->qf_lists = qf_alloc_list_stack(n);
if (qi->qf_lists == NULL) if (qi->qf_lists == NULL)
{ {
vim_free(qi); if (qfltype != QFLT_QUICKFIX)
vim_free(qi);
return NULL; return NULL;
} }
qi->qf_maxcount = n; qi->qf_maxcount = n;
return qi; return qi;
@ -8259,20 +8255,15 @@ set_errorlist(
char_u *title, char_u *title,
dict_T *what) dict_T *what)
{ {
qf_info_T *qi = ql_info; qf_info_T *qi;
int retval = OK; int retval = OK;
if (wp != NULL) if (wp != NULL)
{
qi = ll_get_or_alloc_list(wp); qi = ll_get_or_alloc_list(wp);
if (qi == NULL) else
return FAIL; qi = ql_info;
} if (qi == NULL)
else if (qi == NULL)
{
emsg(_(e_no_quickfix_stack));
return FAIL; return FAIL;
}
if (action == 'f') if (action == 'f')
{ {

View File

@ -704,6 +704,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 */
/**/
1287,
/**/ /**/
1286, 1286,
/**/ /**/