]> granicus.if.org Git - clang/commitdiff
A constructor call should force class's debug info even if -flimit-debug-info is...
authorDevang Patel <dpatel@apple.com>
Tue, 22 Feb 2011 20:55:26 +0000 (20:55 +0000)
committerDevang Patel <dpatel@apple.com>
Tue, 22 Feb 2011 20:55:26 +0000 (20:55 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@126246 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGClass.cpp
test/CodeGenCXX/debug-info-limit.cpp [new file with mode: 0644]

index 8e88beb3cf0dc39b7a55fdf37448d0c9b2814a8a..cd28bbe44db539290d0ce616974abfbd6f0f40fe 100644 (file)
@@ -17,6 +17,7 @@
 #include "clang/AST/EvaluatedExprVisitor.h"
 #include "clang/AST/RecordLayout.h"
 #include "clang/AST/StmtCXX.h"
+#include "clang/Frontend/CodeGenOptions.h"
 
 using namespace clang;
 using namespace CodeGen;
@@ -1140,6 +1141,16 @@ CodeGenFunction::EmitCXXConstructorCall(const CXXConstructorDecl *D,
                                         llvm::Value *This,
                                         CallExpr::const_arg_iterator ArgBeg,
                                         CallExpr::const_arg_iterator ArgEnd) {
+
+  CGDebugInfo *DI = getDebugInfo();
+  if (DI && CGM.getCodeGenOpts().LimitDebugInfo) {
+    // If debug info for this class has been emitted then this is the right time
+    // to do so.
+    const CXXRecordDecl *Parent = D->getParent();
+    DI->getOrCreateRecordType(CGM.getContext().getTypeDeclType(Parent),
+                              Parent->getLocation());
+  }
+
   if (D->isTrivial()) {
     if (ArgBeg == ArgEnd) {
       // Trivial default constructor, no codegen required.
diff --git a/test/CodeGenCXX/debug-info-limit.cpp b/test/CodeGenCXX/debug-info-limit.cpp
new file mode 100644 (file)
index 0000000..75f9271
--- /dev/null
@@ -0,0 +1,14 @@
+// RUN: %clang  -emit-llvm -g -S %s -o - | FileCheck %s
+
+// TAG_member is used to encode debug info for class constructor.
+// CHECK: TAG_member
+class A {
+public:
+  int z;
+};
+
+A *foo () {
+  A *a = new A();
+  return a;
+}
+