clang 20.0.0git
Public Member Functions | List of all members
clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor Class Reference

MatcherDescriptor that wraps multiple "overloads" of the same matcher. More...

#include "/home/buildbot/as-worker-4/publish-doxygen-docs/llvm-project/clang/lib/ASTMatchers/Dynamic/Marshallers.h"

Inheritance diagram for clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor:
Inheritance graph
[legend]

Public Member Functions

 OverloadedMatcherDescriptor (MutableArrayRef< std::unique_ptr< MatcherDescriptor > > Callbacks)
 
 ~OverloadedMatcherDescriptor () override=default
 
VariantMatcher create (SourceRange NameRange, ArrayRef< ParserValue > Args, Diagnostics *Error) const override
 
bool isVariadic () const override
 Returns whether the matcher is variadic.
 
unsigned getNumArgs () const override
 Returns the number of arguments accepted by the matcher if not variadic.
 
void getArgKinds (ASTNodeKind ThisKind, unsigned ArgNo, std::vector< ArgKind > &Kinds) const override
 Given that the matcher is being converted to type ThisKind, append the set of argument types accepted for argument ArgNo to ArgKinds.
 
bool isConvertibleTo (ASTNodeKind Kind, unsigned *Specificity, ASTNodeKind *LeastDerivedKind) const override
 Returns whether this matcher is convertible to the given type.
 
- Public Member Functions inherited from clang::ast_matchers::dynamic::internal::MatcherDescriptor
virtual ~MatcherDescriptor ()=default
 
virtual VariantMatcher create (SourceRange NameRange, ArrayRef< ParserValue > Args, Diagnostics *Error) const =0
 
virtual ASTNodeKind nodeMatcherType () const
 
virtual bool isBuilderMatcher () const
 
virtual std::unique_ptr< MatcherDescriptorbuildMatcherCtor (SourceRange NameRange, ArrayRef< ParserValue > Args, Diagnostics *Error) const
 
virtual bool isVariadic () const =0
 Returns whether the matcher is variadic.
 
virtual unsigned getNumArgs () const =0
 Returns the number of arguments accepted by the matcher if not variadic.
 
virtual void getArgKinds (ASTNodeKind ThisKind, unsigned ArgNo, std::vector< ArgKind > &ArgKinds) const =0
 Given that the matcher is being converted to type ThisKind, append the set of argument types accepted for argument ArgNo to ArgKinds.
 
virtual bool isConvertibleTo (ASTNodeKind Kind, unsigned *Specificity=nullptr, ASTNodeKind *LeastDerivedKind=nullptr) const =0
 Returns whether this matcher is convertible to the given type.
 
virtual bool isPolymorphic () const
 Returns whether the matcher will, given a matcher of any type T, yield a matcher of type T.
 

Detailed Description

MatcherDescriptor that wraps multiple "overloads" of the same matcher.

It will try every overload and generate appropriate errors for when none or more than one overloads match the arguments.

Definition at line 725 of file Marshallers.h.

Constructor & Destructor Documentation

◆ OverloadedMatcherDescriptor()

clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor::OverloadedMatcherDescriptor ( MutableArrayRef< std::unique_ptr< MatcherDescriptor > >  Callbacks)
inline

Definition at line 727 of file Marshallers.h.

◆ ~OverloadedMatcherDescriptor()

clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor::~OverloadedMatcherDescriptor ( )
overridedefault

Member Function Documentation

◆ create()

VariantMatcher clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor::create ( SourceRange  NameRange,
ArrayRef< ParserValue Args,
Diagnostics Error 
) const
inlineoverridevirtual

◆ getArgKinds()

void clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor::getArgKinds ( ASTNodeKind  ThisKind,
unsigned  ArgNo,
std::vector< ArgKind > &  ArgKinds 
) const
inlineoverridevirtual

Given that the matcher is being converted to type ThisKind, append the set of argument types accepted for argument ArgNo to ArgKinds.

Implements clang::ast_matchers::dynamic::internal::MatcherDescriptor.

Definition at line 777 of file Marshallers.h.

◆ getNumArgs()

unsigned clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor::getNumArgs ( ) const
inlineoverridevirtual

Returns the number of arguments accepted by the matcher if not variadic.

Implements clang::ast_matchers::dynamic::internal::MatcherDescriptor.

Definition at line 767 of file Marshallers.h.

◆ isConvertibleTo()

bool clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor::isConvertibleTo ( ASTNodeKind  Kind,
unsigned Specificity,
ASTNodeKind LeastDerivedKind 
) const
inlineoverridevirtual

Returns whether this matcher is convertible to the given type.

If it is so convertible, store in *Specificity a value corresponding to the "specificity" of the converted matcher to the given context, and in *LeastDerivedKind the least derived matcher kind which would result in the same matcher overload. Zero specificity indicates that this conversion would produce a trivial matcher that will either always or never match. Such matchers are excluded from code completion results.

Implements clang::ast_matchers::dynamic::internal::MatcherDescriptor.

Definition at line 785 of file Marshallers.h.

References Kind.

◆ isVariadic()

bool clang::ast_matchers::dynamic::internal::OverloadedMatcherDescriptor::isVariadic ( ) const
inlineoverridevirtual

Returns whether the matcher is variadic.

Variadic matchers can take any number of arguments, but they must be of the same type.

Implements clang::ast_matchers::dynamic::internal::MatcherDescriptor.

Definition at line 757 of file Marshallers.h.


The documentation for this class was generated from the following file: