[cfe-commits] r94473 - in /cfe/trunk/lib/CodeGen: CGDebugInfo.cpp CGDebugInfo.h

Devang Patel dpatel at apple.com
Mon Jan 25 15:32:18 PST 2010


Author: dpatel
Date: Mon Jan 25 17:32:18 2010
New Revision: 94473

URL: http://llvm.org/viewvc/llvm-project?rev=94473&view=rev
Log:
First cut at emitting inheritance info.

Modified:
    cfe/trunk/lib/CodeGen/CGDebugInfo.cpp
    cfe/trunk/lib/CodeGen/CGDebugInfo.h

Modified: cfe/trunk/lib/CodeGen/CGDebugInfo.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGDebugInfo.cpp?rev=94473&r1=94472&r2=94473&view=diff

==============================================================================
--- cfe/trunk/lib/CodeGen/CGDebugInfo.cpp (original)
+++ cfe/trunk/lib/CodeGen/CGDebugInfo.cpp Mon Jan 25 17:32:18 2010
@@ -586,6 +586,40 @@
   }
 }                                 
 
+/// CollectCXXBases - A helper function to collect debug info for
+/// C++ base classes. This is used while creating debug info entry for 
+/// a Record.
+void CGDebugInfo::
+CollectCXXBases(const CXXRecordDecl *Decl,
+                llvm::DICompileUnit Unit,
+                llvm::SmallVectorImpl<llvm::DIDescriptor> &EltTys,
+                llvm::DICompositeType &RecordTy) {
+
+    const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(Decl);
+    for (CXXRecordDecl::base_class_const_iterator BI = Decl->bases_begin(),
+           BE = Decl->bases_end(); BI != BE; ++BI) {
+      unsigned BFlags = 0;
+      if (BI->isVirtual())
+        BFlags = llvm::DIType::FlagVirtual;
+      AccessSpecifier Access = BI->getAccessSpecifier();
+      if (Access == clang::AS_private)
+        BFlags |= llvm::DIType::FlagPrivate;
+      else if (Access == clang::AS_protected)
+        BFlags |= llvm::DIType::FlagProtected;
+
+      const CXXRecordDecl *Base =
+        cast<CXXRecordDecl>(BI->getType()->getAs<RecordType>()->getDecl());
+      llvm::DIType DTy =
+        DebugFactory.CreateDerivedType(llvm::dwarf::DW_TAG_inheritance,
+                                       RecordTy, llvm::StringRef(), 
+                                       llvm::DICompileUnit(), 0, 0, 0,
+                                       RL.getBaseClassOffset(Base), BFlags,
+                                       getOrCreateType(BI->getType(),
+                                                       Unit));
+      EltTys.push_back(DTy);
+    }
+}
+
 /// CreateType - get structure or union type.
 llvm::DIType CGDebugInfo::CreateType(const RecordType *Ty,
                                      llvm::DICompileUnit Unit) {
@@ -643,8 +677,10 @@
   llvm::SmallVector<llvm::DIDescriptor, 16> EltTys;
 
   CollectRecordFields(Decl, Unit, EltTys);
-  if (CXXRecordDecl *CXXDecl = dyn_cast<CXXRecordDecl>(Decl))
+  if (CXXRecordDecl *CXXDecl = dyn_cast<CXXRecordDecl>(Decl)) {
     CollectCXXMemberFunctions(CXXDecl, Unit, EltTys, FwdDecl);
+    CollectCXXBases(CXXDecl, Unit, EltTys, FwdDecl);
+  }
 
   llvm::DIArray Elements =
     DebugFactory.GetOrCreateArray(EltTys.data(), EltTys.size());

Modified: cfe/trunk/lib/CodeGen/CGDebugInfo.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGDebugInfo.h?rev=94473&r1=94472&r2=94473&view=diff

==============================================================================
--- cfe/trunk/lib/CodeGen/CGDebugInfo.h (original)
+++ cfe/trunk/lib/CodeGen/CGDebugInfo.h Mon Jan 25 17:32:18 2010
@@ -91,6 +91,12 @@
                                  llvm::DICompileUnit U,
                                  llvm::SmallVectorImpl<llvm::DIDescriptor> &E,
                                  llvm::DICompositeType &T);
+  void CollectCXXBases(const CXXRecordDecl *Decl,
+                       llvm::DICompileUnit Unit,
+                       llvm::SmallVectorImpl<llvm::DIDescriptor> &EltTys,
+                       llvm::DICompositeType &RecordTy);
+
+
   void CollectRecordFields(const RecordDecl *Decl, llvm::DICompileUnit U,
                            llvm::SmallVectorImpl<llvm::DIDescriptor> &E);
 public:





More information about the cfe-commits mailing list