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
|
=== tests/cases/compiler/contextualTypingWithGenericAndNonGenericSignature.ts ===
//• If e is a FunctionExpression or ArrowFunctionExpression with no type parameters and no parameter or return type annotations, and T is a function type with EXACTLY ONE non - generic call signature, then any inferences made for type parameters referenced by the parameters of T’s call signature are fixed(section 4.12.2) and e is processed with the contextual type T, as described in section 4.9.3.
var f2: {
>f2 : { (x: string, y: number): string; <T, U>(x: T, y: U): T; }
(x: string, y: number): string;
>x : string
>y : number
<T, U>(x: T, y: U): T
>T : T
>U : U
>x : T
>T : T
>y : U
>U : U
>T : T
};
f2 = (x, y) => { return x }
>f2 = (x, y) => { return x } : (x: any, y: any) => any
>f2 : { (x: string, y: number): string; <T, U>(x: T, y: U): T; }
>(x, y) => { return x } : (x: any, y: any) => any
>x : any
>y : any
>x : any
var f3: {
>f3 : { <T, U>(x: T, y: U): T; (x: string, y: number): string; }
<T, U>(x: T, y: U): T
>T : T
>U : U
>x : T
>T : T
>y : U
>U : U
>T : T
(x: string, y: number): string;
>x : string
>y : number
};
f3 = (x, y) => { return x }
>f3 = (x, y) => { return x } : (x: any, y: any) => any
>f3 : { <T, U>(x: T, y: U): T; (x: string, y: number): string; }
>(x, y) => { return x } : (x: any, y: any) => any
>x : any
>y : any
>x : any
|