forked from microsoft/TypeScript
/
contextuallyTypedBindingInitializerNegative.types
82 lines (75 loc) · 2.16 KB
/
contextuallyTypedBindingInitializerNegative.types
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
=== tests/cases/conformance/types/contextualTypes/methodDeclarations/contextuallyTypedBindingInitializerNegative.ts ===
interface Show {
show: (x: number) => string;
>show : (x: number) => string
>x : number
}
function f({ show: showRename = v => v }: Show) {}
>f : ({ show: showRename }: Show) => void
>show : any
>showRename : (x: number) => string
>v => v : (v: number) => number
>v : number
>v : number
function f2({ "show": showRename = v => v }: Show) {}
>f2 : ({ "show": showRename }: Show) => void
>showRename : (x: number) => string
>v => v : (v: number) => number
>v : number
>v : number
function f3({ ["show"]: showRename = v => v }: Show) {}
>f3 : ({ ["show"]: showRename }: Show) => void
>"show" : "show"
>showRename : (x: number) => string
>v => v : (v: number) => number
>v : number
>v : number
interface Nested {
nested: Show
>nested : Show
}
function ff({ nested: nestedRename = { show: v => v } }: Nested) {}
>ff : ({ nested: nestedRename }: Nested) => void
>nested : any
>nestedRename : Show
>{ show: v => v } : { show: (v: number) => number; }
>show : (v: number) => number
>v => v : (v: number) => number
>v : number
>v : number
interface StringIdentity {
stringIdentity(s: string): string;
>stringIdentity : (s: string) => string
>s : string
}
let { stringIdentity: id = arg => arg.length }: StringIdentity = { stringIdentity: x => x};
>stringIdentity : any
>id : (s: string) => string
>arg => arg.length : (arg: string) => number
>arg : string
>arg.length : number
>arg : string
>length : number
>{ stringIdentity: x => x} : { stringIdentity: (x: string) => string; }
>stringIdentity : (x: string) => string
>x => x : (x: string) => string
>x : string
>x : string
interface Tuples {
prop: [string, number];
>prop : [string, number]
}
function g({ prop = [101, 1234] }: Tuples) {}
>g : ({ prop }: Tuples) => void
>prop : [string, number]
>[101, 1234] : [number, number]
>101 : 101
>1234 : 1234
interface StringUnion {
prop: "foo" | "bar";
>prop : "foo" | "bar"
}
function h({ prop = "baz" }: StringUnion) {}
>h : ({ prop }: StringUnion) => void
>prop : "foo" | "bar"
>"baz" : "baz"