File: protocol-extension-default-arg-existential.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (39 lines) | stat: -rw-r--r-- 1,275 bytes parent folder | download
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
// RUN: %target-swift-frontend -emit-sil -verify %s

//
// Make sure neither rdar://problem/37031037 (default arguments on protocol extension methods
// depend on Self and normally get evaluated before an existential self value
// gets opened) nor rdar://problem/39524104 (if you open the existential self
// earlier in an attempt to fix this, then you get undesirable exclusivity
// conflicts on constructs like `existential.x = existential.y`) regress.
//

protocol MethodWithDefaultArgGenerator {
  var a: Int { get set }
  var b: Int { get nonmutating set }

  mutating func mutate(_ x: inout Int)
}

protocol P { static var value: Self { get } }
extension Int: P { static var value: Int { return 0 } }

extension MethodWithDefaultArgGenerator {
  mutating func foo(_ x: Int = 0) {}

  mutating func reabstracted<T>(_ x: T.Type = T.self) -> T { fatalError() }
  mutating func indirected<T: P>(_ x: T = T.value) -> T { fatalError() }

  mutating func exploded(x y: (Int, String) = (0, "foo")) {}
}
func invokeMethodsWithDefaultArgs(x: inout MethodWithDefaultArgGenerator) {
  x.foo()
  _ = x.reabstracted() as Int
  _ = x.indirected() as Int
  x.exploded()
}
func checkAgainstExclusivityViolations(x: inout MethodWithDefaultArgGenerator) {
  x.a = x.a
  x.mutate(&x.b)
}