File: GenericParameter.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 (51 lines) | stat: -rw-r--r-- 1,231 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
/*
 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.Swift {
    /**
     A generic parameter of a declaration, such as the `T` in `foo<T>(...)`.
     */
    public struct GenericParameter: Codable {
        /// The name of the generic parameter.
        public var name: String

        /**
         The index of the generic parameter.

         For example, in the following function signature,

         ```swift
         func foo<T, U>(x: T, y: U)
         ```

         `T` has index 0 and `U` has index 1.
         */
        public var index: Int

        /**
         The depth of the generic parameter.

         For example, in the following generic structure,

         ```swift
         struct MyStruct<T> {
           func foo<U>(x: U, y: T) {
             // ...
           }
         }
         ```

         `T` has depth 0 and `U` has depth 1.
         */
        public var depth: Int
    }
}