ExtractionSemicolonPolicy.m
1.37 KB
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
54
55
56
// RUN: clang-refactor extract -selection=test:%s %s -- 2>&1 | grep -v CHECK | FileCheck %s
@interface NSArray
+ (id)arrayWithObjects:(const id [])objects count:(unsigned long)cnt;
@end
void extractStatementNoSemiObjCFor(NSArray *array) {
/*range astmt=->+2:4*/for (id i in array) {
int x = 0;
}
}
// CHECK: 1 'astmt' results:
// CHECK: static void extracted() {
// CHECK-NEXT: for (id i in array) {
// CHECK-NEXT: int x = 0;
// CHECK-NEXT: }{{$}}
// CHECK-NEXT: }{{[[:space:]].*}}
void extractStatementNoSemiSync() {
id lock;
/*range bstmt=->+2:4*/@synchronized(lock) {
int x = 0;
}
}
// CHECK: 1 'bstmt' results:
// CHECK: static void extracted() {
// CHECK-NEXT: @synchronized(lock) {
// CHECK-NEXT: int x = 0;
// CHECK-NEXT: }{{$}}
// CHECK-NEXT: }{{[[:space:]].*}}
void extractStatementNoSemiAutorel() {
/*range cstmt=->+2:4*/@autoreleasepool {
int x = 0;
}
}
// CHECK: 1 'cstmt' results:
// CHECK: static void extracted() {
// CHECK-NEXT: @autoreleasepool {
// CHECK-NEXT: int x = 0;
// CHECK-NEXT: }{{$}}
// CHECK-NEXT: }{{[[:space:]].*}}
void extractStatementNoSemiTryFinalllllly() {
/*range dstmt=->+3:4*/@try {
int x = 0;
} @finally {
}
}
// CHECK: 1 'dstmt' results:
// CHECK: static void extracted() {
// CHECK-NEXT: @try {
// CHECK-NEXT: int x = 0;
// CHECK-NEXT: } @finally {
// CHECK-NEXT: }{{$}}
// CHECK-NEXT: }{{[[:space:]].*}}