|
reference, declaration → definition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
|
Declarations
tools/clang/include/clang/Sema/Sema.h 116 class EnableIfAttr;
References
gen/tools/clang/include/clang/AST/AttrImpl.inc 3324 EnableIfAttr *EnableIfAttr::clone(ASTContext &C) const {
3325 auto *A = new (C) EnableIfAttr(C, *this, cond, getMessage());
3325 auto *A = new (C) EnableIfAttr(C, *this, cond, getMessage());
11656 return cast<EnableIfAttr>(this)->getSpelling();
12236 return cast<EnableIfAttr>(this)->clone(C);
12816 return cast<EnableIfAttr>(this)->printPretty(OS, Policy);
gen/tools/clang/include/clang/AST/AttrNodeTraverse.inc 72 void VisitEnableIfAttr(const EnableIfAttr *A) {
73 const auto *SA = cast<EnableIfAttr>(A); (void)SA;
73 const auto *SA = cast<EnableIfAttr>(A); (void)SA;
gen/tools/clang/include/clang/AST/AttrTextNodeDump.inc 214 void VisitEnableIfAttr(const EnableIfAttr *A) {
215 const auto *SA = cast<EnableIfAttr>(A); (void)SA;
215 const auto *SA = cast<EnableIfAttr>(A); (void)SA;
gen/tools/clang/include/clang/AST/AttrVisitor.inc 331 bool TraverseEnableIfAttr(EnableIfAttr *A);
332 bool VisitEnableIfAttr(EnableIfAttr *A) {
1958 bool VISITORCLASS<Derived>::TraverseEnableIfAttr(EnableIfAttr *A) {
4116 return getDerived().TraverseEnableIfAttr(cast<EnableIfAttr>(A));
gen/tools/clang/include/clang/AST/Attrs.inc 4502 static EnableIfAttr *CreateImplicit(ASTContext &Ctx, Expr * Cond, llvm::StringRef Message, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
4503 auto *A = new (Ctx) EnableIfAttr(Ctx, CommonInfo, Cond, Message);
4503 auto *A = new (Ctx) EnableIfAttr(Ctx, CommonInfo, Cond, Message);
4510 static EnableIfAttr *Create(ASTContext &Ctx, Expr * Cond, llvm::StringRef Message, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
4511 auto *A = new (Ctx) EnableIfAttr(Ctx, CommonInfo, Cond, Message);
4511 auto *A = new (Ctx) EnableIfAttr(Ctx, CommonInfo, Cond, Message);
4517 static EnableIfAttr *CreateImplicit(ASTContext &Ctx, Expr * Cond, llvm::StringRef Message, SourceRange Range, AttributeCommonInfo::Syntax Syntax) {
4521 static EnableIfAttr *Create(ASTContext &Ctx, Expr * Cond, llvm::StringRef Message, SourceRange Range, AttributeCommonInfo::Syntax Syntax) {
4537 EnableIfAttr *clone(ASTContext &C) const;
gen/tools/clang/include/clang/Sema/AttrTemplateInstantiate.inc 408 const auto *A = cast<EnableIfAttr>(At);
408 const auto *A = cast<EnableIfAttr>(At);
415 return new (C) EnableIfAttr(C, *A, tempInstCond, A->getMessage());
gen/tools/clang/include/clang/Serialization/AttrPCHRead.inc 760 New = new (Context) EnableIfAttr(Context, Info, cond, message);
gen/tools/clang/include/clang/Serialization/AttrPCHWrite.inc 573 const auto *SA = cast<EnableIfAttr>(A);
573 const auto *SA = cast<EnableIfAttr>(A);
include/llvm/ADT/STLExtras.h 75 typename std::add_pointer<typename std::add_const<T>::type>::type;
include/llvm/Support/Casting.h 58 return To::classof(&Val);
66 static inline bool doit(const From &) { return true; }
104 static inline bool doit(const From *Val) {
106 return isa_impl<To, From>::doit(*Val);
106 return isa_impl<To, From>::doit(*Val);
122 return isa_impl_wrap<To, SimpleFrom,
132 return isa_impl_cl<To,FromTy>::doit(Val);
142 return isa_impl_wrap<X, const Y,
172 using ret_type = To *; // Pointer arg case, return Ty*
176 using ret_type = const To *; // Constant pointer arg case, return const Ty*
198 using ret_type = typename cast_retty<To, SimpleFrom>::ret_type;
204 using ret_type = typename cast_retty_impl<To,FromTy>::ret_type;
210 To, From, typename simplify_type<From>::SimpleType>::ret_type;
227 static typename cast_retty<To, FromTy>::ret_type doit(const FromTy &Val) {
228 typename cast_retty<To, FromTy>::ret_type Res2
256 inline typename cast_retty<X, Y>::ret_type cast(Y &Val) {
263 inline typename cast_retty<X, Y *>::ret_type cast(Y *Val) {
265 return cast_convert_val<X, Y*,
337 LLVM_NODISCARD inline typename cast_retty<X, Y>::ret_type dyn_cast(Y &Val) {
342 LLVM_NODISCARD inline typename cast_retty<X, Y *>::ret_type dyn_cast(Y *Val) {
343 return isa<X>(Val) ? cast<X>(Val) : nullptr;
343 return isa<X>(Val) ? cast<X>(Val) : nullptr;
tools/clang/include/clang/AST/AttrIterator.h 47 while (!isa<SpecificAttr>(*Current))
52 while (Current != I && !isa<SpecificAttr>(*Current))
57 using value_type = SpecificAttr *;
58 using reference = SpecificAttr *;
59 using pointer = SpecificAttr *;
68 return cast<SpecificAttr>(*Current);
72 return cast<SpecificAttr>(*Current);
101 inline specific_attr_iterator<SpecificAttr, Container>
106 inline specific_attr_iterator<SpecificAttr, Container>
113 return specific_attr_begin<SpecificAttr>(container) !=
114 specific_attr_end<SpecificAttr>(container);
tools/clang/include/clang/AST/DeclBase.h 524 llvm::iterator_range<specific_attr_iterator<T>> specific_attrs() const {
525 return llvm::make_range(specific_attr_begin<T>(), specific_attr_end<T>());
525 return llvm::make_range(specific_attr_begin<T>(), specific_attr_end<T>());
529 specific_attr_iterator<T> specific_attr_begin() const {
534 specific_attr_iterator<T> specific_attr_end() const {
543 return hasAttrs() && hasSpecificAttr<T>(getAttrs());
tools/clang/include/clang/Sema/Sema.h 3189 EnableIfAttr *CheckEnableIf(FunctionDecl *Function, ArrayRef<Expr *> Args,
tools/clang/lib/AST/ItaniumMangle.cpp 709 if (FD->hasAttr<EnableIfAttr>()) {
715 EnableIfAttr *EIA = dyn_cast<EnableIfAttr>(*I);
715 EnableIfAttr *EIA = dyn_cast<EnableIfAttr>(*I);
tools/clang/lib/CodeGen/Address.h 108 template <class U> inline U cast(CodeGen::Address addr) {
tools/clang/lib/Sema/SemaCodeComplete.cpp 1200 if (!llvm::empty(Candidate.specific_attrs<EnableIfAttr>()) ||
1201 !llvm::empty(Incumbent.specific_attrs<EnableIfAttr>()))
tools/clang/lib/Sema/SemaDeclAttr.cpp 997 D->addAttr(::new (S.Context) EnableIfAttr(S.Context, AL, Cond, Msg));
tools/clang/lib/Sema/SemaExpr.cpp 5489 if (const EnableIfAttr *Attr = S.CheckEnableIf(Callee, ArgExprs, true)) {
tools/clang/lib/Sema/SemaOverload.cpp 867 FD->hasAttr<EnableIfAttr>();
1225 for (specific_attr_iterator<EnableIfAttr>
1226 NewI = New->specific_attr_begin<EnableIfAttr>(),
1227 NewE = New->specific_attr_end<EnableIfAttr>(),
1228 OldI = Old->specific_attr_begin<EnableIfAttr>(),
1229 OldE = Old->specific_attr_end<EnableIfAttr>();
6284 if (EnableIfAttr *FailedAttr = CheckEnableIf(Function, Args)) {
6461 EnableIfAttr *Sema::CheckEnableIf(FunctionDecl *Function, ArrayRef<Expr *> Args,
6463 auto EnableIfAttrs = Function->specific_attrs<EnableIfAttr>();
6476 for (auto *EIA : EnableIfAttrs) {
6792 if (EnableIfAttr *FailedAttr = CheckEnableIf(Method, Args, true)) {
7212 if (EnableIfAttr *FailedAttr = CheckEnableIf(Conversion, None)) {
7370 if (EnableIfAttr *FailedAttr = CheckEnableIf(Conversion, None)) {
9198 bool Cand1Attr = Cand1->hasAttr<EnableIfAttr>();
9199 bool Cand2Attr = Cand2->hasAttr<EnableIfAttr>();
9206 auto Cand1Attrs = Cand1->specific_attrs<EnableIfAttr>();
9207 auto Cand2Attrs = Cand2->specific_attrs<EnableIfAttr>();
9211 Optional<EnableIfAttr *> Cand1A = std::get<0>(Pair);
9212 Optional<EnableIfAttr *> Cand2A = std::get<1>(Pair);
9777 for (auto *EnableIf : FD->specific_attrs<EnableIfAttr>()) {
9777 for (auto *EnableIf : FD->specific_attrs<EnableIfAttr>()) {
10556 EnableIfAttr *Attr = static_cast<EnableIfAttr*>(Cand->DeductionFailure.Data);
13539 if (const EnableIfAttr *Attr = CheckEnableIf(Method, Args, true)) {
tools/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp 214 const EnableIfAttr *EIA, const Decl *Tmpl, FunctionDecl *New) {
219 New->addAttr(new (S.getASTContext()) EnableIfAttr(S.getASTContext(), *EIA,
540 if (const auto *EnableIf = dyn_cast<EnableIfAttr>(TmplAttr)) {
540 if (const auto *EnableIf = dyn_cast<EnableIfAttr>(TmplAttr)) {
tools/clang/lib/Serialization/ASTReaderDecl.cpp 2910 auto AEnableIfAttrs = A->specific_attrs<EnableIfAttr>();
2911 auto BEnableIfAttrs = B->specific_attrs<EnableIfAttr>();
2914 Optional<EnableIfAttr *> Cand1A = std::get<0>(Pair);
2915 Optional<EnableIfAttr *> Cand2A = std::get<1>(Pair);
usr/include/c++/7.4.0/type_traits 1558 { typedef _Tp type; };
1580 { typedef _Tp const type; };