mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
This change makes us treat it exactly as we do 'init'. We don't allow renaming the base name,
and don't fail if the basename doesn't match for calls.
Also:
- explicit init calls/references like `MyType.init(42)` are now reported with
'init' as a keywordBase range, rather than nothing.
- cursor info no longer reports rename as available on init/callAsFunction
calls without arguments, as there's nothing to rename in that case.
- Improved detection of when a referenced function is a call (rather than
reference) across syntactic rename, cursor-info, and indexing.
Resolves rdar://problem/60340429
16 lines
472 B
Swift
16 lines
472 B
Swift
struct Test {
|
|
var base: Int
|
|
/*test:def*/init(base: Int) {}
|
|
}
|
|
|
|
_ = /*test:call*/Test(base: 3)
|
|
_ = Test . /*test:call*/init(base: 3)
|
|
_ = Test . /*test:ref*/init
|
|
_ = Test . /*test:ref*/init(base:)
|
|
|
|
|
|
// RUN: %empty-directory(%t.ranges)
|
|
// RUN: %refactor -find-rename-ranges -source-filename %s -pos="test" -is-function-like -old-name "init(base:)" >> %t.ranges/init.swift.expected
|
|
// RUN: diff -u %S/FindRangeOutputs/init.swift.expected %t.ranges/init.swift.expected
|
|
|