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

References

gen/tools/clang/include/clang/AST/AttrImpl.inc
 2862 ConsumableAttr *ConsumableAttr::clone(ASTContext &C) const {
 2863   auto *A = new (C) ConsumableAttr(C, *this, defaultState);
 2863   auto *A = new (C) ConsumableAttr(C, *this, defaultState);
 2876     OS << " __attribute__((consumable(\"" << ConsumableAttr::ConvertConsumedStateToStr(getDefaultState()) << "\")))";
 2880     OS << " [[clang::consumable(\"" << ConsumableAttr::ConvertConsumedStateToStr(getDefaultState()) << "\")]]";
11630     return cast<ConsumableAttr>(this)->getSpelling();
12210     return cast<ConsumableAttr>(this)->clone(C);
12790     return cast<ConsumableAttr>(this)->printPretty(OS, Policy);
gen/tools/clang/include/clang/AST/AttrTextNodeDump.inc
  176   void VisitConsumableAttr(const ConsumableAttr *A) {
  177     const auto *SA = cast<ConsumableAttr>(A); (void)SA;
  177     const auto *SA = cast<ConsumableAttr>(A); (void)SA;
  179     case ConsumableAttr::Unknown:
  182     case ConsumableAttr::Consumed:
  185     case ConsumableAttr::Unconsumed:
gen/tools/clang/include/clang/AST/AttrVisitor.inc
  279   bool TraverseConsumableAttr(ConsumableAttr *A);
  280   bool VisitConsumableAttr(ConsumableAttr *A) {
 1839 bool VISITORCLASS<Derived>::TraverseConsumableAttr(ConsumableAttr *A) {
 4090       return getDerived().TraverseConsumableAttr(cast<ConsumableAttr>(A));
gen/tools/clang/include/clang/AST/Attrs.inc
 3759   static ConsumableAttr *CreateImplicit(ASTContext &Ctx, ConsumedState DefaultState, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
 3760     auto *A = new (Ctx) ConsumableAttr(Ctx, CommonInfo, DefaultState);
 3760     auto *A = new (Ctx) ConsumableAttr(Ctx, CommonInfo, DefaultState);
 3767   static ConsumableAttr *Create(ASTContext &Ctx, ConsumedState DefaultState, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
 3768     auto *A = new (Ctx) ConsumableAttr(Ctx, CommonInfo, DefaultState);
 3768     auto *A = new (Ctx) ConsumableAttr(Ctx, CommonInfo, DefaultState);
 3774   static ConsumableAttr *CreateImplicit(ASTContext &Ctx, ConsumedState DefaultState, SourceRange Range, AttributeCommonInfo::Syntax Syntax) {
 3778   static ConsumableAttr *Create(ASTContext &Ctx, ConsumedState DefaultState, SourceRange Range, AttributeCommonInfo::Syntax Syntax) {
 3790   ConsumableAttr *clone(ASTContext &C) const;
 3800       .Case("unknown", ConsumableAttr::Unknown)
 3801       .Case("consumed", ConsumableAttr::Consumed)
 3802       .Case("unconsumed", ConsumableAttr::Unconsumed)
 3813     case ConsumableAttr::Unknown: return "unknown";
 3814     case ConsumableAttr::Consumed: return "consumed";
 3815     case ConsumableAttr::Unconsumed: return "unconsumed";
gen/tools/clang/include/clang/Sema/AttrTemplateInstantiate.inc
  350       const auto *A = cast<ConsumableAttr>(At);
  350       const auto *A = cast<ConsumableAttr>(At);
gen/tools/clang/include/clang/Serialization/AttrPCHRead.inc
  645     ConsumableAttr::ConsumedState defaultState(static_cast<ConsumableAttr::ConsumedState>(Record.readInt()));
  646     New = new (Context) ConsumableAttr(Context, Info, defaultState);
gen/tools/clang/include/clang/Serialization/AttrPCHWrite.inc
  486     const auto *SA = cast<ConsumableAttr>(A);
  486     const auto *SA = cast<ConsumableAttr>(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*,
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
  538   template<typename T> T *getAttr() const {
  539     return hasAttrs() ? getSpecificAttr<T>(getAttrs()) : nullptr;
  543     return hasAttrs() && hasSpecificAttr<T>(getAttrs());
tools/clang/lib/Analysis/Consumed.cpp
  148     return RD->hasAttr<ConsumableAttr>();
  196   const ConsumableAttr *CAttr =
  197       QT->getAsCXXRecordDecl()->getAttr<ConsumableAttr>();
  200   case ConsumableAttr::Unknown:
  202   case ConsumableAttr::Unconsumed:
  204   case ConsumableAttr::Consumed:
 1208     if (!RD || !RD->hasAttr<ConsumableAttr>()) {
tools/clang/lib/CodeGen/Address.h
  108 template <class U> inline U cast(CodeGen::Address addr) {
tools/clang/lib/Sema/SemaDeclAttr.cpp
 1105   ConsumableAttr::ConsumedState DefaultState;
 1109     if (!ConsumableAttr::ConvertStrToConsumedState(IL->Ident->getName(),
 1121   D->addAttr(::new (S.Context) ConsumableAttr(S.Context, AL, DefaultState));
 1129     if (!RD->hasAttr<ConsumableAttr>()) {
usr/include/c++/7.4.0/type_traits
 1558     { typedef _Tp     type; };
 1580     { typedef _Tp const     type; };