forked from aniani/vim
patch 7.4.2234
Problem: Can't build with +eval but without +quickfix. (John Marriott) Solution: Move skip_vimgrep_pat() to separate #ifdef block.
This commit is contained in:
106
src/quickfix.c
106
src/quickfix.c
@@ -4318,58 +4318,6 @@ theend:
|
|||||||
vim_regfree(regmatch.regprog);
|
vim_regfree(regmatch.regprog);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Skip over the pattern argument of ":vimgrep /pat/[g][j]".
|
|
||||||
* Put the start of the pattern in "*s", unless "s" is NULL.
|
|
||||||
* If "flags" is not NULL put the flags in it: VGR_GLOBAL, VGR_NOJUMP.
|
|
||||||
* If "s" is not NULL terminate the pattern with a NUL.
|
|
||||||
* Return a pointer to the char just past the pattern plus flags.
|
|
||||||
*/
|
|
||||||
char_u *
|
|
||||||
skip_vimgrep_pat(char_u *p, char_u **s, int *flags)
|
|
||||||
{
|
|
||||||
int c;
|
|
||||||
|
|
||||||
if (vim_isIDc(*p))
|
|
||||||
{
|
|
||||||
/* ":vimgrep pattern fname" */
|
|
||||||
if (s != NULL)
|
|
||||||
*s = p;
|
|
||||||
p = skiptowhite(p);
|
|
||||||
if (s != NULL && *p != NUL)
|
|
||||||
*p++ = NUL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* ":vimgrep /pattern/[g][j] fname" */
|
|
||||||
if (s != NULL)
|
|
||||||
*s = p + 1;
|
|
||||||
c = *p;
|
|
||||||
p = skip_regexp(p + 1, c, TRUE, NULL);
|
|
||||||
if (*p != c)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
/* Truncate the pattern. */
|
|
||||||
if (s != NULL)
|
|
||||||
*p = NUL;
|
|
||||||
++p;
|
|
||||||
|
|
||||||
/* Find the flags */
|
|
||||||
while (*p == 'g' || *p == 'j')
|
|
||||||
{
|
|
||||||
if (flags != NULL)
|
|
||||||
{
|
|
||||||
if (*p == 'g')
|
|
||||||
*flags |= VGR_GLOBAL;
|
|
||||||
else
|
|
||||||
*flags |= VGR_NOJUMP;
|
|
||||||
}
|
|
||||||
++p;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return p;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Restore current working directory to "dirname_start" if they differ, taking
|
* Restore current working directory to "dirname_start" if they differ, taking
|
||||||
* into account whether it is set locally or globally.
|
* into account whether it is set locally or globally.
|
||||||
@@ -5207,3 +5155,57 @@ ex_helpgrep(exarg_T *eap)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endif /* FEAT_QUICKFIX */
|
#endif /* FEAT_QUICKFIX */
|
||||||
|
|
||||||
|
#if defined(FEAT_QUICKFIX) || defined(FEAT_EVAL) || defined(PROTO)
|
||||||
|
/*
|
||||||
|
* Skip over the pattern argument of ":vimgrep /pat/[g][j]".
|
||||||
|
* Put the start of the pattern in "*s", unless "s" is NULL.
|
||||||
|
* If "flags" is not NULL put the flags in it: VGR_GLOBAL, VGR_NOJUMP.
|
||||||
|
* If "s" is not NULL terminate the pattern with a NUL.
|
||||||
|
* Return a pointer to the char just past the pattern plus flags.
|
||||||
|
*/
|
||||||
|
char_u *
|
||||||
|
skip_vimgrep_pat(char_u *p, char_u **s, int *flags)
|
||||||
|
{
|
||||||
|
int c;
|
||||||
|
|
||||||
|
if (vim_isIDc(*p))
|
||||||
|
{
|
||||||
|
/* ":vimgrep pattern fname" */
|
||||||
|
if (s != NULL)
|
||||||
|
*s = p;
|
||||||
|
p = skiptowhite(p);
|
||||||
|
if (s != NULL && *p != NUL)
|
||||||
|
*p++ = NUL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* ":vimgrep /pattern/[g][j] fname" */
|
||||||
|
if (s != NULL)
|
||||||
|
*s = p + 1;
|
||||||
|
c = *p;
|
||||||
|
p = skip_regexp(p + 1, c, TRUE, NULL);
|
||||||
|
if (*p != c)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
/* Truncate the pattern. */
|
||||||
|
if (s != NULL)
|
||||||
|
*p = NUL;
|
||||||
|
++p;
|
||||||
|
|
||||||
|
/* Find the flags */
|
||||||
|
while (*p == 'g' || *p == 'j')
|
||||||
|
{
|
||||||
|
if (flags != NULL)
|
||||||
|
{
|
||||||
|
if (*p == 'g')
|
||||||
|
*flags |= VGR_GLOBAL;
|
||||||
|
else
|
||||||
|
*flags |= VGR_NOJUMP;
|
||||||
|
}
|
||||||
|
++p;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@@ -763,6 +763,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 */
|
||||||
|
/**/
|
||||||
|
2234,
|
||||||
/**/
|
/**/
|
||||||
2233,
|
2233,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user