forked from swiftlang/swift
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcomplete_sequence_rdar75358153.swift
47 lines (40 loc) · 1.16 KB
/
complete_sequence_rdar75358153.swift
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
// BEGIN t1.swift
enum E {
case foo, bar
}
func foo(_ arg: E) {}
func test(val: E) {
foo(.bar)
}
// BEGIN t2.swift
enum E {
case foo, bar
}
func foo(_ arg: E) {}
func test(val: E) {
foo(.bar)
if v
}
// BEGIN dummy.swift
// rdar://75358153
// Previously, completing inside single expression body, then completing inside
// *non* single expression body in the same function caused a crash because the
// "has single expression" flag didn't cleard. This file tests the scenario not
// to regress again.
// RUN: %empty-directory(%t)
// RUN: %{python} %utils/split_file.py -o %t %s
// RUN: %sourcekitd-test \
// RUN: -req=complete -pos=6:8 -text-input %t/t1.swift %t/t.swift -- %t/t.swift == \
// RUN: -req=complete -pos=7:6 -text-input %t/t2.swift %t/t.swift -- %t/t.swift \
// RUN: | %FileCheck %s
// CHECK-LABEL: key.results: [
// CHECK-DAG: key.description: "bar",
// CHECK-DAG: key.description: "foo",
// CHECK-DAG: key.description: "hash(self: E)",
// CHECK: ]
// CHECK-NOT: key.reusingastcontext: 1
// CHECK-LABEL: key.results: [
// CHECK-DAG: key.description: "val",
// CHECK-DAG: key.description: "foo(arg: E)",
// CHECK: ],
// CHECK: key.reusingastcontext: 1