File: SymbolKind.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 (49 lines) | stat: -rw-r--r-- 2,110 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
/*
 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
*/

import Foundation

extension SymbolGraph.Symbol {
    /// A description of a symbol's kind, such as a structure or protocol.
    public struct Kind: Equatable, Codable {
        /// A unique identifier for this symbol's kind.
        public var identifier: KindIdentifier

        /// A display name for a kind of symbol.
        ///
        /// For example, a Swift class might use `"Class"`.
        /// This display name should not be abbreviated:
        /// for instance, use `"Structure"` instead of `"Struct"` if applicable.
        public var displayName: String

        /// Initializes a new ``SymbolGraph/Symbol/Kind-swift.struct`` with an already-parsed
        /// ``SymbolGraph/Symbol/KindIdentifier`` and display name.
        public init(parsedIdentifier: KindIdentifier, displayName: String) {
            identifier = parsedIdentifier
            self.displayName = displayName
        }

        /// Initializes a new ``SymbolGraph/Symbol/Kind-swift.struct`` by parsing a new
        /// ``SymbolGraph/Symbol/KindIdentifier`` from the given identifier string, and combining it
        /// with a display name.
        @available(*, deprecated, message: "Use init(rawIdentifier:displayName:) instead")
        public init(identifier: String, displayName: String) {
            self.init(rawIdentifier: identifier, displayName: displayName)
        }

        /// Initializes a new ``SymbolGraph/Symbol/Kind-swift.struct`` by parsing a new
        /// ``SymbolGraph/Symbol/KindIdentifier`` from the given identifier string, and combining it
        /// with a display name.
        public init(rawIdentifier: String, displayName: String) {
            identifier = KindIdentifier(identifier: rawIdentifier)
            self.displayName = displayName
        }
    }
}