File: DirectAndTransitiveCollections.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 (97 lines) | stat: -rw-r--r-- 3,726 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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
//===------------------ DirectAndTransitiveCollections.swift --------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2020 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//

// Use the type system to ensure that dependencies are transitively closed
// without doing too much work at the leaves of the call tree

public struct Transitively {}
public struct Directly {}

public struct InvalidatedSet<ClosureLevel, Element: Hashable>: Sequence {
  var contents: Set<Element>

  @_spi(Testing) public init(_ s: Set<Element> = Set()) {
    self.contents = s
  }
  init<Elements: Sequence>(_ elements: Elements)
  where Elements.Element == Element
  {
    self.init(Set(elements))
  }
  mutating func insert(_ e: Element) {
    contents.insert(e)
  }
  mutating func formUnion<Elements: Sequence>(_ elements: Elements)
  where Elements.Element == Element{
    contents.formUnion(elements)
  }
  public func makeIterator() -> Set<Element>.Iterator {
    contents.makeIterator()
  }
  public func map<R>(_ transform: (Element) -> R) -> InvalidatedArray<ClosureLevel, R> {
    InvalidatedArray(contents.map(transform))
  }
  public func compactMap<R>(_ transform: (Element) -> R? ) -> InvalidatedArray<ClosureLevel, R> {
    InvalidatedArray(contents.compactMap(transform))
  }
  public func filter(_ isIncluded: (Element) -> Bool) -> InvalidatedArray<ClosureLevel, Element> {
    InvalidatedArray(contents.filter(isIncluded))
  }
}

extension InvalidatedSet where Element: Comparable {
  func sorted() -> InvalidatedArray<ClosureLevel, Element> {
    sorted(by: <)
  }
}
extension InvalidatedSet {
  func sorted(by areInIncreasingOrder: (Element, Element) -> Bool
  ) -> InvalidatedArray<ClosureLevel, Element>  {
    InvalidatedArray(contents.sorted(by: areInIncreasingOrder))
  }
}

public struct InvalidatedArray<ClosureLevel, Element>: Sequence {
  var contents: [Element]

  init(_ s: [Element] = []) {
    self.contents = s
  }
  init<Elements: Sequence>(_ elements: Elements)
  where Elements.Element == Element
  {
    self.init(Array(elements))
  }
  public func makeIterator() -> Array<Element>.Iterator {
    contents.makeIterator()
  }
  public mutating func append(_ e: Element) {
    contents.append(e)
  }
  public func reduce<R: Hashable>(
    into initialResult: InvalidatedSet<ClosureLevel, R>,
    _ updateAccumulatingResult: (inout Set<R>, Element) -> ()
  ) -> InvalidatedSet<ClosureLevel, R> {
    InvalidatedSet(
      contents.reduce(into: initialResult.contents, updateAccumulatingResult))
  }
  public var count: Int { contents.count }
}

public typealias TransitivelyInvalidatedNodeArray = InvalidatedArray<Transitively, ModuleDependencyGraph.Node>
public typealias TransitivelyInvalidatedSourceSet = InvalidatedSet<Transitively, DependencySource>
public typealias TransitivelyInvalidatedInputArray = InvalidatedArray<Transitively, TypedVirtualPath>
public typealias TransitivelyInvalidatedInputSet = InvalidatedSet<Transitively, TypedVirtualPath>
public typealias TransitivelyInvalidatedSwiftSourceFileArray = InvalidatedArray<Transitively, SwiftSourceFile>
public typealias TransitivelyInvalidatedSwiftSourceFileSet = InvalidatedSet<Transitively, SwiftSourceFile>
public typealias DirectlyInvalidatedNodeArray = InvalidatedArray<Directly, ModuleDependencyGraph.Node>
public typealias DirectlyInvalidatedNodeSet = InvalidatedSet<Directly, ModuleDependencyGraph.Node>