2018-07-28 02:26:40 +08:00
|
|
|
// RUN: %clang_analyze_cc1 -x objective-c -analyzer-checker=core,nullability -analyzer-output=text -Wno-objc-root-class -fblocks -verify %s
|
2018-02-24 07:26:56 +08:00
|
|
|
|
2018-07-28 02:26:40 +08:00
|
|
|
#include "../Inputs/system-header-simulator-for-nullability.h"
|
|
|
|
|
2022-02-12 20:23:43 +08:00
|
|
|
extern int coin(void);
|
2018-07-28 02:26:40 +08:00
|
|
|
|
|
|
|
@interface I : NSObject
|
2018-02-24 07:26:56 +08:00
|
|
|
- (int)initVar:(int *)var param:(int)param;
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation I
|
|
|
|
- (int)initVar:(int *)var param:(int)param {
|
[analyzer] ConditionBRVisitor: Enhance to write out more information
Summary:
Add extra messages to the bug report to inform the user why the analyzer
`Taking true/false branch`.
Reviewers: NoQ, george.karpenkov
Reviewed By: NoQ
Subscribers: gerazo, gsd, dkrupp, whisperity, baloghadamsoftware, xazax.hun,
eraman, szepet, a.sidorin, mikhail.ramalho, Szelethus,
donat.nagy, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D53076
llvm-svn: 362020
2019-05-30 04:06:09 +08:00
|
|
|
if (param) { // expected-note{{'param' is 0}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
2018-02-24 07:26:56 +08:00
|
|
|
*var = 1;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
return 1; // expected-note{{Returning without writing to '*var'}}
|
2019-08-22 11:08:48 +08:00
|
|
|
// expected-note@-1{{Returning the value 1, which participates in a condition later}}
|
2018-02-24 07:26:56 +08:00
|
|
|
}
|
|
|
|
@end
|
|
|
|
|
|
|
|
int foo(I *i) {
|
|
|
|
int x; //expected-note{{'x' declared without an initial value}}
|
|
|
|
int out = [i initVar:&x param:0]; //expected-note{{Calling 'initVar:param:'}}
|
|
|
|
//expected-note@-1{{Returning from 'initVar:param:'}}
|
[analyzer] ConditionBRVisitor: Enhance to write out more information
Summary:
Add extra messages to the bug report to inform the user why the analyzer
`Taking true/false branch`.
Reviewers: NoQ, george.karpenkov
Reviewed By: NoQ
Subscribers: gerazo, gsd, dkrupp, whisperity, baloghadamsoftware, xazax.hun,
eraman, szepet, a.sidorin, mikhail.ramalho, Szelethus,
donat.nagy, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D53076
llvm-svn: 362020
2019-05-30 04:06:09 +08:00
|
|
|
if (out) //expected-note{{'out' is 1}}
|
|
|
|
//expected-note@-1{{Taking true branch}}
|
2018-02-24 07:26:56 +08:00
|
|
|
return x; //expected-warning{{Undefined or garbage value returned to caller}}
|
|
|
|
//expected-note@-1{{Undefined or garbage value returned to caller}}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int initializer1(int *p, int x) {
|
[analyzer] ConditionBRVisitor: Enhance to write out more information
Summary:
Add extra messages to the bug report to inform the user why the analyzer
`Taking true/false branch`.
Reviewers: NoQ, george.karpenkov
Reviewed By: NoQ
Subscribers: gerazo, gsd, dkrupp, whisperity, baloghadamsoftware, xazax.hun,
eraman, szepet, a.sidorin, mikhail.ramalho, Szelethus,
donat.nagy, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D53076
llvm-svn: 362020
2019-05-30 04:06:09 +08:00
|
|
|
if (x) { // expected-note{{'x' is 0}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
2018-02-24 07:26:56 +08:00
|
|
|
*p = 1;
|
|
|
|
return 0;
|
|
|
|
} else {
|
|
|
|
return 1; // expected-note {{Returning without writing to '*p'}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-12 20:23:43 +08:00
|
|
|
int initFromBlock(void) {
|
2018-02-24 07:26:56 +08:00
|
|
|
__block int z;
|
|
|
|
^{ // expected-note {{Calling anonymous block}}
|
|
|
|
int p; // expected-note{{'p' declared without an initial value}}
|
|
|
|
initializer1(&p, 0); // expected-note{{Calling 'initializer1'}}
|
|
|
|
// expected-note@-1{{Returning from 'initializer1'}}
|
|
|
|
z = p; // expected-warning{{Assigned value is garbage or undefined}}
|
|
|
|
// expected-note@-1{{Assigned value is garbage or undefined}}
|
|
|
|
}();
|
|
|
|
return z;
|
|
|
|
}
|
2018-07-28 02:26:40 +08:00
|
|
|
|
|
|
|
extern void expectNonNull(NSString * _Nonnull a);
|
|
|
|
|
|
|
|
@interface A : NSObject
|
|
|
|
- (void) initAMaybe;
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation A {
|
|
|
|
NSString * a;
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) initAMaybe {
|
|
|
|
if (coin()) // expected-note{{Assuming the condition is false}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
a = @"string";
|
|
|
|
} // expected-note{{Returning without writing to 'self->a'}}
|
|
|
|
|
2018-08-02 10:02:40 +08:00
|
|
|
- (void) passNullToNonnull {
|
2018-07-28 02:26:40 +08:00
|
|
|
a = nil; // expected-note{{nil object reference stored to 'a'}}
|
|
|
|
[self initAMaybe]; // expected-note{{Calling 'initAMaybe'}}
|
|
|
|
// expected-note@-1{{Returning from 'initAMaybe'}}
|
|
|
|
expectNonNull(a); // expected-warning{{nil passed to a callee that requires a non-null 1st parameter}}
|
|
|
|
// expected-note@-1{{nil passed to a callee that requires a non-null 1st parameter}}
|
|
|
|
}
|
|
|
|
|
2018-08-02 10:02:40 +08:00
|
|
|
- (void) initAMaybeWithExplicitSelf {
|
|
|
|
if (coin()) // expected-note{{Assuming the condition is false}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
self->a = @"string";
|
|
|
|
} // expected-note{{Returning without writing to 'self->a'}}
|
|
|
|
|
|
|
|
- (void) passNullToNonnullWithExplicitSelf {
|
|
|
|
self->a = nil; // expected-note{{nil object reference stored to 'a'}}
|
|
|
|
[self initAMaybeWithExplicitSelf]; // expected-note{{Calling 'initAMaybeWithExplicitSelf'}}
|
|
|
|
// expected-note@-1{{Returning from 'initAMaybeWithExplicitSelf'}}
|
|
|
|
expectNonNull(a); // expected-warning{{nil passed to a callee that requires a non-null 1st parameter}}
|
|
|
|
// expected-note@-1{{nil passed to a callee that requires a non-null 1st parameter}}
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) initPassedAMaybe:(A *) param {
|
|
|
|
if (coin()) // expected-note{{Assuming the condition is false}}
|
|
|
|
// expected-note@-1{{Taking false branch}}
|
|
|
|
param->a = @"string";
|
|
|
|
} // expected-note{{Returning without writing to 'param->a'}}
|
|
|
|
|
|
|
|
- (void) useInitPassedAMaybe:(A *) paramA {
|
|
|
|
paramA->a = nil; // expected-note{{nil object reference stored to 'a'}}
|
|
|
|
[self initPassedAMaybe:paramA]; // expected-note{{Calling 'initPassedAMaybe:'}}
|
|
|
|
// expected-note@-1{{Returning from 'initPassedAMaybe:'}}
|
|
|
|
expectNonNull(paramA->a); // expected-warning{{nil passed to a callee that requires a non-null 1st parameter}}
|
|
|
|
// expected-note@-1{{nil passed to a callee that requires a non-null 1st parameter}}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-07-28 02:26:40 +08:00
|
|
|
@end
|