Fix <rdar://problem/6253149> property declaration doesn't declare getter and setter.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56785 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Sema/SemaDeclObjC.cpp b/lib/Sema/SemaDeclObjC.cpp
index 0241655..4e05a13 100644
--- a/lib/Sema/SemaDeclObjC.cpp
+++ b/lib/Sema/SemaDeclObjC.cpp
@@ -874,6 +874,9 @@
}
}
}
+ // Save the size so we can detect if we've added any property methods.
+ unsigned int insMethodsSizePriorToPropAdds = insMethods.size();
+ unsigned int clsMethodsSizePriorToPropAdds = clsMethods.size();
if (ObjCInterfaceDecl *I = dyn_cast<ObjCInterfaceDecl>(ClassDecl)) {
// Compares properties declared in this class to those of its
@@ -925,6 +928,24 @@
}
}
}
+ // Add any synthesized methods to the global pool. This allows us to
+ // handle the following, which is supported by GCC (and part of the design).
+ //
+ // @interface Foo
+ // @property double bar;
+ // @end
+ //
+ // void thisIsUnfortunate() {
+ // id foo;
+ // double bar = [foo bar];
+ // }
+ //
+ if (insMethodsSizePriorToPropAdds < insMethods.size())
+ for (unsigned i = insMethodsSizePriorToPropAdds; i < insMethods.size(); i++)
+ AddInstanceMethodToGlobalPool(insMethods[i]);
+ if (clsMethodsSizePriorToPropAdds < clsMethods.size())
+ for (unsigned i = clsMethodsSizePriorToPropAdds; i < clsMethods.size(); i++)
+ AddFactoryMethodToGlobalPool(clsMethods[i]);
}