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

References

gen/tools/clang/include/clang/AST/AttrImpl.inc
  929 AlwaysInlineAttr *AlwaysInlineAttr::clone(ASTContext &C) const {
  930   auto *A = new (C) AlwaysInlineAttr(C, *this);
  930   auto *A = new (C) AlwaysInlineAttr(C, *this);
11536     return cast<AlwaysInlineAttr>(this)->getSpelling();
12116     return cast<AlwaysInlineAttr>(this)->clone(C);
12696     return cast<AlwaysInlineAttr>(this)->printPretty(OS, Policy);
gen/tools/clang/include/clang/AST/AttrTextNodeDump.inc
   73   void VisitAlwaysInlineAttr(const AlwaysInlineAttr *A) {
gen/tools/clang/include/clang/AST/AttrVisitor.inc
   91   bool TraverseAlwaysInlineAttr(AlwaysInlineAttr *A);
   92   bool VisitAlwaysInlineAttr(AlwaysInlineAttr *A) {
 1384 bool VISITORCLASS<Derived>::TraverseAlwaysInlineAttr(AlwaysInlineAttr *A) {
 3996       return getDerived().TraverseAlwaysInlineAttr(cast<AlwaysInlineAttr>(A));
gen/tools/clang/include/clang/AST/Attrs.inc
 1168   static AlwaysInlineAttr *CreateImplicit(ASTContext &Ctx, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
 1169     auto *A = new (Ctx) AlwaysInlineAttr(Ctx, CommonInfo);
 1169     auto *A = new (Ctx) AlwaysInlineAttr(Ctx, CommonInfo);
 1176   static AlwaysInlineAttr *Create(ASTContext &Ctx, const AttributeCommonInfo &CommonInfo = {SourceRange{}}) {
 1177     auto *A = new (Ctx) AlwaysInlineAttr(Ctx, CommonInfo);
 1177     auto *A = new (Ctx) AlwaysInlineAttr(Ctx, CommonInfo);
 1181   static AlwaysInlineAttr *CreateImplicit(ASTContext &Ctx, SourceRange Range, AttributeCommonInfo::Syntax Syntax, AlwaysInlineAttr::Spelling S = static_cast<Spelling>(SpellingNotCalculated)) {
 1181   static AlwaysInlineAttr *CreateImplicit(ASTContext &Ctx, SourceRange Range, AttributeCommonInfo::Syntax Syntax, AlwaysInlineAttr::Spelling S = static_cast<Spelling>(SpellingNotCalculated)) {
 1185   static AlwaysInlineAttr *Create(ASTContext &Ctx, SourceRange Range, AttributeCommonInfo::Syntax Syntax, AlwaysInlineAttr::Spelling S = static_cast<Spelling>(SpellingNotCalculated)) {
 1185   static AlwaysInlineAttr *Create(ASTContext &Ctx, SourceRange Range, AttributeCommonInfo::Syntax Syntax, AlwaysInlineAttr::Spelling S = static_cast<Spelling>(SpellingNotCalculated)) {
 1195   AlwaysInlineAttr *clone(ASTContext &C) const;
gen/tools/clang/include/clang/Sema/AttrTemplateInstantiate.inc
  129       const auto *A = cast<AlwaysInlineAttr>(At);
  129       const auto *A = cast<AlwaysInlineAttr>(At);
gen/tools/clang/include/clang/Serialization/AttrPCHRead.inc
  208     New = new (Context) AlwaysInlineAttr(Context, Info);
gen/tools/clang/include/clang/Serialization/AttrPCHWrite.inc
  157     const auto *SA = cast<AlwaysInlineAttr>(A);
  157     const auto *SA = cast<AlwaysInlineAttr>(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*,
  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);
  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/include/clang/Sema/Sema.h
 2810   AlwaysInlineAttr *mergeAlwaysInlineAttr(Decl *D,
tools/clang/lib/CodeGen/Address.h
  108 template <class U> inline U cast(CodeGen::Address addr) {
tools/clang/lib/CodeGen/CGCXX.cpp
  149         TargetDecl.getDecl()->hasAttr<AlwaysInlineAttr>())) {
tools/clang/lib/CodeGen/CGCall.cpp
 3804     if (TargetDecl->hasAttr<AlwaysInlineAttr>() &&
tools/clang/lib/CodeGen/CodeGenModule.cpp
 1518   ShouldAddOptNone &= !D->hasAttr<AlwaysInlineAttr>();
 1544   } else if (D->hasAttr<AlwaysInlineAttr>() &&
 2697   if (CodeGenOpts.OptimizationLevel == 0 && !F->hasAttr<AlwaysInlineAttr>())
tools/clang/lib/Sema/SemaAttr.cpp
  866   if (FD->hasAttr<MinSizeAttr>() || FD->hasAttr<AlwaysInlineAttr>())
tools/clang/lib/Sema/SemaDecl.cpp
 2553   else if (const auto *AA = dyn_cast<AlwaysInlineAttr>(Attr))
 2553   else if (const auto *AA = dyn_cast<AlwaysInlineAttr>(Attr))
tools/clang/lib/Sema/SemaDeclAttr.cpp
  299   if (const auto *A = D->getAttr<AttrTy>()) {
  299   if (const auto *A = D->getAttr<AttrTy>()) {
  450   if (checkAttrMutualExclusion<IncompatibleAttrType>(S, D, AL))
 4049 AlwaysInlineAttr *Sema::mergeAlwaysInlineAttr(Decl *D,
 4058   if (D->hasAttr<AlwaysInlineAttr>())
 4061   return ::new (Context) AlwaysInlineAttr(Context, CI);
 4148   if (AlwaysInlineAttr *Inline = D->getAttr<AlwaysInlineAttr>()) {
 4148   if (AlwaysInlineAttr *Inline = D->getAttr<AlwaysInlineAttr>()) {
 4151     D->dropAttr<AlwaysInlineAttr>();
 4177   if (AlwaysInlineAttr *Inline =
 6881     handleSimpleAttributeWithExclusions<NotTailCalledAttr, AlwaysInlineAttr>(
tools/clang/lib/Sema/SemaOpenMP.cpp
 3141         AlwaysInlineAttr::CreateImplicit(
 3143             AlwaysInlineAttr::Keyword_forceinline));
 3186         AlwaysInlineAttr::CreateImplicit(
 3188             AlwaysInlineAttr::Keyword_forceinline));
 3239         AlwaysInlineAttr::CreateImplicit(
 3241             AlwaysInlineAttr::Keyword_forceinline));
 3284         AlwaysInlineAttr::CreateImplicit(
 3286             AlwaysInlineAttr::Keyword_forceinline));
 3334         AlwaysInlineAttr::CreateImplicit(
 3336             AlwaysInlineAttr::Keyword_forceinline));
 3381         AlwaysInlineAttr::CreateImplicit(
 3383             AlwaysInlineAttr::Keyword_forceinline));
 3468         AlwaysInlineAttr::CreateImplicit(
 3470             AlwaysInlineAttr::Keyword_forceinline));
tools/clang/lib/Serialization/ASTWriterDecl.cpp
 2413       if (!FD->hasAttr<AlwaysInlineAttr>()) {
usr/include/c++/7.4.0/type_traits
 1554     { typedef _Tp     type; };
 1558     { typedef _Tp     type; };
 1580     { typedef _Tp const     type; };