clang 20.0.0git
Public Member Functions | Static Public Member Functions | Public Attributes | List of all members
clang::TemplateIdAnnotation Struct Referencefinal

Information about a template-id annotation token. More...

#include "clang/Sema/ParsedTemplate.h"

Inheritance diagram for clang::TemplateIdAnnotation:
Inheritance graph
[legend]

Public Member Functions

ParsedTemplateArgumentgetTemplateArgs ()
 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 TemplateIdAnnotationCreate (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 IdentifierInfoName
 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.
 

Detailed Description

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.

Member Function Documentation

◆ Create()

static TemplateIdAnnotation * clang::TemplateIdAnnotation::Create ( SourceLocation  TemplateKWLoc,
SourceLocation  TemplateNameLoc,
const