File: Fragment.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 (53 lines) | stat: -rw-r--r-- 1,787 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
/*
 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.DeclarationFragments {
    /**
     A general-purpose fragment of syntax spelling out a declaration.

     For example, a C function might break up `int main(int argc, char **argv)`
     or a Swift structure might break up into `struct MyStruct<S: Sequence>`.
     */
    public struct Fragment: Equatable, Codable {
        /**
         The kind of fragment, such as a token keyword, identifier,
         or span of text.
         */
        public var kind: Kind

        /**
         How the token was spelled in the source code.
         */
        public var spelling: String

        /**
         A precise identifier if the fragment corresponds to another symbol.
         This may be useful for linking to other symbols when displaying
         function parameter types.
         */
        public var preciseIdentifier: String?

        /**
          Initialize a fragment with the given `kind`, `spelling`, and `preciseIdentifier`.

          - Parameters:
             - kind: The kind of fragment.
             - spelling: How the token was spelled in the source code.
             - preciseIdentifier: A precise identifier if the fragment corresponds to another symbol.
         */
        public init(kind: Kind, spelling: String, preciseIdentifier: String?) {
            self.kind = kind
            self.spelling = spelling
            self.preciseIdentifier = preciseIdentifier
        }
    }
}