llvm-project/clang/test/Analysis/ObjCProperties.m
Artem Dergachev 12cbc8cbf0 [analyzer] Fix property access kind detection inside parentheses.
'(self.prop)' produces a surprising AST where ParenExpr
resides inside `PseudoObjectExpr.

This breaks ObjCMethodCall::getMessageKind() which in turn causes us
to perform unnecessary dynamic dispatch bifurcation when evaluating
body-farmed property accessors, which in turn causes us
to explore infeasible paths.
2021-10-14 21:07:19 -07:00

53 lines
1.2 KiB
Objective-C

// RUN: %clang_analyze_cc1 -w %s -verify \
// RUN: -analyzer-checker=core,alpha.core,debug.ExprInspection
#ifdef HEADER // A clever trick to avoid splitting up the test.
@interface NSObject
@end
@interface HeaderClass : NSObject
@property NSObject *prop;
@end
#else
#define HEADER
#include "ObjCProperties.m"
@implementation HeaderClass
- (void)foo {
if ((self.prop)) {
}
// This test tests that no dynamic bifurcation is performed on the property.
// The TRUE/FALSE dilemma correctly arises from eagerly-assume behavior
// inside the if-statement. The dynamic bifurcation at (self.prop) inside
// the if-statement was causing an UNKNOWN to show up as well due to
// extra parentheses being caught inside PseudoObjectExpr.
// This should not be UNKNOWN.
clang_analyzer_eval(self.prop); // expected-warning{{TRUE}}
// expected-warning@-1{{FALSE}}
}
@end
// The point of this test cases is to exercise properties in the static
// analyzer
@interface MyClass {
@private
id _X;
}
- (id)initWithY:(id)Y;
@property(copy, readwrite) id X;
@end
@implementation MyClass
@synthesize X = _X;
- (id)initWithY:(id)Y {
self.X = Y;
return self;
}
@end
#endif