]> granicus.if.org Git - clang/commitdiff
[analyzer] Hotfix for RetainCountChecker: assert was too strong.
authorGeorge Karpenkov <ekarpenkov@apple.com>
Fri, 1 Feb 2019 23:06:44 +0000 (23:06 +0000)
committerGeorge Karpenkov <ekarpenkov@apple.com>
Fri, 1 Feb 2019 23:06:44 +0000 (23:06 +0000)
Bridged casts can happen to non-CF objects as well.

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

lib/StaticAnalyzer/Checkers/RetainCountChecker/RetainCountChecker.cpp
test/Analysis/objc-arc.m

index 9d2d8cd82aa6dba9960c9f2050db30ae8ef0282c..cdda327d625000c79ffa46eff5353172339aaa7d 100644 (file)
@@ -187,11 +187,10 @@ void RetainCountChecker::checkPostStmt(const CastExpr *CE,
 
   QualType QT = CE->getType();
   ObjKind K;
-  if (coreFoundation::isCFObjectRef(QT)) {
-    K = ObjKind::CF;
-  } else {
-    assert(cocoa::isCocoaObjectRef(QT));
+  if (QT->isObjCObjectPointerType()) {
     K = ObjKind::ObjC;
+  } else {
+    K = ObjKind::CF;
   }
 
   ArgEffect AE = ArgEffect(IncRef, K);
index c5549fae846433edda68fab51a40ef4c7e7a4e4c..30e4ffcadd9e26900c767f027a1ea874a2535a97 100644 (file)
@@ -239,8 +239,23 @@ extern const CFAllocatorRef kCFAllocatorDefault;
 extern CFTypeRef CFRetain(CFTypeRef cf);
 extern void CFRelease(CFTypeRef cf);
 
+
 void check_bridge_retained_cast() {
     NSString *nsStr = [[NSString alloc] init];
     CFStringRef cfStr = (__bridge_retained CFStringRef)nsStr;
     CFRelease(cfStr); // no-warning
 }
+
+@interface A;
+@end
+
+void check_bridge_to_non_cocoa(CFStringRef s) {
+  A *a = (__bridge_transfer A *) s; // no-crash
+}
+
+struct B;
+
+struct B * check_bridge_to_non_cf() {
+  NSString *s = [[NSString alloc] init];
+  return (__bridge struct B*) s;
+}