File: UnifiedSymbol%2BEncodable.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 (124 lines) | stat: -rw-r--r-- 4,420 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
121
122
123
124
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2022 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
*/

import Foundation

extension UnifiedSymbolGraph.Symbol: Encodable {
    enum CodingKeys: String, CaseIterable, CodingKey {
        // Base
        case uniqueIdentifier
        case mainGraphSelectors
        case modules
        case kind
        case pathComponents
        case type
        case names
        case docComment
        case accessLevel
        case mixins
    }

    private struct EncodableModule: Encodable {
        var selector: UnifiedSymbolGraph.Selector
        var module: SymbolGraph.Module
    }

    private struct EncodableKind: Encodable {
        var selector: UnifiedSymbolGraph.Selector
        var kind: SymbolGraph.Symbol.Kind
    }

    private struct EncodablePathComponents: Encodable {
        var selector: UnifiedSymbolGraph.Selector
        var pathComponents: [String]
    }

    private struct EncodableNames: Encodable {
        var selector: UnifiedSymbolGraph.Selector
        var names: SymbolGraph.Symbol.Names
    }

    private struct EncodableDocComment: Encodable {
        var selector: UnifiedSymbolGraph.Selector
        var docComment: SymbolGraph.LineList
    }

    private struct EncodableAccessLevel: Encodable {
        var selector: UnifiedSymbolGraph.Selector
        var accessLevel: SymbolGraph.Symbol.AccessControl
    }

    private struct EncodableMixins: Encodable {
        var selector: UnifiedSymbolGraph.Selector
        var mixins: [String: Mixin]

        func encode(to encoder: Encoder) throws {
            // To keep Symbol's flexibility when coding Mixins, we use
            // Symbol's CodingKeys.
            var container = encoder.container(keyedBy: SymbolGraph.Symbol.CodingKeys.self)

            try container.encode(selector, forKey: SymbolGraph.Symbol.CodingKeys(rawValue: "selector"))

            // This is copied from SymbolGraph.Symbol's encoding method
            for (key, mixin) in mixins {
                guard let info = SymbolGraph.Symbol.CodingKeys.mixinCodingInfo[key] ?? encoder.registeredSymbolMixins?[key] else {
                    continue
                }
                
                try info.encode(mixin, &container)
            }
        }
    }

    public func encode(to encoder: Encoder) throws {
        var container = encoder.container(keyedBy: CodingKeys.self)

        // Base

        try container.encode(uniqueIdentifier, forKey: .uniqueIdentifier)
        try container.encode(mainGraphSelectors, forKey: .mainGraphSelectors)
        try container.encodeIfPresent(type, forKey: .type)

        let encodedModules = modules.map({ EncodableModule(selector: $0.key, module: $0.value) })
        if !encodedModules.isEmpty {
            try container.encode(encodedModules, forKey: .modules)
        }

        let encodedKinds = kind.map({ EncodableKind(selector: $0.key, kind: $0.value) })
        if !encodedKinds.isEmpty {
            try container.encode(encodedKinds, forKey: .kind)
        }

        let encodedPathComponents = pathComponents.map({ EncodablePathComponents(selector: $0.key, pathComponents: $0.value) })
        if !encodedPathComponents.isEmpty {
            try container.encode(encodedPathComponents, forKey: .pathComponents)
        }

        let encodedNames = names.map({ EncodableNames(selector: $0.key, names: $0.value) })
        if !encodedNames.isEmpty {
            try container.encode(encodedNames, forKey: .names)
        }

        let encodedDocComments = docComment.map({ EncodableDocComment(selector: $0.key, docComment: $0.value) })
        if !encodedDocComments.isEmpty {
            try container.encode(encodedDocComments, forKey: .docComment)
        }

        let encodedAccessLevels = accessLevel.map({ EncodableAccessLevel(selector: $0.key, accessLevel: $0.value) })
        if !encodedAccessLevels.isEmpty {
            try container.encode(encodedAccessLevels, forKey: .accessLevel)
        }

        let encodedMixins = mixins.map({ EncodableMixins(selector: $0.key, mixins: $0.value) })
        if !encodedMixins.isEmpty {
            try container.encode(encodedMixins, forKey: .mixins)
        }
    }
}