summaryrefslogtreecommitdiffstats
path: root/test/SemaObjC/idiomatic-parentheses.m
blob: c6281f0987dec0030217b1cae24c94a38f072813 (plain)
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
42
43
44
45
46
47
48
49
50
51
52
53
// RUN: %clang_cc1 -fsyntax-only -verify -Wparentheses -Wno-objc-root-class %s

// Don't warn about some common ObjC idioms unless we have -Widiomatic-parentheses on.
// <rdar://problem/7382435>

@interface Object 
{
  unsigned uid;
}
- (id) init;
- (id) initWithInt: (int) i;
- (id) myInit __attribute__((objc_method_family(init)));
- (void) iterate: (id) coll;
- (id) nextObject;
@property unsigned uid;
@end

@implementation Object
@synthesize uid;
- (id) init {
  if (self = [self init]) {
  }
  return self;
}

- (id) initWithInt: (int) i {
  if (self = [self initWithInt: i]) {
  }
  // rdar://11066598
  if (self.uid = 100) { // expected-warning {{using the result of an assignment as a condition without parentheses}} \
                        // expected-note {{place parentheses around the assignment to silence this warning}} \
                        // expected-note {{use '==' to turn this assignment into an equality comparison}}
        // ...
  }
  return self;
}

- (id) myInit {
  if (self = [self myInit]) {
  }
  return self;
}

- (void) iterate: (id) coll {
  id cur;
  while (cur = [coll nextObject]) {
  }
}

- (id) nextObject {
  return self;
}
@end