File: Flatten.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 (75 lines) | stat: -rw-r--r-- 2,205 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
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
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2021 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
//
//===----------------------------------------------------------------------===//

// Takes an unflattened array of scalar ranges and some Equatable property and
// attempts to merge ranges who share the same Equatable property. E.g:
//
//     0x0 ... 0xA  = .control
//     0xB ... 0xB  = .control
//     0xC ... 0x1F = .control
//
//    into:
//
//    0x0 ... 0x1F = .control
public func flatten<T: Equatable>(
  _ unflattened: [(ClosedRange<UInt32>, T)]
) -> [(ClosedRange<UInt32>, T)] {
  var result: [(ClosedRange<UInt32>, T)] = []

  for elt in unflattened.sorted(by: { $0.0.lowerBound < $1.0.lowerBound }) {
    guard !result.isEmpty, result.last!.1 == elt.1 else {
      result.append(elt)
      continue
    }
    
    if elt.0.lowerBound == result.last!.0.upperBound + 1 {
      result[result.count - 1].0 = result.last!.0.lowerBound ... elt.0.upperBound
    } else {
      result.append(elt)
    }
  }

  return result
}

// Takes an unflattened array of scalars and some Equatable property and
// attempts to merge scalars into ranges who share the same Equatable
// property. E.g:
//
//     0x9 = .control
//     0xA = .control
//     0xB = .control
//     0xC = .control
//
//    into:
//
//    0x9 ... 0xC = .control
public func flatten<T: Equatable>(
  _ unflattened: [(UInt32, T)]
) -> [(ClosedRange<UInt32>, T)] {
  var result: [(ClosedRange<UInt32>, T)] = []
  
  for elt in unflattened.sorted(by: { $0.0 < $1.0 }) {
    guard !result.isEmpty, result.last!.1 == elt.1 else {
      result.append((elt.0 ... elt.0, elt.1))
      continue
    }
    
    if elt.0 == result.last!.0.upperBound + 1 {
      result[result.count - 1].0 = result.last!.0.lowerBound ... elt.0
    } else {
      result.append((elt.0 ... elt.0, elt.1))
    }
  }
  
  return result
}