File: inferenceErasedSignatures.types

package info (click to toggle)
node-typescript 4.9.5%2Bds1-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 533,908 kB
  • sloc: javascript: 2,018,330; makefile: 7; sh: 1
file content (118 lines) | stat: -rw-r--r-- 2,930 bytes parent folder | download | duplicates (3)
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
=== tests/cases/compiler/inferenceErasedSignatures.ts ===
// Repro from #37163

declare class SomeBaseClass {
>SomeBaseClass : SomeBaseClass

    set<K extends keyof this>(key: K, value: this[K]): this[K];
>set : <K extends keyof this>(key: K, value: this[K]) => this[K]
>key : K
>value : this[K]
}

abstract class SomeAbstractClass<C, M, R> extends SomeBaseClass {
>SomeAbstractClass : SomeAbstractClass<C, M, R>
>SomeBaseClass : SomeBaseClass

    foo!: (r?: R) => void;
>foo : (r?: R) => void
>r : R | undefined

    bar!: (r?: any) => void;
>bar : (r?: any) => void
>r : any

    abstract baz(c: C): Promise<M>;
>baz : (c: C) => Promise<M>
>c : C
}

class SomeClass extends SomeAbstractClass<number, string, boolean> {
>SomeClass : SomeClass
>SomeAbstractClass : SomeAbstractClass<number, string, boolean>

    async baz(context: number): Promise<string> {
>baz : (context: number) => Promise<string>
>context : number

        return `${context}`;
>`${context}` : string
>context : number
    }
}

type CType<T> = T extends SomeAbstractClass<infer C, any, any> ? C : never;
>CType : CType<T>

type MType<T> = T extends SomeAbstractClass<any, infer M, any> ? M : never;
>MType : MType<T>

type RType<T> = T extends SomeAbstractClass<any, any, infer R> ? R : never;
>RType : RType<T>

type SomeClassC = CType<SomeClass>; // number
>SomeClassC : number

type SomeClassM = MType<SomeClass>; // string
>SomeClassM : string

type SomeClassR = RType<SomeClass>; // boolean
>SomeClassR : boolean

// Repro from #37163

interface BaseType<T1, T2>  {
    set<K extends keyof this>(key: K, value: this[K]): this[K];
>set : <K extends keyof this>(key: K, value: this[K]) => this[K]
>key : K
>value : this[K]

    useT1(c: T1): void;
>useT1 : (c: T1) => void
>c : T1

    useT2(r?: T2): void;
>useT2 : (r?: T2) => void
>r : T2 | undefined

    unrelatedButSomehowRelevant(r?: any): void;
>unrelatedButSomehowRelevant : (r?: any) => void
>r : any
}

interface InheritedType extends BaseType<number, boolean> {
    // This declaration shouldn't do anything...
    useT1(_: number): void
>useT1 : (_: number) => void
>_ : number
}

// Structural expansion of InheritedType
interface StructuralVersion  {
    set<K extends keyof this>(key: K, value: this[K]): this[K];
>set : <K extends keyof this>(key: K, value: this[K]) => this[K]
>key : K
>value : this[K]

    useT1(c: number): void;
>useT1 : (c: number) => void
>c : number

    useT2(r?: boolean): void;
>useT2 : (r?: boolean) => void
>r : boolean | undefined

    unrelatedButSomehowRelevant(r?: any): void;
>unrelatedButSomehowRelevant : (r?: any) => void
>r : any
}

type GetT1<T> = T extends BaseType<infer U, any> ? U : never;
>GetT1 : GetT1<T>

type T1 = GetT1<InheritedType>; // number
>T1 : number

type T2 = GetT1<StructuralVersion>; // number
>T2 : number