Basics
authorDavid Blaikie <dblaikie@gmail.com>
Sat, 2 Feb 2013 00:34:16 +0000 (00:34 +0000)
committerDavid Blaikie <dblaikie@gmail.com>
Sat, 2 Feb 2013 00:34:16 +0000 (00:34 +0000)
llvm-svn: 174246

clang/lib/CodeGen/CGDebugInfo.cpp
clang/lib/CodeGen/CGDebugInfo.h
clang/lib/CodeGen/CGDecl.cpp
clang/lib/CodeGen/CodeGenFunction.cpp

index 5e60bd8f66c64bb666be8f041e8c9a305dd9d026..6d61c52af5f2f8ba018963f4caa52f87c0c18783 100644 (file)
@@ -111,6 +111,9 @@ llvm::DIDescriptor CGDebugInfo::getContextDescriptor(const Decl *Context) {
       return llvm::DIDescriptor(Ty);
     }
   }
+
+  if (!LexicalBlockStack.empty())
+    return llvm::DIDescriptor(LexicalBlockStack.back());
   return TheCU;
 }
 
@@ -2822,6 +2825,12 @@ void CGDebugInfo::EmitGlobalVariable(const ValueDecl *VD,
                                 getStaticDataMemberDeclaration(VD));
 }
 
+void CGDebugInfo::EmitUsingDirectiveDecl(const UsingDirectiveDecl &UD) {
+  SourceLocation Loc = UD.getNamespaceKeyLocation();
+  llvm::DIFile Unit = getOrCreateFile(Loc);
+  DBuilder.createUsingDirective(getContextDescriptor(&UD), Unit, getLineNumber(Loc), getOrCreateNameSpace(UD.getNominatedNamespace()));
+}
+
 /// getOrCreateNamesSpace - Return namespace descriptor for the given
 /// namespace decl.
 llvm::DINameSpace 
index fbbee0b3d2bc65cbf2beb80f7a947a5ad9c4b3c0..bcda906a027228d344cbd9994ea63fb62c73f498 100644 (file)
@@ -34,6 +34,7 @@ namespace clang {
   class ObjCInterfaceDecl;
   class ClassTemplateSpecializationDecl;
   class GlobalDecl;
+  class UsingDirectiveDecl;
 
 namespace CodeGen {
   class CodeGenModule;
@@ -247,6 +248,9 @@ public:
   /// EmitGlobalVariable - Emit global variable's debug info.
   void EmitGlobalVariable(const ValueDecl *VD, llvm::Constant *Init);
 
+  /// \brief Emit a C++ using directive.
+  void EmitUsingDirectiveDecl(const UsingDirectiveDecl &UD);
+
   /// getOrCreateRecordType - Emit record type's standalone debug info. 
   llvm::DIType getOrCreateRecordType(QualType Ty, SourceLocation L);
 
index a43a38360b1e078ae9c634c41ac3dcfa6a8aecd5..75b45cc28be30c197d317a7c0e335b3184e6fd39 100644 (file)
@@ -78,14 +78,18 @@ void CodeGenFunction::EmitDecl(const Decl &D) {
   case Decl::CXXRecord: // struct/union/class X; [C++]
   case Decl::Using:          // using X; [C++]
   case Decl::UsingShadow:
-  case Decl::UsingDirective: // using namespace X; [C++]
   case Decl::NamespaceAlias:
   case Decl::StaticAssert: // static_assert(X, ""); [C++0x]
   case Decl::Label:        // __label__ x;
   case Decl::Import:
     // None of these decls require codegen support.
     return;
-
+  case Decl::UsingDirective: { // using namespace X; [C++]
+    if (CGDebugInfo *DI = getDebugInfo()) {
+      DI->EmitUsingDirectiveDecl(cast<UsingDirectiveDecl>(D));
+    }
+    return;
+  }
   case Decl::Var: {
     const VarDecl &VD = cast<VarDecl>(D);
     assert(VD.isLocalVarDecl() &&
index 729cdba4dee912e4dfba2a44a95dae0c8e0b175c..119b90aa0816cb8a4495ec625e0d328ac0287e04 100644 (file)
@@ -191,6 +191,7 @@ void CodeGenFunction::FinishFunction(SourceLocation EndLoc) {
   // Emit debug descriptor for function end.
   if (CGDebugInfo *DI = getDebugInfo()) {
     DI->EmitFunctionEnd(Builder);
+    DI->setLocation(EndLoc);
   }
 
   EmitFunctionEpilog(*CurFnInfo);