File: VariantContainer.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 (53 lines) | stat: -rw-r--r-- 2,113 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
/*
 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
*/

/// A type that contains variant collections.
///
/// This protocol provides utility APIs for types that contain ``VariantCollection`` values.
public protocol VariantContainer {}

public extension VariantContainer {
    /// Sets the given value, if present, as the default value of the variant collection at the given key path.
    ///
    /// If a variant collection is present, this function updates its default value to the given value. Otherwise, it creates a new variant container with the given
    /// value as its default value.
    mutating func setVariantDefaultValue<Value>(
        _ newValue: Value?,
        keyPath: WritableKeyPath<Self, VariantCollection<Value>?>
    ) {
        if self[keyPath: keyPath] != nil {
            newValue.map { self[keyPath: keyPath]!.defaultValue = $0 }
        } else {
            self[keyPath: keyPath] = newValue.map { VariantCollection<Value>.init(defaultValue: $0) }
        }
    }
    
    /// Returns the default value of the variant collection at the given key path, if present.
    func getVariantDefaultValue<Value>(
        keyPath: WritableKeyPath<Self, VariantCollection<Value>?>
    ) -> Value? {
        self[keyPath: keyPath]?.defaultValue
    }
    
    /// Sets the given value as the default value of the variant collection at the given key path.
    mutating func setVariantDefaultValue<Value>(
        _ newValue: Value,
        keyPath: WritableKeyPath<Self, VariantCollection<Value>>
    ) {
        self[keyPath: keyPath].defaultValue = newValue
    }
    
    /// Returns the default value of the variant collection at the given key path.
    func getVariantDefaultValue<Value>(
        keyPath: WritableKeyPath<Self, VariantCollection<Value>>
    ) -> Value {
        self[keyPath: keyPath].defaultValue
    }
}