mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
The patch introduces a new setting instead of changing existing settings because the generated interfaces in the IDE have slightly different requirements; the extended type there is unconditionally not printed qualified (even if it is ambiguous). This is likely because the ambiguity heuristic is very weak; it doesn't even do name lookup. Simplifying that logic would be nice, but then we'd need to update a bunch of IDE/print* tests and end up with more more visual clutter in the IDE. Introducing the new setting means we can change the behavior for swiftinterface files without affecting the behavior for IDE interfaces. Fixes rdar://79093752.
29 lines
1.5 KiB
Swift
29 lines
1.5 KiB
Swift
// RUN: %empty-directory(%t)
|
|
// RUN: %empty-directory(%t/modulecache)
|
|
|
|
// 1) Build .swiftinterface files for MyPoint and MyExtensions, using a non-default module cache path
|
|
// RUN: %target-swift-frontend -emit-module-interface-path %t/MyPointModule.swiftinterface -module-name MyPointModule -emit-module -o /dev/null %S/Inputs/parseable-interface/MyPoint.swift
|
|
// RUN: %target-swift-frontend -emit-module-interface-path %t/MyPointExtensions.swiftinterface -module-name MyPointExtensions -emit-module -o /dev/null -module-cache-path %t/modulecache -I %t %S/Inputs/parseable-interface/MyPointExtensions.swift
|
|
// RUN: %empty-directory(%t/modulecache)
|
|
|
|
// 2) Check completion using the default (cold) module cache
|
|
// RUN: %target-swift-ide-test -code-completion -code-completion-token=MEMBER -source-filename %s -I %t | %FileCheck %s
|
|
|
|
// 3) Check completion again with a warm module cache
|
|
// RUN: %target-swift-ide-test -code-completion -code-completion-token=MEMBER -source-filename %s -I %t | %FileCheck %s
|
|
|
|
import MyPointModule
|
|
import MyPointExtensions
|
|
|
|
let x = MyPoint(x: 1, y: 10.5)
|
|
|
|
print(x.#^MEMBER^#)
|
|
|
|
// CHECK: Begin completions, 5 items
|
|
// CHECK: Keyword[self]/CurrNominal: self[#MyPoint#]; name=self
|
|
// CHECK: Decl[InstanceVar]/CurrNominal: x[#Double#]; name=x
|
|
// CHECK: Decl[InstanceVar]/CurrNominal: y[#Double#]; name=y
|
|
// CHECK: Decl[InstanceVar]/CurrNominal: magnitudeSquared[#Double#]; name=magnitudeSquared
|
|
// CHECK: Decl[InstanceVar]/CurrNominal: magnitude[#Double#]; name=magnitude
|
|
// CHECK: End completions
|