File: assume-super-init-does-not-return-nil.m

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (41 lines) | stat: -rw-r--r-- 806 bytes parent folder | download | duplicates (28)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// RUN: %clang_analyze_cc1 -analyzer-checker=core,osx -verify %s

typedef signed char BOOL;

@protocol NSObject  - (BOOL)isEqual:(id)object; @end
@interface NSObject <NSObject> {}
+(id)alloc;
+(id)new;
-(id)init;
-(id)autorelease;
-(id)copy;
- (Class)class;
-(id)retain;
- (oneway void)release;
@end

@interface Cell : NSObject {
  int x;
}
- (id) init;
- (void)test;
@end

@implementation Cell
- (id) init {
  if ((self = [super init])) {
    return self;
  }
  // Test that this is being analyzed.
  int m;
  m = m + 1; //expected-warning {{The left operand of '+' is a garbage value}}
  return self;
}

// Make sure that we do not propagate the 'nil' check from inlined 'init' to 'test'.
- (void) test {
  Cell *newCell = [[Cell alloc] init];
  newCell->x = 5; // no-warning
  [newCell release];
}
@end