File: contextuallyTypedBindingInitializerNegative.types

package info (click to toggle)
node-typescript 2.1.5-1~bpo8%2B1
  • links: PTS, VCS
  • area: main
  • in suites: jessie-backports
  • size: 203,960 kB
  • sloc: sh: 11; makefile: 5
file content (100 lines) | stat: -rw-r--r-- 2,653 bytes parent folder | download | duplicates (2)
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
=== tests/cases/conformance/types/contextualTypes/methodDeclarations/contextuallyTypedBindingInitializerNegative.ts ===
interface Show {
>Show : 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: number) => number)
>v => v : (v: number) => number
>v : number
>v : number
>Show : Show

function f2({ "show": showRename = v => v }: Show) {}
>f2 : ({"show": showRename}: Show) => void
>showRename : ((x: number) => string) | ((v: number) => number)
>v => v : (v: number) => number
>v : number
>v : number
>Show : Show

function f3({ ["show"]: showRename = v => v }: Show) {}
>f3 : ({["show"]: showRename}: Show) => void
>"show" : "show"
>showRename : ((x: number) => string) | ((v: number) => number)
>v => v : (v: number) => number
>v : number
>v : number
>Show : Show

interface Nested {
>Nested : Nested

    nested: Show
>nested : Show
>Show : Show
}
function ff({ nested: nestedRename = { show: v => v } }: Nested) {}
>ff : ({nested: nestedRename}: Nested) => void
>nested : any
>nestedRename : Show | { show: (v: number) => number; }
>{ show: v => v } : { show: (v: number) => number; }
>show : (v: number) => number
>v => v : (v: number) => number
>v : number
>v : number
>Nested : Nested

interface StringIdentity {
>StringIdentity : 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: string) => number)
>arg => arg.length : (arg: string) => number
>arg : string
>arg.length : number
>arg : string
>length : number
>StringIdentity : StringIdentity
>{ stringIdentity: x => x} : { stringIdentity: (x: string) => string; }
>stringIdentity : (x: string) => string
>x => x : (x: string) => string
>x : string
>x : string

interface Tuples {
>Tuples : Tuples

    prop: [string, number];
>prop : [string, number]
}
function g({ prop = [101, 1234] }: Tuples) {}
>g : ({prop}: Tuples) => void
>prop : [string, number] | [number, number]
>[101, 1234] : [number, number]
>101 : 101
>1234 : 1234
>Tuples : Tuples

interface StringUnion {
>StringUnion : StringUnion

    prop: "foo" | "bar";
>prop : "foo" | "bar"
}
function h({ prop = "baz" }: StringUnion) {}
>h : ({prop}: StringUnion) => void
>prop : "foo" | "bar" | "baz"
>"baz" : "baz"
>StringUnion : StringUnion