File: Generics.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 (72 lines) | stat: -rw-r--r-- 2,284 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
/*
 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 {
    /**
     The generic signature of a declaration or type.
     */
    public struct Generics: Mixin {
        public static let mixinKey = "swiftGenerics"

        enum CodingKeys: String, CodingKey {
            case parameters
            case constraints
        }

        /**
         The generic parameters of a declaration.

         For example, in the following generic function signature,

         ```swift
         func foo<T>(_ thing: T) { ... }
         ```

         `T` is a *generic parameter*.
         */
        public var parameters: [GenericParameter]

        /**
         The generic constraints of a declaration.

         For example, in the following generic function signature,

         ```swift
         func foo<S>(_ s: S) where S: Sequence
         ```

         There is a *conformance constraint* involving `S`.
         */
        public var constraints: [GenericConstraint]
        
        public init(parameters: [SymbolGraph.Symbol.Swift.GenericParameter], constraints: [SymbolGraph.Symbol.Swift.GenericConstraint]) {
            self.parameters = parameters
            self.constraints = constraints
        }

        public init(from decoder: Decoder) throws {
            let container = try decoder.container(keyedBy: CodingKeys.self)
            parameters = try container.decodeIfPresent([GenericParameter].self, forKey: .parameters) ?? []
            constraints = try container.decodeIfPresent([GenericConstraint].self, forKey: .constraints) ?? []
        }

        public func encode(to encoder: Encoder) throws {
            var container = encoder.container(keyedBy: CodingKeys.self)
            if !parameters.isEmpty {
                try container.encode(parameters, forKey: .parameters)
            }
            if !constraints.isEmpty {
                try container.encode(constraints, forKey: .constraints)
            }
        }
    }
}