]> granicus.if.org Git - clang/commitdiff
super and class property reference expressions don't need to be
authorDouglas Gregor <dgregor@apple.com>
Fri, 13 Apr 2012 15:53:08 +0000 (15:53 +0000)
committerDouglas Gregor <dgregor@apple.com>
Fri, 13 Apr 2012 15:53:08 +0000 (15:53 +0000)
rebuilt. Fixes <rdar://problem/11052352>.

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

lib/Sema/SemaPseudoObject.cpp
test/SemaObjCXX/property-reference.mm

index d52c912457a1ca52f15bce0ee5894b8330716ab8..3b2cf8d7350eb3ec83e91ff0ca97e61390116b6f 100644 (file)
@@ -1300,8 +1300,13 @@ static Expr *stripOpaqueValuesFromPseudoObjectRef(Sema &S, Expr *E) {
   Expr *opaqueRef = E->IgnoreParens();
   if (ObjCPropertyRefExpr *refExpr
         = dyn_cast<ObjCPropertyRefExpr>(opaqueRef)) {
-    OpaqueValueExpr *baseOVE = cast<OpaqueValueExpr>(refExpr->getBase());
-    return ObjCPropertyRefRebuilder(S, baseOVE->getSourceExpr()).rebuild(E);
+    if (refExpr->isObjectReceiver()) {
+      OpaqueValueExpr *baseOVE = cast<OpaqueValueExpr>(refExpr->getBase());
+      return ObjCPropertyRefRebuilder(S, baseOVE->getSourceExpr()).rebuild(E);
+    }
+
+    // Neither class or super property references need a rebuild.
+    return E;
   } else if (ObjCSubscriptRefExpr *refExpr
                = dyn_cast<ObjCSubscriptRefExpr>(opaqueRef)) {
     OpaqueValueExpr *baseOVE = cast<OpaqueValueExpr>(refExpr->getBaseExpr());
index 18f06045a340976355ca001cd3e1dd0b301c9e12..b86ae5e9f51ddc3a3974b440f8efe30562563434 100644 (file)
@@ -42,3 +42,18 @@ typedef const TCPPObject& CREF_TCPPObject;
        cppObjectNonAtomic = cppObject;
 }
 @end
+
+
+// <rdar://problem/11052352>
+@interface NSObject
++ alloc;
+- init;
+- class;
+@end
+
+template<typename T> void f() {
+  NSObject *o = [NSObject.alloc init];
+  [o class];
+}
+
+template void f<int>();