r215453 - Allow @synchronized to contextually convert a C++ object to an ObjC object pointer.
Jordan Rose
jordan_rose at apple.com
Tue Aug 12 09:20:36 PDT 2014
Author: jrose
Date: Tue Aug 12 11:20:36 2014
New Revision: 215453
URL: http://llvm.org/viewvc/llvm-project?rev=215453&view=rev
Log:
Allow @synchronized to contextually convert a C++ object to an ObjC object pointer.
Patch by Grant Paul!
Added:
cfe/trunk/test/SemaObjCXX/synchronized.mm
Modified:
cfe/trunk/lib/Sema/SemaStmt.cpp
Modified: cfe/trunk/lib/Sema/SemaStmt.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaStmt.cpp?rev=215453&r1=215452&r2=215453&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaStmt.cpp (original)
+++ cfe/trunk/lib/Sema/SemaStmt.cpp Tue Aug 12 11:20:36 2014
@@ -3102,9 +3102,24 @@ Sema::ActOnObjCAtSynchronizedOperand(Sou
if (!type->isDependentType() &&
!type->isObjCObjectPointerType()) {
const PointerType *pointerType = type->getAs<PointerType>();
- if (!pointerType || !pointerType->getPointeeType()->isVoidType())
- return Diag(atLoc, diag::error_objc_synchronized_expects_object)
- << type << operand->getSourceRange();
+ if (!pointerType || !pointerType->getPointeeType()->isVoidType()) {
+ if (getLangOpts().CPlusPlus) {
+ if (RequireCompleteType(atLoc, type,
+ diag::err_incomplete_receiver_type))
+ return Diag(atLoc, diag::error_objc_synchronized_expects_object)
+ << type << operand->getSourceRange();
+
+ ExprResult result = PerformContextuallyConvertToObjCPointer(operand);
+ if (!result.isUsable())
+ return Diag(atLoc, diag::error_objc_synchronized_expects_object)
+ << type << operand->getSourceRange();
+
+ operand = result.get();
+ } else {
+ return Diag(atLoc, diag::error_objc_synchronized_expects_object)
+ << type << operand->getSourceRange();
+ }
+ }
}
// The operand to @synchronized is a full-expression.
Added: cfe/trunk/test/SemaObjCXX/synchronized.mm
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaObjCXX/synchronized.mm?rev=215453&view=auto
==============================================================================
--- cfe/trunk/test/SemaObjCXX/synchronized.mm (added)
+++ cfe/trunk/test/SemaObjCXX/synchronized.mm Tue Aug 12 11:20:36 2014
@@ -0,0 +1,20 @@
+// RUN: %clang_cc1 -fsyntax-only -verify -Wno-objc-root-class %s
+
+ at interface PBXTrackableTaskManager @end
+ at implementation PBXTrackableTaskManager @end
+
+struct x {
+ operator PBXTrackableTaskManager *() const { return 0; }
+} a;
+
+struct y {
+ operator int *() const { return 0; }
+} b;
+
+void test1() {
+ @synchronized (a) {
+ }
+
+ @synchronized (b) { // expected-error {{@synchronized requires an Objective-C object type ('struct y' invalid)}}
+ }
+}
More information about the cfe-commits
mailing list