File: VolumeRenderSection.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 (120 lines) | stat: -rw-r--r-- 4,669 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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
 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
*/

/// Represents a volume containing a grouped list of tutorials.
public struct VolumeRenderSection: RenderSection, Equatable {
    public var kind: RenderSectionKind = .volume
    
    /// A group in a volume.
    public struct Chapter: Codable, TextIndexing, Equatable {
        /// The name of the chapter.
        public var name: String?
        /// An abstract describing the chapter.
        public var content: [RenderBlockContent] = []
        /// The (ordered) tutorials in a chapter.
        public var tutorials: [RenderReferenceIdentifier] = []
        
        /// An image for the chapter.
        public var image: RenderReferenceIdentifier?
        
        public var headings: [String] {
            return name.map { [$0] } ?? [] + content.headings
        }

        public func rawIndexableTextContent(references: [String : RenderReference]) -> String {
            return content.rawIndexableTextContent(references: references)
        }

        /// Creates a new chapter with the given name.
        ///
        /// - Parameter name: The name of the chapter.
        public init(name: String?) {
            self.name = name
        }
    }
    
    /// The title of the volume section.
    public var name: String?
    
    /// An image for the volume.
    public var image: RenderReferenceIdentifier?
    
    /// Content that appears under the title of the chapters section.
    public var content: [RenderBlockContent]? = nil
    
    /// The chapters/groups in this section.
    public var chapters: [Chapter] = []
    
    /// Creates a new volume with the given name.
    ///
    /// - Parameter name: The name of the volume.
    public init(name: String?) {
        self.name = name
    }
    
    enum CodingKeys: CodingKey {
        case kind
        case name
        case image
        case content
        case chapters
    }
    
    // Override encode(to:) to explicitly encode 'null' when 'name' is nil, for anonymous volumes.
    public func encode(to encoder: Encoder) throws {
        var container = encoder.container(keyedBy: CodingKeys.self)
        try container.encode(kind, forKey: .kind)
        try container.encode(name, forKey: .name)
        try container.encode(image, forKey: .image)
        try container.encode(content, forKey: .content)
        try container.encode(chapters, forKey: .chapters)
    }
}

// Diffable conformance
extension VolumeRenderSection: RenderJSONDiffable {
    /// Returns the differences between this VolumeRenderSection and the given one.
    func difference(from other: VolumeRenderSection, at path: CodablePath) -> JSONPatchDifferences {
        var diffBuilder = DifferenceBuilder(current: self, other: other, basePath: path)

        diffBuilder.addDifferences(atKeyPath: \.kind, forKey: CodingKeys.kind)
        diffBuilder.addDifferences(atKeyPath: \.name, forKey: CodingKeys.name)
        diffBuilder.addDifferences(atKeyPath: \.image, forKey: CodingKeys.image)
        diffBuilder.addDifferences(atKeyPath: \.content, forKey: CodingKeys.content)
        diffBuilder.addDifferences(atKeyPath: \.chapters, forKey: CodingKeys.chapters)

        return diffBuilder.differences
    }

    /// Returns if this VolumeRenderSection is similar enough to the given one.
    func isSimilar(to other: VolumeRenderSection) -> Bool {
        return self.name == other.name || self.content == other.content
    }
}

// Diffable conformance
extension VolumeRenderSection.Chapter: RenderJSONDiffable {
    /// Returns the differences between this Chapter and the given one.
    func difference(from other: VolumeRenderSection.Chapter, at path: CodablePath) -> JSONPatchDifferences {
        var diffBuilder = DifferenceBuilder(current: self, other: other, basePath: path)

        diffBuilder.addDifferences(atKeyPath: \.name, forKey: CodingKeys.name)
        diffBuilder.addDifferences(atKeyPath: \.content, forKey: CodingKeys.content)
        diffBuilder.addDifferences(atKeyPath: \.tutorials, forKey: CodingKeys.tutorials)
        diffBuilder.addDifferences(atKeyPath: \.image, forKey: CodingKeys.image)

        return diffBuilder.differences
    }

    /// Returns if this Chapter is similar enough to the given one.
    func isSimilar(to other: VolumeRenderSection.Chapter) -> Bool {
        return self.name == other.name || self.content == other.content
    }
}