File: genericCallWithObjectTypeArgsAndConstraints5.types

package info (click to toggle)
node-typescript 3.3.3333-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 324,548 kB
  • sloc: makefile: 6; sh: 3
file content (63 lines) | stat: -rw-r--r-- 1,244 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
=== tests/cases/conformance/types/typeRelationships/typeInference/genericCallWithObjectTypeArgsAndConstraints5.ts ===
// Generic call with constraints infering type parameter from object member properties

class C {
>C : C

    x: string;
>x : string
}

class D {
>D : D

    x: string;
>x : string

    y: string;
>y : string
}

function foo<T, U extends T>(t: T, t2: U) {
>foo : <T, U extends T>(t: T, t2: U) => (x: T) => U
>t : T
>t2 : U

    return (x: T) => t2;
>(x: T) => t2 : (x: T) => U
>x : T
>t2 : U
}

var c: C;
>c : C

var d: D;
>d : D

var r2 = foo(d, c); // the constraints are self-referencing, no downstream error
>r2 : any
>foo(d, c) : any
>foo : <T, U extends T>(t: T, t2: U) => (x: T) => U
>d : D
>c : C

var r9 = foo(() => 1, () => { }); // the constraints are self-referencing, no downstream error
>r9 : any
>foo(() => 1, () => { }) : any
>foo : <T, U extends T>(t: T, t2: U) => (x: T) => U
>() => 1 : () => number
>1 : 1
>() => { } : () => void

function other<T, U extends T>() {
>other : <T, U extends T>() => void

    var r5 = foo<T, U>(c, d); // error
>r5 : any
>foo<T, U>(c, d) : any
>foo : <T, U extends T>(t: T, t2: U) => (x: T) => U
>c : C
>d : D
}