mirror of
https://github.com/vim/vim.git
synced 2025-10-13 06:54:15 -04:00
patch 8.1.1093: support for outdated tags format slows down tag parsing
Problem: Support for outdated tags format slows down tag parsing. Solution: Remove FEAT_TAG_OLDSTATIC.
This commit is contained in:
@@ -305,12 +305,9 @@
|
||||
#endif
|
||||
|
||||
/*
|
||||
* +tag_old_static Old style static tags: "file:tag file ..". Slows
|
||||
* down tag searching a bit.
|
||||
* +tag_old_static Old style static tags: "file:tag file ..".
|
||||
* Support was removed in 8.1.1093.
|
||||
*/
|
||||
#ifdef FEAT_NORMAL
|
||||
# define FEAT_TAG_OLDSTATIC
|
||||
#endif
|
||||
|
||||
/*
|
||||
* +cscope Unix only: Cscope support.
|
||||
|
53
src/tag.c
53
src/tag.c
@@ -1964,28 +1964,6 @@ parse_line:
|
||||
break;
|
||||
}
|
||||
|
||||
#ifdef FEAT_TAG_OLDSTATIC
|
||||
/*
|
||||
* Check for old style static tag: "file:tag file .."
|
||||
*/
|
||||
tagp.fname = NULL;
|
||||
for (p = lbuf; p < tagp.tagname_end; ++p)
|
||||
{
|
||||
if (*p == ':')
|
||||
{
|
||||
if (tagp.fname == NULL)
|
||||
tagp.fname = tagp.tagname_end + 1;
|
||||
if (fnamencmp(lbuf, tagp.fname, p - lbuf) == 0
|
||||
&& tagp.fname[p - lbuf] == TAB)
|
||||
{
|
||||
// found one
|
||||
tagp.tagname = p + 1;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Skip this line if the length of the tag is different and
|
||||
* there is no regexp, or the tag is too short.
|
||||
@@ -2098,10 +2076,7 @@ parse_line:
|
||||
/*
|
||||
* Can be a matching tag, isolate the file name and command.
|
||||
*/
|
||||
#ifdef FEAT_TAG_OLDSTATIC
|
||||
if (tagp.fname == NULL)
|
||||
#endif
|
||||
tagp.fname = tagp.tagname_end + 1;
|
||||
tagp.fname = tagp.tagname_end + 1;
|
||||
tagp.fname_end = vim_strchr(tagp.fname, TAB);
|
||||
tagp.command = tagp.fname_end + 1;
|
||||
if (tagp.fname_end == NULL)
|
||||
@@ -2201,14 +2176,7 @@ parse_line:
|
||||
is_static = FALSE;
|
||||
if (!is_etag) /* emacs tags are never static */
|
||||
#endif
|
||||
{
|
||||
#ifdef FEAT_TAG_OLDSTATIC
|
||||
if (tagp.tagname != lbuf)
|
||||
is_static = TRUE; /* detected static tag before */
|
||||
else
|
||||
#endif
|
||||
is_static = test_for_static(&tagp);
|
||||
}
|
||||
is_static = test_for_static(&tagp);
|
||||
|
||||
/* decide in which of the sixteen tables to store this
|
||||
* match */
|
||||
@@ -2870,23 +2838,6 @@ test_for_static(tagptrs_T *tagp)
|
||||
{
|
||||
char_u *p;
|
||||
|
||||
#ifdef FEAT_TAG_OLDSTATIC
|
||||
int len;
|
||||
|
||||
/*
|
||||
* Check for old style static tag: "file:tag file .."
|
||||
*/
|
||||
len = (int)(tagp->fname_end - tagp->fname);
|
||||
p = tagp->tagname + len;
|
||||
if ( p < tagp->tagname_end
|
||||
&& *p == ':'
|
||||
&& fnamencmp(tagp->tagname, tagp->fname, len) == 0)
|
||||
{
|
||||
tagp->tagname = p + 1;
|
||||
return TRUE;
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Check for new style static tag ":...<Tab>file:[<Tab>...]"
|
||||
*/
|
||||
|
@@ -605,11 +605,7 @@ static char *(features[]) =
|
||||
#else
|
||||
"-tag_binary",
|
||||
#endif
|
||||
#ifdef FEAT_TAG_OLDSTATIC
|
||||
"+tag_old_static",
|
||||
#else
|
||||
"-tag_old_static",
|
||||
#endif
|
||||
"-tag_any_white",
|
||||
#ifdef FEAT_TCL
|
||||
# ifdef DYNAMIC_TCL
|
||||
@@ -775,6 +771,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1093,
|
||||
/**/
|
||||
1092,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user