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

package info (click to toggle)
swiftlang 6.1.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,791,532 kB
  • sloc: cpp: 9,901,743; ansic: 2,201,431; asm: 1,091,827; python: 308,252; objc: 82,166; f90: 80,126; lisp: 38,358; pascal: 25,559; sh: 20,429; ml: 5,058; perl: 4,745; makefile: 4,484; awk: 3,535; javascript: 3,018; xml: 918; fortran: 664; cs: 573; ruby: 396
file content (39 lines) | stat: -rw-r--r-- 1,275 bytes parent folder | download | duplicates (2)
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)
}