File: UnifiedSymbol%2BExtensions.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 (117 lines) | stat: -rw-r--r-- 4,806 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
/*
 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 SymbolKit

extension UnifiedSymbolGraph.Symbol {
    var defaultSelector: UnifiedSymbolGraph.Selector? {
        // Return the default selector from the main graph selectors, or if one could not be determined, from all
        // the symbol's selectors including ones for extension symbol graphs.
        return defaultSelector(in: mainGraphSelectors) ?? defaultSelector(in: pathComponents.keys)
    }
    
    private func defaultSelector(
        in selectors: some Sequence<UnifiedSymbolGraph.Selector>
    ) -> UnifiedSymbolGraph.Selector? {
        // Return the default selector based on the ordering defined below.
        return selectors.sorted { lhsSelector, rhsSelector in
            switch (lhsSelector.interfaceLanguage, rhsSelector.interfaceLanguage) {
                
            // If both selectors are Swift, pick the one that has the most matching platforms with the other selectors.
            case ("swift", "swift"):
                let nonSwiftSelectors = selectors.filter { $0.interfaceLanguage != "swift" }
                
                let lhsMatchingPlatformsCount = nonSwiftSelectors.filter { $0.platform == lhsSelector.platform }.count
                let rhsMatchingPlatformsCount = nonSwiftSelectors.filter { $0.platform == rhsSelector.platform }.count
                
                if lhsMatchingPlatformsCount == rhsMatchingPlatformsCount {
                    // If they have the same number of matching platforms, return the alphabetically smallest platform.
                    return arePlatformsInIncreasingOrder(lhsSelector.platform, rhsSelector.platform)
                }
                
                return lhsMatchingPlatformsCount > rhsMatchingPlatformsCount
            case ("swift", _):
                return true
            case (_, "swift"):
                return false
            default:
                // Return the alphabetically smallest platform.
                return arePlatformsInIncreasingOrder(lhsSelector.platform, rhsSelector.platform)
            }
        }.first
    }
    
    private func arePlatformsInIncreasingOrder(_ platform1: String?, _ platform2: String?) -> Bool {
        switch (platform1, platform2) {
        case (nil, _):
            return true
        case (_, nil):
            return false
        case (let platform1?, let platform2?):
            return platform1 < platform2
        }
    }

    func symbol(forSelector selector: UnifiedSymbolGraph.Selector?) -> SymbolGraph.Symbol? {
        guard let selector,
              let kind = self.kind[selector],
              let pathComponents = self.pathComponents[selector],
              let names = self.names[selector],
              let accessLevel = self.accessLevel[selector],
              let mixins = self.mixins[selector] else {
            return nil
        }

        return SymbolGraph.Symbol(
            identifier: SymbolGraph.Symbol.Identifier(
                precise: self.uniqueIdentifier,
                interfaceLanguage: selector.interfaceLanguage),
            names: names,
            pathComponents: pathComponents,
            docComment: self.docComment[selector],
            accessLevel: accessLevel,
            kind: kind,
            mixins: mixins
        )
    }

    var defaultSymbol: SymbolGraph.Symbol? {
        symbol(forSelector: defaultSelector)
    }
    
    /// Returns the primary symbol to use as documentation source.
    var documentedSymbol: SymbolGraph.Symbol? {
        return symbol(forSelector: documentedSymbolSelector)
    }
    
    /// Returns the primary symbol selector to use as documentation source.
    var documentedSymbolSelector: UnifiedSymbolGraph.Selector? {
        // We'll prioritize the first documented 'swift' symbol, if we have
        // one.
        return docComment.keys.first { selector in
            return selector.interfaceLanguage == "swift"
        } ?? docComment.keys.first
    }

    func identifier(forLanguage interfaceLanguage: String) -> SymbolGraph.Symbol.Identifier {
        return SymbolGraph.Symbol.Identifier(
            precise: self.uniqueIdentifier,
            interfaceLanguage: interfaceLanguage
        )
    }

    var defaultIdentifier: SymbolGraph.Symbol.Identifier {
        if let defaultInterfaceLanguage = defaultSelector?.interfaceLanguage {
            return identifier(forLanguage: defaultInterfaceLanguage)
        } else {
            return identifier(forLanguage: "swift")
        }
    }
}