File: contextuallyTypedBindingInitializerNegative.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 (82 lines) | stat: -rw-r--r-- 2,213 bytes parent folder | download | duplicates (5)
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"