From: Fariborz Jahanian Date: Thu, 10 Dec 2009 20:46:08 +0000 (+0000) Subject: Add support for finding composite type of twp objective-c pointers X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5501636b41318a9161d5f2b278e6e2c6a794e4d2;p=clang Add support for finding composite type of twp objective-c pointers in objective-c++ mode. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@91059 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaExprCXX.cpp b/lib/Sema/SemaExprCXX.cpp index 5e0ce666ea..6d991b6a7c 100644 --- a/lib/Sema/SemaExprCXX.cpp +++ b/lib/Sema/SemaExprCXX.cpp @@ -1806,6 +1806,11 @@ QualType Sema::CXXCheckConditionalOperands(Expr *&Cond, Expr *&LHS, Expr *&RHS, QualType Composite = FindCompositePointerType(LHS, RHS); if (!Composite.isNull()) return Composite; + + // Similarly, attempt to find composite type of twp objective-c pointers. + Composite = FindCompositeObjCPointerType(LHS, RHS, QuestionLoc); + if (!Composite.isNull()) + return Composite; // Fourth bullet is same for pointers-to-member. However, the possible // conversions are far more limited: we have null-to-pointer, upcast of diff --git a/test/SemaObjCXX/conditional-expr.mm b/test/SemaObjCXX/conditional-expr.mm new file mode 100644 index 0000000000..ee756dbd34 --- /dev/null +++ b/test/SemaObjCXX/conditional-expr.mm @@ -0,0 +1,67 @@ +// RUN: clang-cc -x objective-c++ -fsyntax-only -verify %s + +@protocol P0 +@end +@protocol P1 +@end +@protocol P2 +@end + +@interface A +@end + +@interface B : A +@end + +void bar(id x); +void barP0(id x); +void barP1(id x); +void barP2(id x); + +void f0(A *a) { + id l = a; +} + +void f1(id x, A *a) { + id l = a; +} + +void f2(id x) { + id l = x; // expected-error {{incompatible type initializing 'id', expected 'id'}} +} + +void f3(A *a) { + id l = a; // expected-error {{incompatible type initializing 'A *', expected 'id'}} +} + +void f4(int cond, id x, A *a) { + bar(cond ? x : a); +} + +void f5(int cond, A *a, B *b) { + bar(cond ? a : b); +} + +void f6(int cond, id x, A *a) { + bar(cond ? (id) x : a); +} + +void f7(int cond, id x, A *a) { + bar(cond ? a : (id) x); +} + +void f8(int cond, id x0, id x1) { + barP0(cond ? x0 : x1); // expected-warning {{incompatible operand types ('id' and 'id')}} +} + +void f9(int cond, id x0, id x1) { + barP1(cond ? x0 : x1); // expected-warning {{incompatible operand types ('id' and 'id')}} +} + +void f10(int cond, id x0, id x1) { + barP2(cond ? x0 : x1); // expected-warning {{incompatible operand types ('id' and 'id')}} +} + +int f11(int cond, A* a, B* b) { + return (cond? b : a)->x; // expected-error{{'A' does not have a member named 'x'}} +}