File: TableCellContainer.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 (68 lines) | stat: -rw-r--r-- 2,461 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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/*
 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 container of ``Table/Cell`` elements.
public protocol TableCellContainer: Markup, ExpressibleByArrayLiteral {
    /// Create a row from cells.
    ///
    /// - parameter cells: A sequence of ``Table/Cell`` elements from which to make this row.
    init<Cells: Sequence>(_ cells: Cells) where Cells.Element == Table.Cell
}

// MARK: - Public API

public extension TableCellContainer {
    /// Create a row from one cell.
    ///
    /// - parameter cell: The one cell comprising the row.
    init(_ cell: Table.Cell) {
        self.init(CollectionOfOne(cell))
    }

    /// Create a row from cells.
    ///
    /// - parameter cells: A sequence of ``Table/Cell`` elements from which to make this row.
    init(_ cells: Table.Cell...) {
        self.init(cells)
    }

    init(arrayLiteral elements: Table.Cell...) {
        self.init(elements)
    }

    /// The cells of the row.
    ///
    /// - Precondition: All children of a ``TableCellContainer`` must be a `Table.Cell`.
    var cells: LazyMapSequence<MarkupChildren, Table.Cell> {
        return children.lazy.map { $0 as! Table.Cell }
    }

    /// Replace all cells with a sequence of cells.
    ///
    /// - parameter newCells: A sequence of ``Table/Cell`` elements that will replace all of the cells in this row.
    mutating func setCells<Cells: Sequence>(_ newCells: Cells) where Cells.Element == Table.Cell {
        replaceCellsInRange(0..<childCount, with: newCells)
    }

    /// Replace cells in a range with a sequence of cells.
    mutating func replaceCellsInRange<Cells: Sequence>(_ range: Range<Int>, with incomingCells: Cells) where Cells.Element == Table.Cell {
        var rawChildren = raw.markup.copyChildren()
        rawChildren.replaceSubrange(range, with: incomingCells.map { $0.raw.markup })
        let newRaw = raw.markup.withChildren(rawChildren)
        _data = _data.replacingSelf(newRaw)
    }

    /// Append a cell to the row.
    ///
    /// - parameter cell: The cell to append to the row.
    mutating func appendCell(_ cell: Table.Cell) {
        replaceCellsInRange(childCount..<childCount, with: CollectionOfOne(cell))
    }
}