aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaExprObjC.cpp
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2008-06-04 19:00:03 +0000
committerFariborz Jahanian <fjahanian@apple.com>2008-06-04 19:00:03 +0000
commit26631704d15e2fe19bae8a22939e0a473407c20d (patch)
tree88dd414e8b67efb168f8179d6f8adc27ccfee87f /lib/Sema/SemaExprObjC.cpp
parent50c5c7241029651d4ff976f840bbca59fa81445f (diff)
Fix a gcc compatibility issue which allows more protocol-qualified id on RHS to be
assigned to less protocol qualified object on LHS. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@51956 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaExprObjC.cpp')
-rw-r--r--lib/Sema/SemaExprObjC.cpp15
1 files changed, 12 insertions, 3 deletions
diff --git a/lib/Sema/SemaExprObjC.cpp b/lib/Sema/SemaExprObjC.cpp
index c9cfc92f4d..108ff3c21e 100644
--- a/lib/Sema/SemaExprObjC.cpp
+++ b/lib/Sema/SemaExprObjC.cpp
@@ -327,13 +327,21 @@ static bool ProtocolCompatibleWithProtocol(ObjCProtocolDecl *lProto,
/// lookupCategory is true).
static bool ClassImplementsProtocol(ObjCProtocolDecl *lProto,
ObjCInterfaceDecl *IDecl,
- bool lookupCategory) {
+ bool lookupCategory,
+ bool RHSIsQualifiedID = false) {
// 1st, look up the class.
ObjCProtocolDecl **protoList = IDecl->getReferencedProtocols();
for (unsigned i = 0; i < IDecl->getNumIntfRefProtocols(); i++) {
if (ProtocolCompatibleWithProtocol(lProto, protoList[i]))
return true;
+ // This is dubious and is added to be compatible with gcc.
+ // In gcc, it is also allowed assigning a protocol-qualified 'id'
+ // type to a LHS object when protocol in qualified LHS is in list
+ // of protocols in the rhs 'id' object. This IMO, should be a bug.
+ else if (RHSIsQualifiedID &&
+ ProtocolCompatibleWithProtocol(protoList[i], lProto))
+ return true;
}
// 2nd, look up the category.
@@ -350,7 +358,8 @@ static bool ClassImplementsProtocol(ObjCProtocolDecl *lProto,
// 3rd, look up the super class(s)
if (IDecl->getSuperClass())
return
- ClassImplementsProtocol(lProto, IDecl->getSuperClass(), lookupCategory);
+ ClassImplementsProtocol(lProto, IDecl->getSuperClass(), lookupCategory,
+ RHSIsQualifiedID);
return false;
}
@@ -481,7 +490,7 @@ bool Sema::ObjCQualifiedIdTypesAreCompatible(QualType lhs, QualType rhs,
ObjCInterfaceDecl *lhsID = IT->getDecl();
for (unsigned j = 0; j < rhsQID->getNumProtocols(); j++) {
ObjCProtocolDecl *rhsProto = rhsQID->getProtocols(j);
- if (!ClassImplementsProtocol(rhsProto, lhsID, compare))
+ if (!ClassImplementsProtocol(rhsProto, lhsID, compare, true))
return false;
}
return true;