blob: 19d476fc294f16ab269c01c6f233328161f2ccc3 [file] [log] [blame]
Daniel Dunbard7d5f022009-03-24 02:24:46 +00001// RUN: clang-cc -fsyntax-only %s -verify -fblocks
Steve Naroff61f40a22008-09-10 19:17:48 +00002
3void I( void (^)(void));
4void (^noop)(void);
5
6void nothing();
7int printf(const char*, ...);
8
9typedef void (^T) (void);
10
11void takeclosure(T);
12int takeintint(int (^C)(int)) { return C(4); }
13
14T somefunction() {
15 if (^{ })
16 nothing();
17
18 noop = ^{};
19
20 noop = ^{printf("\nClosure\n"); };
21
22 I(^{ });
23
Mike Stump397195b2009-04-17 00:09:41 +000024 return ^{printf("\nClosure\n"); };
Steve Naroff61f40a22008-09-10 19:17:48 +000025}
26void test2() {
27 int x = 4;
28
29 takeclosure(^{ printf("%d\n", x); });
30
31 while (1) {
32 takeclosure(^{
33 break; // expected-error {{'break' statement not in loop or switch statement}}
34 continue; // expected-error {{'continue' statement not in loop statement}}
35 while(1) break; // ok
36 goto foo; // expected-error {{goto not allowed}}
37 });
38 break;
39 }
40
41foo:
Eli Friedman04831aa2009-03-22 23:26:56 +000042 takeclosure(^{ x = 4; }); // expected-error {{variable is not assignable (missing __block type specifier)}}
Chris Lattner3f84ad22009-04-22 05:27:59 +000043 __block y = 7; // expected-warning {{type specifier missing, defaults to 'int'}}
Steve Naroff4f6a7d72008-09-26 14:41:28 +000044 takeclosure(^{ y = 8; });
Steve Naroff61f40a22008-09-10 19:17:48 +000045}
46
47
48void (^test3())(void) {
Mike Stump397195b2009-04-17 00:09:41 +000049 return ^{};
Steve Naroff61f40a22008-09-10 19:17:48 +000050}
51
52void test4() {
53 void (^noop)(void) = ^{};
54 void (*noop2)() = 0;
55}
56
Steve Naroff4f6a7d72008-09-26 14:41:28 +000057void myfunc(int (^block)(int)) {}
58
Eli Friedman5fdeae12009-03-22 23:00:19 +000059void myfunc3(const int *x);
Steve Naroff4f6a7d72008-09-26 14:41:28 +000060
61void test5() {
62 int a;
63
64 myfunc(^(int abcd) {
65 myfunc3(&a);
66 return 1;
67 });
68}
69
Steve Naroff61f40a22008-09-10 19:17:48 +000070void *X;
71
72void test_arguments() {
Steve Naroff61f40a22008-09-10 19:17:48 +000073 int y;
Steve Naroff61f40a22008-09-10 19:17:48 +000074 int (^c)(char);
75 (1 ? c : 0)('x');
76 (1 ? 0 : c)('x');
77
78 (1 ? c : c)('x');
79}
80
Steve Naroff8af6a452008-10-02 17:12:56 +000081static int global_x = 10;
82void (^global_block)(void) = ^{ printf("global x is %d\n", global_x); };
83
Steve Naroff3aaa4822009-04-16 19:02:57 +000084typedef void (^void_block_t)(void);
85
86static const void_block_t myBlock = ^{ };
87
88static const void_block_t myBlock2 = ^ void(void) { };
89
Steve Naroff61f40a22008-09-10 19:17:48 +000090#if 0
91// Old syntax. FIXME: convert/test.
92void test_byref() {
93 int i;
94
Chris Lattner966f0992008-11-21 01:05:04 +000095 X = ^{| g |}; // error {{use of undeclared identifier 'g'}}
Steve Naroff61f40a22008-09-10 19:17:48 +000096
97 X = ^{| i,i,i | };
98
99 X = ^{|i| i = 0; };
100
101}
102
103// TODO: global closures someday.
104void *A = ^{};
105void *B = ^(int){ A = 0; };
106
107
108// Closures can not take return types at this point.
109void test_retvals() {
110 // Explicit return value.
Chris Lattner966f0992008-11-21 01:05:04 +0000111 ^int{}; // error {{closure with explicit return type requires argument list}}
Steve Naroff61f40a22008-09-10 19:17:48 +0000112 X = ^void(){};
113
114 // Optional specification of return type.
Chris Lattner966f0992008-11-21 01:05:04 +0000115 X = ^char{ return 'x'; }; // error {{closure with explicit return type requires argument list}}
Steve Naroff61f40a22008-09-10 19:17:48 +0000116
117 X = ^/*missing declspec*/ *() { return (void*)0; };
118 X = ^void*() { return (void*)0; };
119
120 //X = ^char(short c){ if (c) return c; else return (int)4; };
121
122}
123
124#endif