reference, declarationdefinition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced

References

gen/tools/clang/include/clang/AST/AttrImpl.inc
11127 WeakAttr *WeakAttr::clone(ASTContext &C) const {
11128   auto *A = new (C) WeakAttr(C, *this);
11128   auto *A = new (C) WeakAttr(C, *this);
12052     return cast<WeakAttr>(this)->getSpelling();
12632     return cast<WeakAttr>(this)->clone(C);
13212     return cast<WeakAttr>(this)->printPretty(OS, Policy);
gen/tools/clang/include/clang/AST/AttrVisitor.inc
 1123   bool TraverseWeakAttr(WeakAttr *A);
 1124   bool VisitWeakAttr(WeakAttr *A) {
 3869 bool VISITORCLASS<Derived>::TraverseWeakAttr(WeakAttr *A) {
 4512       return getDerived().TraverseWeakAttr(cast<WeakAttr>(A));
gen/tools/clang/include/clang/AST/Attrs.inc
15095   static WeakAttr *CreateImplicit(ASTContext &Ctx, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
15096     auto *A = new (Ctx) WeakAttr(Ctx, CommonInfo);
15096     auto *A = new (Ctx) WeakAttr(Ctx, CommonInfo);
15103   static WeakAttr *Create(ASTContext &Ctx, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
15104     auto *A = new (Ctx) WeakAttr(Ctx, CommonInfo);
15104     auto *A = new (Ctx) WeakAttr(Ctx, CommonInfo);
15110   static WeakAttr *CreateImplicit(ASTContext &Ctx, SourceRange Range, AttributeCommonInfo::Syntax Syntax) {
15114   static WeakAttr *Create(ASTContext &Ctx, SourceRange Range, AttributeCommonInfo::Syntax Syntax) {
15124   WeakAttr *clone(ASTContext &C) const;
gen/tools/clang/include/clang/Sema/AttrTemplateInstantiate.inc
 1306       const auto *A = cast<WeakAttr>(At);
 1306       const auto *A = cast<WeakAttr>(At);
gen/tools/clang/include/clang/Serialization/AttrPCHRead.inc
 2456     New = new (Context) WeakAttr(Context, Info);
gen/tools/clang/include/clang/Serialization/AttrPCHWrite.inc
 1839     const auto *SA = cast<WeakAttr>(A);
 1839     const auto *SA = cast<WeakAttr>(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);
  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*,
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);
  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);
  117 inline SpecificAttr *getSpecificAttr(const Container& container) {
  118   specific_attr_iterator<SpecificAttr, Container> i =
  119       specific_attr_begin<SpecificAttr>(container);
  120   if (i != specific_attr_end<SpecificAttr>(container))
tools/clang/include/clang/AST/DeclBase.h
  517     Vec.erase(std::remove_if(Vec.begin(), Vec.end(), isa<T, Attr*>), Vec.end());
  538   template<typename T> T *getAttr() const {
  539     return hasAttrs() ? getSpecificAttr<T>(getAttrs()) : nullptr;
  543     return hasAttrs() && hasSpecificAttr<T>(getAttrs());
tools/clang/lib/AST/Decl.cpp
 4598     if (isa<WeakAttr>(I) || isa<WeakRefAttr>(I))
tools/clang/lib/CodeGen/Address.h
  108 template <class U> inline U cast(CodeGen::Address addr) {
tools/clang/lib/CodeGen/CGOpenMPRuntime.cpp
 1303     if (D->hasAttr<WeakAttr>() || D->hasAttr<WeakRefAttr>() ||
tools/clang/lib/CodeGen/CodeGenModule.cpp
 1766       (ND->hasAttr<WeakAttr>() || ND->isWeakImported()))
 3122       if (FD && !FD->hasAttr<WeakAttr>())
 3415       if (D && !D->hasAttr<WeakAttr>())
 4180   if (D->hasAttr<WeakAttr>()) {
 4503   if (D->hasAttr<WeakAttr>() || D->hasAttr<WeakRefAttr>() ||
tools/clang/lib/CodeGen/ItaniumCXXABI.cpp
 3307       if (RD->hasAttr<WeakAttr>())
tools/clang/lib/Frontend/InterfaceStubFunctionsConsumer.cpp
  121       const bool IsWeak = (ND->hasAttr<WeakAttr>() ||
tools/clang/lib/Sema/SemaDecl.cpp
 6126   if (WeakAttr *Attr = ND.getAttr<WeakAttr>()) {
 6126   if (WeakAttr *Attr = ND.getAttr<WeakAttr>()) {
 6129       ND.dropAttr<WeakAttr>();
17628     PrevDecl->addAttr(WeakAttr::CreateImplicit(Context, PragmaLoc, AttributeCommonInfo::AS_Pragma));
tools/clang/lib/Sema/SemaDeclAttr.cpp
  404   D->addAttr(::new (S.Context) AttrType(S.Context, CI));
 6904     handleSimpleAttribute<WeakAttr>(S, D, AL);
 7384     NewD->addAttr(WeakAttr::CreateImplicit(Context, W.getLocation(),
 7396     ND->addAttr(WeakAttr::CreateImplicit(Context, W.getLocation(),
tools/clang/lib/Sema/SemaDeclCXX.cpp
 2677         if (RD->hasAttr<WeakAttr>())
 2678           Class->addAttr(WeakAttr::CreateImplicit(Context));
usr/include/c++/7.4.0/type_traits
 1558     { typedef _Tp     type; };
 1580     { typedef _Tp const     type; };