summaryrefslogtreecommitdiffstats
path: root/test/SemaObjC/arc-invalid.m
blob: 07b6480c1f9bec904b1210817f29ead898cd93b6 (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
// RUN: %clang_cc1 -fsyntax-only -fobjc-arc -fblocks -Wno-objc-root-class -verify %s

// rdar://problem/10982793
// [p foo] in ARC creates a cleanup.
// The plus is invalid and causes the cleanup to go unbound.
// Don't crash.
@interface A
- (id) foo;
@end
void takeBlock(void (^)(void));
void test0(id p) {
  takeBlock(^{ [p foo] + p; }); // expected-error {{invalid operands to binary expression}}
}

void test1(void) {
  __autoreleasing id p; // expected-note {{'p' declared here}}
  takeBlock(^{ (void) p; }); // expected-error {{cannot capture __autoreleasing variable in a block}}
}

// rdar://17024681
@class WebFrame;
@interface WebView  // expected-note {{previous definition is here}}
- (WebFrame *)mainFrame;
@end

@interface WebView  // expected-error {{duplicate interface definition for class 'WebView'}}
@property (nonatomic, readonly, strong) WebFrame *mainFrame;
@end

@interface UIWebDocumentView
- (WebView *)webView;
@end

@interface UIWebBrowserView : UIWebDocumentView
@end

@interface StoreBanner @end

@implementation StoreBanner
+ (void)readMetaTagContentForUIWebBrowserView:(UIWebBrowserView *)browserView
{
  [[browserView webView] mainFrame];
}
@end