mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-10 01:55:08 +00:00
61c848d254
Following r363007, which reverted r362998, r362996, and r362994, reapply with adjustments for the CRLF differences encountered with Windows. Namely, the `-b` option of `diff` is employed, and the `grep` patterns have `$` replaced with `[[:space:]]*$`. llvm-svn: 363069
22 lines
1.3 KiB
Objective-C
22 lines
1.3 KiB
Objective-C
// RUN: %clang_analyze_cc1 -fblocks -analyzer-checker=core,nullability.NullPassedToNonnull,nullability.NullReturnedFromNonnull,nullability.NullablePassedToNonnull,nullability.NullableReturnedFromNonnull,nullability.NullableDereferenced -analyzer-output=text -verify %s
|
|
// RUN: %clang_analyze_cc1 -fblocks -analyzer-checker=core,nullability.NullPassedToNonnull,nullability.NullReturnedFromNonnull,nullability.NullablePassedToNonnull,nullability.NullableReturnedFromNonnull,nullability.NullableDereferenced -analyzer-output=plist -o %t.plist %s
|
|
// RUN: %normalize_plist <%t.plist | diff -ub %S/Inputs/expected-plists/nullability-notes.m.plist -
|
|
|
|
#include "Inputs/system-header-simulator-for-nullability.h"
|
|
|
|
void takesNonnull(NSObject *_Nonnull y);
|
|
|
|
@interface ClassWithProperties: NSObject
|
|
@property(copy, nullable) NSObject *x; // plist check ensures no control flow piece from here to 'self.x'.
|
|
-(void) method;
|
|
@end;
|
|
@implementation ClassWithProperties
|
|
-(void) method {
|
|
// no-crash
|
|
NSObject *x = self.x; // expected-note{{Nullability 'nullable' is inferred}}
|
|
takesNonnull(x); // expected-warning{{Nullable pointer is passed to a callee that requires a non-null 1st parameter}}
|
|
// expected-note@-1{{Nullable pointer is passed to a callee that requires a non-null 1st parameter}}
|
|
}
|
|
@end
|
|
|