<p>In <a href="https://github.com/geany/geany/pull/889#discussion_r50985317">tagmanager/ctags/c.c</a>:</p>
<pre style='color:#555'>>      for (i = 0; i < st->tokenIndex; i++)
>    {
> +          const tokenInfo *const t = st->token[i];
> +
> +          /* stop if we find the token used to generate the tag name, or
> +           * a name token in the middle yet not preceded by a scope separator */
> +          if ((t == nameToken ||
> +               (t->type == nameToken->type &&
> +                t->keyword == nameToken->keyword &&
> +                t->lineNumber == nameToken->lineNumber &&
> +                strcmp(vStringValue(t->name), vStringValue(nameToken->name)) == 0)) ||
> +              (t->type == TOKEN_NAME && seenType &&
> +               (i > 0 && st->token[i - 1]->type != TOKEN_DOUBLE_COLON)))
</pre>
<p><a href="https://github.com/elextr" class="user-mention">@elextr</a> I'm afraid that proper template parsing would double the c.c size and would take a really lot of time to develop. The only possibility to have templates in the type is to really just record the input string together with some reasonable begin/end type detection. But even this will probably require quite some work and the question is whether it's worth it.</p>

<p>The implementation in this patch is good enough IMO - at least for the scope completion where we'd have to remove the templates anyway.</p>

<p style="font-size:small;-webkit-text-size-adjust:none;color:#666;">—<br>Reply to this email directly or <a href="https://github.com/geany/geany/pull/889/files#r50985317">view it on GitHub</a>.<img alt="" height="1" src="https://github.com/notifications/beacon/ABDrJ8G8YRbl9sdvQDo0rTi2K8WD5SERks5peMMugaJpZM4HMkrH.gif" width="1" /></p>
<div itemscope itemtype="http://schema.org/EmailMessage">
<div itemprop="action" itemscope itemtype="http://schema.org/ViewAction">
  <link itemprop="url" href="https://github.com/geany/geany/pull/889/files#r50985317"></link>
  <meta itemprop="name" content="View Pull Request"></meta>
</div>
<meta itemprop="description" content="View this Pull Request on GitHub"></meta>
</div>