mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
[index] Make sure to walk the accessor bodies of local properties Otherwise we'll miss global symbols references. rdar://42301005
48 lines
1.6 KiB
Swift
48 lines
1.6 KiB
Swift
// RUN: %target-swift-ide-test -print-indexed-symbols -source-filename %s | %FileCheck %s
|
|
|
|
protocol P1 {}
|
|
|
|
// CHECK: [[@LINE+1]]:8 | struct/Swift | S1 | [[S1_USR:.*]] | Def
|
|
struct S1 : P1 {}
|
|
|
|
func test(_ o: P1?) {
|
|
switch o {
|
|
// CHECK-NOT: [[@LINE+2]]:17 | enumerator/Swift | some |
|
|
// CHECK: [[@LINE+1]]:17 | struct/Swift | S1 | [[S1_USR]] | Ref
|
|
case let s as S1:
|
|
test(s)
|
|
default:
|
|
test(o)
|
|
}
|
|
}
|
|
|
|
func foo() {} // CHECK: [[@LINE]]:6 | function/Swift | foo() | [[foo_USR:.*]] | Def
|
|
|
|
func test1() { // CHECK: [[@LINE]]:6 | function/Swift | test1() | [[test1_USR:.*]] | Def
|
|
func local_func() {
|
|
// FIXME: Saying that 'test1' is the caller of 'foo' is inaccurate, but we'd need
|
|
// to switch to recording local symbols in order to model this properly.
|
|
foo() // CHECK: [[@LINE]]:5 | function/Swift | foo() | [[foo_USR]] | Ref,Call,RelCall,RelCont | rel: 1
|
|
// CHECK-NEXT: RelCall,RelCont | function/Swift | test1() | [[test1_USR]]
|
|
}
|
|
|
|
var local_prop: Int {
|
|
get {
|
|
foo() // CHECK: [[@LINE]]:7 | function/Swift | foo() | [[foo_USR]] | Ref,Call,RelCall,RelCont | rel: 1
|
|
// CHECK-NEXT: RelCall,RelCont | function/Swift | test1() | [[test1_USR]]
|
|
return 0
|
|
}
|
|
set {
|
|
foo() // CHECK: [[@LINE]]:7 | function/Swift | foo() | [[foo_USR]] | Ref,Call,RelCall,RelCont | rel: 1
|
|
// CHECK-NEXT: RelCall,RelCont | function/Swift | test1() | [[test1_USR]]
|
|
}
|
|
}
|
|
|
|
struct LocalS {
|
|
func meth() {
|
|
foo() // CHECK: [[@LINE]]:7 | function/Swift | foo() | [[foo_USR]] | Ref,Call,RelCall,RelCont | rel: 1
|
|
// CHECK-NEXT: RelCall,RelCont | function/Swift | test1() | [[test1_USR]]
|
|
}
|
|
}
|
|
}
|