mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
The type of an outermost property wrapper should be printed together with (inferred) generic arguments because otherwise if a any wrapper in the chain has generic parameters that are not involved in `wrappedValue:` argument it won't be impossible to infer them while type-checking the interface file where it appears. Resolves: rdar://122963120
134 lines
4.9 KiB
Swift
134 lines
4.9 KiB
Swift
// RUN: %empty-directory(%t)
|
|
|
|
// RUN: %target-swift-emit-module-interface(%t/TestResilient.swiftinterface) %s -module-name TestResilient
|
|
// RUN: %target-swift-typecheck-module-from-interface(%t/TestResilient.swiftinterface) -module-name TestResilient
|
|
// RUN: %FileCheck %s < %t/TestResilient.swiftinterface
|
|
|
|
// RUN: %target-swift-frontend -compile-module-from-interface -swift-version 5 %t/TestResilient.swiftinterface -o %t/TestResilient.swiftmodule
|
|
// RUN: %target-swift-frontend -emit-module -o /dev/null -merge-modules -swift-version 5 -emit-module-interface-path - %t/TestResilient.swiftmodule -module-name TestResilient | %FileCheck %s
|
|
|
|
@propertyWrapper
|
|
public struct Wrapper<T> {
|
|
public var wrappedValue: T
|
|
|
|
public init(wrappedValue: T) {
|
|
self.wrappedValue = wrappedValue
|
|
}
|
|
}
|
|
|
|
@propertyWrapper
|
|
public struct WrapperWithInitialValue<T> {
|
|
public var wrappedValue: T
|
|
|
|
public init(initialValue: T) {
|
|
self.wrappedValue = initialValue
|
|
}
|
|
|
|
public init(alternate value: T) {
|
|
self.wrappedValue = value
|
|
}
|
|
|
|
public var projectedValue: Wrapper<T> {
|
|
get { Wrapper(wrappedValue: wrappedValue) }
|
|
set { wrappedValue = newValue.wrappedValue }
|
|
}
|
|
}
|
|
|
|
@propertyWrapper
|
|
public struct ProjectedValueWrapper<T> {
|
|
public var wrappedValue: T
|
|
|
|
public init(wrappedValue: T) {
|
|
self.wrappedValue = wrappedValue
|
|
}
|
|
|
|
public init(projectedValue: Wrapper<T>) {
|
|
self.wrappedValue = projectedValue.wrappedValue
|
|
}
|
|
|
|
public var projectedValue: Wrapper<T> {
|
|
get { Wrapper(wrappedValue: wrappedValue) }
|
|
set { wrappedValue = newValue.wrappedValue }
|
|
}
|
|
}
|
|
|
|
@propertyWrapper public struct HasTwoTypeParameters<Value, Other> {
|
|
public var wrappedValue: Value
|
|
|
|
init(wrappedValue: Value, _ other: Other) {
|
|
fatalError()
|
|
}
|
|
}
|
|
|
|
// CHECK: public struct HasWrappers {
|
|
public struct HasWrappers {
|
|
// CHECK: @TestResilient.Wrapper<Swift.Int> public var x: {{(Swift.)?}}Int {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: set
|
|
// CHECK-NEXT: _modify
|
|
// CHECK-NEXT: }
|
|
@Wrapper public var x: Int
|
|
|
|
// CHECK: @TestResilient.WrapperWithInitialValue<Swift.Int> @_projectedValueProperty($y) public var y: Swift.Int {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: }
|
|
@WrapperWithInitialValue public private(set) var y = 17
|
|
|
|
// CHECK: public var $y: TestResilient.Wrapper<{{(Swift.)?}}Int> {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK: @TestResilient.HasTwoTypeParameters<Swift.Int, Swift.String> public var w1: Swift.Int {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: set
|
|
// CHECK-NEXT: _modify
|
|
// CHECK-NEXT: }
|
|
@HasTwoTypeParameters(wrappedValue: 0, "other") public var w1: Int
|
|
|
|
// CHECK: @TestResilient.HasTwoTypeParameters<Swift.Int, Swift.String> public var w2: Swift.Int {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: set
|
|
// CHECK-NEXT: _modify
|
|
// CHECK-NEXT: }
|
|
@HasTwoTypeParameters("other") public var w2: Int = 0
|
|
|
|
// CHECK: @TestResilient.HasTwoTypeParameters<TestResilient.HasTwoTypeParameters<Swift.Int, Swift.Double>, Swift.String> @TestResilient.HasTwoTypeParameters public var w3: Swift.Int {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: set
|
|
// CHECK-NEXT: _modify
|
|
// CHECK-NEXT: }
|
|
@HasTwoTypeParameters("a") @HasTwoTypeParameters(1.0) public var w3: Int = 0
|
|
|
|
// CHECK: @TestResilient.WrapperWithInitialValue<Swift.Bool> @_projectedValueProperty($z) public var z: Swift.Bool {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: set
|
|
// CHECK-NEXT: _modify
|
|
// CHECK-NEXT: }
|
|
@WrapperWithInitialValue(alternate: false) public var z
|
|
|
|
// CHECK: @TestResilient.HasTwoTypeParameters<TestResilient.Wrapper<Swift.Int>, Swift.String> @TestResilient.Wrapper public var composed: Swift.Int {
|
|
// CHECK-NEXT: get
|
|
// CHECK-NEXT: set
|
|
// CHECK-NEXT: _modify
|
|
// CHECK-NEXT: }
|
|
@HasTwoTypeParameters("other") @Wrapper public var composed: Int = 42
|
|
|
|
// CHECK: public func hasParameterWithImplementationWrapper(x: Swift.Int)
|
|
public func hasParameterWithImplementationWrapper(@Wrapper x: Int) { }
|
|
|
|
// CHECK: public func hasParameterWithImplementationWrapperComposed(x: Swift.Int)
|
|
public func hasParameterWithImplementationWrapperComposed(@Wrapper @ProjectedValueWrapper x: Int) { }
|
|
|
|
// CHECK: @inlinable public func hasParameterWithImplementationWrapperInlinable(@TestResilient.Wrapper x: Swift.Int)
|
|
@inlinable public func hasParameterWithImplementationWrapperInlinable(@Wrapper x: Int) { }
|
|
|
|
// CHECK: @_alwaysEmitIntoClient public func hasParameterWithImplementationWrapperAEIC(@TestResilient.Wrapper x: Swift.Int)
|
|
@_alwaysEmitIntoClient public func hasParameterWithImplementationWrapperAEIC(@Wrapper x: Int) { }
|
|
|
|
// CHECK: public func hasParameterWithAPIWrapper(@TestResilient.ProjectedValueWrapper<Swift.Int> x: Swift.Int)
|
|
public func hasParameterWithAPIWrapper(@ProjectedValueWrapper x: Int) { }
|
|
|
|
// CHECK: public func hasParameterWithAPIWrapperComposed(@TestResilient.ProjectedValueWrapper<TestResilient.Wrapper<Swift.Int>> @TestResilient.Wrapper x: Swift.Int)
|
|
public func hasParameterWithAPIWrapperComposed(@ProjectedValueWrapper @Wrapper x: Int) { }
|
|
}
|