File: AlternateDeclarations.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 (58 lines) | stat: -rw-r--r-- 2,309 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
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2023 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 SymbolGraph.Symbol {
    /// A mixin to hold alternate declarations of a symbol.
    ///
    /// This mixin is created while a symbol graph is decoded, to hold ``DeclarationFragments-swift.struct``
    /// for symbols which share the same precise identifier.
    public struct AlternateDeclarations: Mixin, Codable {
        public static let mixinKey = "alternateDeclarations"

        /// Alternate declarations for this symbol.
        public var declarations: [DeclarationFragments]

        public init(declarations: [DeclarationFragments]) {
            self.declarations = declarations
        }

        public init(from decoder: Decoder) throws {
            let container = try decoder.singleValueContainer()
            declarations = try container.decode([DeclarationFragments].self)
        }

        public func encode(to encoder: Encoder) throws {
            var container = encoder.singleValueContainer()
            try container.encode(declarations)
        }
    }

    /// Convenience accessor to fetch alternate declarations for this symbol.
    public var alternateDeclarations: [DeclarationFragments]? {
        (mixins[AlternateDeclarations.mixinKey] as? AlternateDeclarations)?.declarations
    }

    internal mutating func addAlternateDeclaration(_ declaration: DeclarationFragments) {
        if var alternateDeclarations = mixins[AlternateDeclarations.mixinKey] as? AlternateDeclarations {
            alternateDeclarations.declarations.append(declaration)
            mixins[AlternateDeclarations.mixinKey] = alternateDeclarations
        } else {
            mixins[AlternateDeclarations.mixinKey] = AlternateDeclarations(declarations: [declaration])
        }
    }

    internal mutating func addAlternateDeclaration(from symbol: SymbolGraph.Symbol) {
        if let declaration = symbol.mixins[DeclarationFragments.mixinKey] as? DeclarationFragments {
            addAlternateDeclaration(declaration)
        }
    }
}