]> granicus.if.org Git - clang/commitdiff
Add support for objc property decls according to the page at:
authorEric Christopher <echristo@apple.com>
Thu, 29 Mar 2012 08:43:37 +0000 (08:43 +0000)
committerEric Christopher <echristo@apple.com>
Thu, 29 Mar 2012 08:43:37 +0000 (08:43 +0000)
    http://llvm.org/docs/SourceLevelDebugging.html#objcproperty

    including type and DECL. Expand the getter and setter names
    into the fully qualified names.

    rdar://11144023

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@153640 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGDebugInfo.cpp
test/CodeGenObjC/debug-info-property3.m

index 90eb861d939fb11678113d6dcaa21d9ec6d415f8..fa26d4706d65d0a0c2a793b9d592d898c2417943 100644 (file)
@@ -165,15 +165,6 @@ StringRef CGDebugInfo::getObjCMethodName(const ObjCMethodDecl *OMD) {
   return StringRef(StrPtr, OS.tell());
 }
 
-/// getSelectorName - Return selector name. This is used for debugging
-/// info.
-StringRef CGDebugInfo::getSelectorName(Selector S) {
-  const std::string &SName = S.getAsString();
-  char *StrPtr = DebugInfoNames.Allocate<char>(SName.size());
-  memcpy(StrPtr, SName.data(), SName.size());
-  return StringRef(StrPtr, SName.size());
-}
-
 /// getClassName - Get class name including template argument list.
 StringRef 
 CGDebugInfo::getClassName(const RecordDecl *RD) {
@@ -1324,11 +1315,18 @@ llvm::DIType CGDebugInfo::CreateType(const ObjCInterfaceType *Ty,
   for (ObjCContainerDecl::prop_iterator I = ID->prop_begin(),
          E = ID->prop_end(); I != E; ++I) {
     const ObjCPropertyDecl *PD = *I;
+    SourceLocation Loc = PD->getLocation();
+    llvm::DIFile PUnit = getOrCreateFile(Loc);
+    unsigned PLine = getLineNumber(Loc);
+    ObjCMethodDecl *GDecl = PD->getGetterMethodDecl();
+    ObjCMethodDecl *SDecl = PD->getSetterMethodDecl();
     llvm::MDNode *PropertyNode =
       DBuilder.createObjCProperty(PD->getName(),
-                                  getSelectorName(PD->getGetterName()),
-                                  getSelectorName(PD->getSetterName()),
-                                  PD->getPropertyAttributes());
+                                 PUnit, PLine,
+                                 GDecl ? getObjCMethodName(GDecl) : "",
+                                 SDecl ? getObjCMethodName(SDecl) : "",
+                                  PD->getPropertyAttributes(),
+                                 getOrCreateType(PD->getType(), PUnit));
     EltTys.push_back(PropertyNode);
   }
 
@@ -1380,11 +1378,18 @@ llvm::DIType CGDebugInfo::CreateType(const ObjCInterfaceType *Ty,
       if (ObjCPropertyImplDecl *PImpD = 
           ImpD->FindPropertyImplIvarDecl(Field->getIdentifier())) {
         if (ObjCPropertyDecl *PD = PImpD->getPropertyDecl()) {
-          PropertyNode =
-            DBuilder.createObjCProperty(PD->getName(),
-                                        getSelectorName(PD->getGetterName()),
-                                        getSelectorName(PD->getSetterName()),
-                                        PD->getPropertyAttributes());
+         SourceLocation Loc = PD->getLocation();
+         llvm::DIFile PUnit = getOrCreateFile(Loc);
+         unsigned PLine = getLineNumber(Loc);
+         ObjCMethodDecl *GDecl = PD->getGetterMethodDecl();
+         ObjCMethodDecl *SDecl = PD->getSetterMethodDecl();
+         PropertyNode =
+           DBuilder.createObjCProperty(PD->getName(),
+                                       PUnit, PLine,
+                                       GDecl ? getObjCMethodName(GDecl) : "",
+                                       SDecl ? getObjCMethodName(SDecl) : "",
+                                       PD->getPropertyAttributes(),
+                                       getOrCreateType(PD->getType(),PUnit));
         }
       }
     }
index 330c8db4cdf8b5fdecf3b1448321cec07a74dd00..804127d8c47fa1e1c5b20d4fa52ef5dfc0a3bb63 100644 (file)
@@ -1,6 +1,6 @@
 // RUN: %clang_cc1 -S -emit-llvm -g %s -o - | FileCheck %s
 
-// CHECK: metadata !"p1", metadata !"p1", metadata !"setP1:", i32 2316} ; [ DW_TAG_APPLE_property ]
+// CHECK: metadata !"p1", metadata !6, i32 5, metadata !"-[I1 p1]", metadata !"-[I1 setP1:]", i32 2316, metadata !9} ; [ DW_TAG_APPLE_property ]
 @interface I1
 @property int p1;
 @end