The ivar ref would be transformed by the Typo Correction TreeTransform, but not
be owned, resulting in the source location being invalid. This would eventually
lead to an assertion in findCapturingExpr. Prevent this assertion from
triggering.
Resolves PR25113.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@260017
91177308-0d34-0410-b5e6-
96231b3b80d8
return Owned(E);
}
+ ExprResult TransformObjCIvarRefExpr(ObjCIvarRefExpr *E) {
+ return Owned(E);
+ }
+
ExprResult Transform(Expr *E) {
ExprResult Res;
while (true) {
typedef unsigned long NSUInteger;
+id nameless; // expected-note{{'nameless' declared here}}
+
@interface NSArray
- (instancetype)initWithObjects:(const id[])objects count:(NSUInteger)count;
@end
@interface I
@property NSArray *array;
+- (id)getArrayById:(id)name;
+- (void)setArrayValue:(id)array;
@end
@interface J
- (void)setArray:(id)array;
+- (void)setIvarArray;
@end
@implementation J {
- (void)setArray:(id)array { // expected-note{{'array' declared here}}
i.array = aray; // expected-error{{use of undeclared identifier 'aray'; did you mean 'array'}}
}
+- (void)setIvarArray {
+ [i setArrayValue:[i getArrayById:nameles]]; // expected-error{{use of undeclared identifier 'nameles'; did you mean 'nameless'}}
+}
@end