| /src/contrib/llvm-project/clang/lib/AST/ |
| H A D | VTTBuilder.cpp | 67 const auto *BaseDecl = in LayoutSecondaryVTTs() local 72 Layout.getBaseClassOffset(BaseDecl); in LayoutSecondaryVTTs() 75 LayoutVTT(BaseSubobject(BaseDecl, BaseOffset), /*BaseIsVirtual=*/false); in LayoutSecondaryVTTs() 93 const auto *BaseDecl = in LayoutSecondaryVirtualPointers() local 103 if (!BaseDecl->isDynamicClass()) in LayoutSecondaryVirtualPointers() 111 if (!VBases.insert(BaseDecl).second) in LayoutSecondaryVirtualPointers() 114 BaseOffset = MostDerivedClassLayout.getVBaseClassOffset(BaseDecl); in LayoutSecondaryVirtualPointers() 120 Layout.getBaseClassOffset(BaseDecl); in LayoutSecondaryVirtualPointers() 123 Layout.getPrimaryBase() == BaseDecl) in LayoutSecondaryVirtualPointers() 133 (BaseDecl->getNumVBases() || BaseDeclIsMorallyVirtual)) { in LayoutSecondaryVirtualPointers() [all …]
|
| H A D | CXXInheritance.cpp | 80 const CXXRecordDecl *BaseDecl = Base->getCanonicalDecl(); in isDerivedFrom() local 82 [BaseDecl](const CXXBaseSpecifier *Specifier, CXXBasePath &Path) { in isDerivedFrom() 84 FindBaseClass(Specifier, Path, BaseDecl); in isDerivedFrom() 101 const CXXRecordDecl *BaseDecl = Base->getCanonicalDecl(); in isVirtuallyDerivedFrom() local 103 [BaseDecl](const CXXBaseSpecifier *Specifier, CXXBasePath &Path) { in isVirtuallyDerivedFrom() 104 return FindVirtualBaseClass(Specifier, Path, BaseDecl); in isVirtuallyDerivedFrom() 522 const CXXRecordDecl *BaseDecl = cast<CXXRecordDecl>(RT->getDecl()); in Collect() local 523 if (!BaseDecl->isPolymorphic()) in Collect() 529 Collect(BaseDecl, false, InVirtualSubobject, Overriders); in Collect() 541 CXXFinalOverriderMap *&MyVirtualOverriders = VirtualOverriders[BaseDecl]; in Collect() [all …]
|
| H A D | RecordLayoutBuilder.cpp | 190 const CXXRecordDecl *BaseDecl = Base.getType()->getAsCXXRecordDecl(); in ComputeEmptySubobjectSizes() local 193 const ASTRecordLayout &Layout = Context.getASTRecordLayout(BaseDecl); in ComputeEmptySubobjectSizes() 194 if (BaseDecl->isEmpty()) { in ComputeEmptySubobjectSizes() 395 const CXXRecordDecl *BaseDecl = Base.getType()->getAsCXXRecordDecl(); in CanPlaceFieldSubobjectAtOffset() local 397 CharUnits BaseOffset = Offset + Layout.getBaseClassOffset(BaseDecl); in CanPlaceFieldSubobjectAtOffset() 398 if (!CanPlaceFieldSubobjectAtOffset(BaseDecl, Class, BaseOffset)) in CanPlaceFieldSubobjectAtOffset() 506 const CXXRecordDecl *BaseDecl = Base.getType()->getAsCXXRecordDecl(); in UpdateEmptyFieldSubobjects() local 508 CharUnits BaseOffset = Offset + Layout.getBaseClassOffset(BaseDecl); in UpdateEmptyFieldSubobjects() 509 UpdateEmptyFieldSubobjects(BaseDecl, Class, BaseOffset, in UpdateEmptyFieldSubobjects() 971 const CXXRecordDecl *BaseDecl = I.getType()->getAsCXXRecordDecl(); in ComputeBaseSubobjectInfo() local [all …]
|
| H A D | VTableBuilder.cpp | 348 const CXXRecordDecl *BaseDecl = B.getType()->getAsCXXRecordDecl(); in ComputeBaseOffsets() local 354 if (SubobjectOffsets.count(std::make_pair(BaseDecl, 0))) in ComputeBaseOffsets() 360 BaseOffset = MostDerivedClassLayout.getVBaseClassOffset(BaseDecl); in ComputeBaseOffsets() 362 LayoutClassLayout.getVBaseClassOffset(BaseDecl); in ComputeBaseOffsets() 365 CharUnits Offset = Layout.getBaseClassOffset(BaseDecl); in ComputeBaseOffsets() 371 ComputeBaseOffsets(BaseSubobject(BaseDecl, BaseOffset), in ComputeBaseOffsets() 384 const CXXRecordDecl *BaseDecl = B.getType()->getAsCXXRecordDecl(); in dump() local 387 if (!BaseDecl->isPolymorphic()) in dump() 392 if (!VisitedVirtualBases.insert(BaseDecl).second) { in dump() 397 BaseOffset = MostDerivedClassLayout.getVBaseClassOffset(BaseDecl); in dump() [all …]
|
| H A D | DeclCXX.cpp | 2144 const auto *BaseDecl = in mayBeAbstract() local 2146 if (BaseDecl->isAbstract()) in mayBeAbstract()
|
| H A D | ExprConstant.cpp | 3157 const CXXRecordDecl *BaseDecl = Base->getType()->getAsCXXRecordDecl(); in HandleLValueBase() local 3160 return HandleLValueDirectBase(Info, E, Obj, DerivedDecl, BaseDecl); in HandleLValueBase() 3174 Obj.getLValueOffset() += Layout.getVBaseClassOffset(BaseDecl); in HandleLValueBase() 3175 Obj.addDecl(Info, E, BaseDecl, /*Virtual*/ true); in HandleLValueBase() 7104 CXXRecordDecl *BaseDecl = BS.getType()->getAsCXXRecordDecl(); in visitRecord() local 7107 Layout.getBaseClassOffset(BaseDecl) + Offset)) in visitRecord() 7371 CXXRecordDecl *BaseDecl = BS.getType()->getAsCXXRecordDecl(); in visit() local 7374 BS.getType(), Layout.getBaseClassOffset(BaseDecl) + Offset); in visit()
|
| /src/contrib/llvm-project/clang/lib/AST/Interp/ |
| H A D | Context.cpp | 276 unsigned Context::collectBaseOffset(const RecordDecl *BaseDecl, in collectBaseOffset() argument 278 assert(BaseDecl); in collectBaseOffset() 280 const auto *FinalDecl = cast<CXXRecordDecl>(BaseDecl); in collectBaseOffset() 290 const auto *BaseDecl = cast<CXXRecordDecl>(B.Decl); in collectBaseOffset() local 292 if (BaseDecl == FinalDecl || BaseDecl->isDerivedFrom(FinalDecl)) { in collectBaseOffset() 295 CurDecl = BaseDecl; in collectBaseOffset()
|
| H A D | MemberPointer.cpp | 48 if (const RecordDecl *BaseDecl = Base.getDeclPtr().getRecord()->getDecl(); in toPointer() local 49 BaseDecl != FieldParent) in toPointer() 50 Offset += Ctx.collectBaseOffset(FieldParent, BaseDecl); in toPointer()
|
| H A D | Context.h | 107 unsigned collectBaseOffset(const RecordDecl *BaseDecl,
|
| H A D | Compiler.cpp | 2605 const auto *BaseDecl = Base.dyn_cast<const ValueDecl *>(); in VisitSourceLocExpr() local 2606 assert(BaseDecl); in VisitSourceLocExpr() 2608 auto *UGCD = cast<UnnamedGlobalConstantDecl>(BaseDecl); in VisitSourceLocExpr() 4751 const auto *BaseDecl = Base->getAsCXXRecordDecl(); in visitFunc() local 4752 assert(BaseDecl); in visitFunc() 4755 assert(R->getVirtualBase(BaseDecl)); in visitFunc() 4756 if (!this->emitGetPtrThisVirtBase(BaseDecl, InitExpr)) in visitFunc() 4762 const Record::Base *B = R->getBase(BaseDecl); in visitFunc() 5289 const CXXRecordDecl *BaseDecl = extractRecordDecl(BaseType); in collectBaseOffset() local 5292 return Ctx.collectBaseOffset(BaseDecl, DerivedDecl); in collectBaseOffset()
|
| /src/contrib/llvm-project/clang/lib/CodeGen/ |
| H A D | CGRecordLayoutBuilder.cpp | 723 const CXXRecordDecl *BaseDecl = Layout.getPrimaryBase(); in accumulateBases() local 725 getStorageType(BaseDecl), BaseDecl)); in accumulateBases() 734 const CXXRecordDecl *BaseDecl = Base.getType()->getAsCXXRecordDecl(); in accumulateBases() local 736 !Context.getASTRecordLayout(BaseDecl).getNonVirtualSize().isZero()) in accumulateBases() 737 Members.push_back(MemberInfo(Layout.getBaseClassOffset(BaseDecl), in accumulateBases() 738 MemberInfo::Base, getStorageType(BaseDecl), BaseDecl)); in accumulateBases() 882 const CXXRecordDecl *BaseDecl = Base.getType()->getAsCXXRecordDecl(); in calculateTailClippingOffset() local 887 if (Context.isNearlyEmpty(BaseDecl) && !hasOwnStorage(RD, BaseDecl)) in calculateTailClippingOffset() 890 Layout.getVBaseClassOffset(BaseDecl)); in calculateTailClippingOffset() 898 const CXXRecordDecl *BaseDecl = Base.getType()->getAsCXXRecordDecl(); in accumulateVBases() local [all …]
|
| H A D | CGClass.cpp | 188 const auto *BaseDecl = in computeNonVirtualBaseClassOffset() local 192 Offset += Layout.getBaseClassOffset(BaseDecl); in computeNonVirtualBaseClassOffset() 194 RD = BaseDecl; in computeNonVirtualBaseClassOffset() 2636 auto *BaseDecl = in getVTablePointers() local 2640 if (!BaseDecl->isDynamicClass()) in getVTablePointers() 2649 if (!VBases.insert(BaseDecl).second) in getVTablePointers() 2655 BaseOffset = Layout.getVBaseClassOffset(BaseDecl); in getVTablePointers() 2661 BaseOffset = Base.getBaseOffset() + Layout.getBaseClassOffset(BaseDecl); in getVTablePointers() 2663 OffsetFromNearestVBase + Layout.getBaseClassOffset(BaseDecl); in getVTablePointers() 2664 BaseDeclIsNonVirtualPrimaryBase = Layout.getPrimaryBase() == BaseDecl; in getVTablePointers() [all …]
|
| H A D | ItaniumCXXABI.cpp | 3813 auto *BaseDecl = in CanUseSingleInheritance() local 3815 if (!BaseDecl->isEmpty() && in CanUseSingleInheritance() 3816 BaseDecl->isDynamicClass() != RD->isDynamicClass()) in CanUseSingleInheritance() 4320 auto *BaseDecl = in ComputeVMIClassTypeInfoFlags() local 4325 if (!Bases.VirtualBases.insert(BaseDecl).second) { in ComputeVMIClassTypeInfoFlags() 4330 if (Bases.NonVirtualBases.count(BaseDecl)) in ComputeVMIClassTypeInfoFlags() 4335 if (!Bases.NonVirtualBases.insert(BaseDecl).second) { in ComputeVMIClassTypeInfoFlags() 4340 if (Bases.VirtualBases.count(BaseDecl)) in ComputeVMIClassTypeInfoFlags() 4346 for (const auto &I : BaseDecl->bases()) in ComputeVMIClassTypeInfoFlags() 4420 auto *BaseDecl = in BuildVMIClassTypeInfo() local [all …]
|
| H A D | MicrosoftCXXABI.cpp | 964 const CXXRecordDecl *BaseDecl = Base.getType()->getAsCXXRecordDecl(); in performBaseAdjustment() local 965 if (Context.getASTRecordLayout(BaseDecl).hasExtendableVFPtr()) { in performBaseAdjustment() 966 PolymorphicBase = BaseDecl; in performBaseAdjustment()
|
| H A D | CGExpr.cpp | 4004 if (const auto *BaseDecl = PointeeType->getAsRecordDecl()) in hasBPFPreserveStaticOffset() local 4005 return hasBPFPreserveStaticOffset(BaseDecl); in hasBPFPreserveStaticOffset()
|
| H A D | CGOpenMPRuntime.cpp | 6841 const ValueDecl *BaseDecl = nullptr, const Expr *MapExpr = nullptr, in generateInfoForComponentList() argument 7191 : BaseDecl; in generateInfoForComponentList()
|
| /src/contrib/llvm-project/clang/lib/StaticAnalyzer/Core/ |
| H A D | Store.cpp | 281 const CXXRecordDecl *BaseDecl = BaseType->getPointeeCXXRecordDecl(); in evalDerivedToBase() local 282 if (!BaseDecl) in evalDerivedToBase() 283 BaseDecl = BaseType->getAsCXXRecordDecl(); in evalDerivedToBase() 284 assert(BaseDecl && "not a C++ object?"); in evalDerivedToBase() 290 if (SR->getSymbol()->getType()->getPointeeCXXRecordDecl() == BaseDecl) in evalDerivedToBase() 297 BaseDecl, cast<SubRegion>(DerivedReg), IsVirtual); in evalDerivedToBase()
|
| /src/contrib/llvm-project/clang/lib/Sema/ |
| H A D | SemaLookup.cpp | 3037 CXXRecordDecl *BaseDecl = cast<CXXRecordDecl>(BaseType->getDecl()); in addAssociatedClassesAndNamespaces() local 3038 if (Result.addClassTransitive(BaseDecl)) { in addAssociatedClassesAndNamespaces() 3040 DeclContext *BaseCtx = BaseDecl->getDeclContext(); in addAssociatedClassesAndNamespaces() 3044 if (BaseDecl->bases_begin() != BaseDecl->bases_end()) in addAssociatedClassesAndNamespaces() 3045 Bases.push_back(BaseDecl); in addAssociatedClassesAndNamespaces()
|
| H A D | SemaDeclCXX.cpp | 2650 auto *BaseDecl = in CheckBaseSpecifier() local 2656 if (BaseDecl) { in CheckBaseSpecifier() 2659 if (BaseDecl->isUnion()) { in CheckBaseSpecifier() 2669 dyn_cast<ClassTemplateSpecializationDecl>(BaseDecl)) { in CheckBaseSpecifier() 2682 BaseDecl = BaseDecl->getDefinition(); in CheckBaseSpecifier() 2683 assert(BaseDecl && "Base type is not incomplete, but has no definition"); in CheckBaseSpecifier() 2688 const auto *BaseCSA = BaseDecl->getAttr<CodeSegAttr>(); in CheckBaseSpecifier() 2694 Diag(BaseDecl->getLocation(), diag::note_base_class_specified_here) in CheckBaseSpecifier() 2695 << BaseDecl; in CheckBaseSpecifier() 2705 if (BaseDecl->hasFlexibleArrayMember()) { in CheckBaseSpecifier() [all …]
|
| H A D | SemaChecking.cpp | 1550 const auto *BaseDecl = in findConstantBaseAndOffset() local 1552 if (!BaseDecl) in findConstantBaseAndOffset() 1555 return {BaseDecl, Result.Val.getLValueOffset()}; in findConstantBaseAndOffset() 1620 auto [BaseDecl, Offset] = findConstantBaseAndOffset(S, Arg); in checkPointerAuthValue() 1624 if (!BaseDecl) in checkPointerAuthValue() 1628 else if (isa<FunctionDecl>(BaseDecl)) in checkPointerAuthValue() 1668 auto [BaseDecl, Offset] = findConstantBaseAndOffset(S, Pointer); in checkPointerAuthValue() 1669 if (!BaseDecl || !isa<VarDecl>(BaseDecl)) in checkPointerAuthValue() 12805 const CXXRecordDecl *BaseDecl = Base->getType()->getAsCXXRecordDecl(); in getDerivedToBaseAlignmentAndOffset() local 12812 Ctx.getASTRecordLayout(BaseDecl).getNonVirtualAlignment(); in getDerivedToBaseAlignmentAndOffset() [all …]
|
| H A D | SemaExprCXX.cpp | 937 CXXRecordDecl *BaseDecl = BS.getType()->getAsCXXRecordDecl(); in collectPublicBases() local 942 NewSubobject = VBases.insert(BaseDecl).second; in collectPublicBases() 947 ++SubobjectsSeen[BaseDecl]; in collectPublicBases() 952 PublicSubobjectsSeen.insert(BaseDecl); in collectPublicBases() 955 collectPublicBases(BaseDecl, SubobjectsSeen, VBases, PublicSubobjectsSeen, in collectPublicBases()
|
| H A D | SemaInit.cpp | 8936 RecordDecl *BaseDecl in Diagnose() local 8939 S.Diag(BaseDecl->getLocation(), diag::note_previous_decl) in Diagnose() 8940 << S.Context.getTagDeclType(BaseDecl); in Diagnose()
|
| /src/contrib/llvm-project/clang/include/clang/ExtractAPI/ |
| H A D | ExtractAPIVisitor.h | 178 if (auto *BaseDecl = BaseSpecifier.getType()->getAsTagDecl()) { in getBases() local 179 Bases.emplace_back(createSymbolReferenceForDecl(*BaseDecl)); in getBases()
|