File: thisBinding2.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 (77 lines) | stat: -rw-r--r-- 2,140 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
=== tests/cases/compiler/thisBinding2.ts ===
class C {
>C : C

 x: number;
>x : number

    constructor() {
        this.x = (() => {
>this.x = (() => {   var x = 1;   return this.x;  })() : number
>this.x : number
>this : this
>x : number
>(() => {   var x = 1;   return this.x;  })() : number
>(() => {   var x = 1;   return this.x;  }) : () => number
>() => {   var x = 1;   return this.x;  } : () => number

   var x = 1;
>x : number
>1 : 1

   return this.x;
>this.x : number
>this : this
>x : number

  })();
  this.x = function() {
>this.x = function() {   var x = 1;   return this.x;  }() : any
>this.x : number
>this : this
>x : number
>function() {   var x = 1;   return this.x;  }() : any
>function() {   var x = 1;   return this.x;  } : () => any

   var x = 1;
>x : number
>1 : 1

   return this.x;
>this.x : any
>this : any
>x : any

  }();
    }  
}
declare function setTimeout(expression: any, msec?: number, language?: any): number;
>setTimeout : { (handler: TimerHandler, timeout?: number, ...arguments: any[]): number; (expression: any, msec?: number, language?: any): number; }
>expression : any
>msec : number
>language : any

var messenger = {
>messenger : { message: string; start: () => number; }
>{    message: "Hello World",    start: function () {        return setTimeout(() => { var x = this.message; }, 3000);    }} : { message: string; start: () => number; }

    message: "Hello World",
>message : string
>"Hello World" : "Hello World"

    start: function () {
>start : () => number
>function () {        return setTimeout(() => { var x = this.message; }, 3000);    } : () => number

        return setTimeout(() => { var x = this.message; }, 3000);
>setTimeout(() => { var x = this.message; }, 3000) : number
>setTimeout : { (handler: TimerHandler, timeout?: number, ...arguments: any[]): number; (expression: any, msec?: number, language?: any): number; }
>() => { var x = this.message; } : () => void
>x : string
>this.message : string
>this : { message: string; start: () => number; }
>message : string
>3000 : 3000
    }
};