File: RangeReplaceableCollection%2BGroup.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 (31 lines) | stat: -rw-r--r-- 1,263 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
/*
 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 Swift project authors
*/

import Foundation

extension RangeReplaceableCollection {
    /// Groups successive elements as long as check determines that they belong together.
    ///
    /// - Parameter belongsInGroupWithPrevious: A check whether the given element belongs in the same group as the previous element
    /// - Returns: An array of subsequences of elements that belong together.
    func group(asLongAs belongsInGroupWithPrevious: (_ previous: Element, _ current: Element) throws -> Bool) rethrows -> [SubSequence] {
        var result = [SubSequence]()
        
        let indexPairs = zip(indices, indices.dropFirst())
        var splitStart = startIndex
        for (previous, current) in indexPairs where try !belongsInGroupWithPrevious(self[previous], self[current]) {
            result.append(self[splitStart...previous])
            splitStart = current
        }
        result.append(self[splitStart...])
        return result
    }
    
}