File: RenderNodeTransformationComposition.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 (50 lines) | stat: -rw-r--r-- 2,512 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
/*
 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 transformation that applies two transformations, one after the other.
public struct RenderNodeTransformationComposition: RenderNodeTransforming {
    /// The first transformation to apply.
    public var first: RenderNodeTransforming
    /// The second transformation to apply.
    public var second: RenderNodeTransforming
    
    /// Initializes a transformation that applies two transformations, one after the other.
    ///
    /// - Parameters:
    ///   - first: The first transformation to apply.
    ///   - second: The second transformation to apply.
    public init(first: RenderNodeTransforming, second: RenderNodeTransforming) {
        self.first = first
        self.second = second
    }
    
    /// Applies the two transformations, in sequence, to a given render node.
    ///
    /// The composed transformation passes the output from the first transformation as the input to the second transformation.
    ///
    ///     ┌─────────────────────────────┐
    ///     │  ┌────────┐     ┌────────┐  │
    ///   ──┼─▶│        │────▶│        │──┼─▶
    ///     │  │ First  │     │ Second │  │
    ///   ──┼─▶│        │────▶│        │──┼─▶
    ///     │  └────────┘     └────────┘  │
    ///     └─────────────────────────────┘
    ///
    /// - Parameters:
    ///   - renderNode: The node to transform.
    ///   - context: The context in which the composed transformation transforms the node.
    /// - Returns: The transformed node, and a possibly modified context that's passed through both transformers.
    public func transform(renderNode: RenderNode, context: RenderNodeTransformationContext)
        -> RenderNodeTransformationResult {
        return [first, second].reduce((renderNode: renderNode, context: context)) { result, transformation in
            transformation.transform(renderNode: result.renderNode, context: result.context)
        }
    }
}