File: Sequence%2BCategorize.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 (36 lines) | stat: -rw-r--r-- 1,778 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
/*
 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
*/

extension Sequence {
    /// Splits a sequence into a list of matching elements and a list of non-matching elements.
    ///
    /// - Parameter matches: A closure that takes an element of the sequence as its argument and returns a `Result` value indicating whether the element should be included in the matching list.
    /// - Returns: A pair of the matching elements and the remaining elements, that didn't match.
    func categorize<Result>(where matches: (Element) -> Result?) -> (matching: [Result], remainder: [Element]) {
        var matching = [Result]()
        var remainder = [Element]()
        for element in self {
            if let matchingResult = matches(element) {
                matching.append(matchingResult)
            } else {
                remainder.append(element)
            }
        }
        return (matching, remainder)
    }

    /// Splits a sequence into a list of elements that satisfy a given predicate and a list of those that don't.
    ///
    /// - Parameter isIncluded: A closure that takes an element of the sequence as its argument and returns a Boolean value indicating whether the element should be included in the matching list.
    /// - Returns: A path of the elements that satisfied the predicate and those that didn't.
    func categorize(where isIncluded: (Element) -> Bool) -> (matching: [Element], remainder: [Element]) {
        return (filter(isIncluded), filter { !isIncluded($0) })
    }
}