clang 20.0.0git
|
Information about a template-id annotation token. More...
#include "clang/Sema/ParsedTemplate.h"
Public Member Functions | |
ParsedTemplateArgument * | getTemplateArgs () |
Retrieves a pointer to the template arguments. | |
void | Destroy () |
bool | mightBeType () const |
Determine whether this might be a type template. | |
bool | hasInvalidName () const |
bool | hasInvalidArgs () const |
bool | isInvalid () const |
Static Public Member Functions | |
static TemplateIdAnnotation * | Create (SourceLocation TemplateKWLoc, SourceLocation TemplateNameLoc, const IdentifierInfo *Name, OverloadedOperatorKind OperatorKind, ParsedTemplateTy OpaqueTemplateName, TemplateNameKind TemplateKind, SourceLocation LAngleLoc, SourceLocation RAngleLoc, ArrayRef< ParsedTemplateArgument > TemplateArgs, bool ArgsInvalid, SmallVectorImpl< TemplateIdAnnotation * > &CleanupList) |
Creates a new TemplateIdAnnotation with NumArgs arguments and appends it to List. | |
Public Attributes | |
friend | TrailingObjects |
SourceLocation | TemplateKWLoc |
TemplateKWLoc - The location of the template keyword. | |
SourceLocation | TemplateNameLoc |
TemplateNameLoc - The location of the template name within the source. | |
const IdentifierInfo * | Name |
FIXME: Temporarily stores the name of a specialization. | |
OverloadedOperatorKind | Operator |
FIXME: Temporarily stores the overloaded operator kind. | |
ParsedTemplateTy | Template |
The declaration of the template corresponding to the template-name. | |
TemplateNameKind | Kind |
The kind of template that Template refers to. | |
SourceLocation | LAngleLoc |
The location of the '<' before the template argument list. | |
SourceLocation | RAngleLoc |
The location of the '>' after the template argument list. | |
unsigned | NumArgs |
NumArgs - The number of template arguments. | |
bool | ArgsInvalid |
Whether an error was encountered in the template arguments. | |
Information about a template-id annotation token.
A template-id annotation token contains the template name, template arguments, and the source locations for important tokens. All of the information about template arguments is allocated directly after this structure. A template-id annotation token can also be generated by a type-constraint construct with no explicit template arguments, e.g. "template<C T>" would annotate C as a TemplateIdAnnotation with no template arguments (the angle locations would be invalid in this case).
Definition at line 149 of file ParsedTemplate.h.
|