File: Name.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 (43 lines) | stat: -rw-r--r-- 1,454 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
/*
 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
*/

extension DocumentationNode {
    /**
     The annotated name of a node.
     
     Extend this type to transform the name of a node into various forms,
     such as for display as a title or in a task group, or normalized for
     search indexing.
     */
    public enum Name: Hashable, CustomStringConvertible {
        /// The name of a conceptual document is its title.
        case conceptual(title: String)
        /// The name of the symbol is derived from its declaration.
        case symbol(declaration: AttributedCodeListing.Line)
        
        public func hash(into hasher: inout Hasher) {
            switch self {
            case .conceptual(let text):
                hasher.combine(text)
            case .symbol(let declaration):
                hasher.combine(declaration)
            }
        }
        
        public var description: String {
            switch self {
            case .conceptual(let title):
                return title
            case .symbol(let declaration):
                return declaration.tokens.map { $0.description }.joined(separator: " ")
            }
        }
    }
}