File: simpleRecursionWithBaseCase.types

package info (click to toggle)
node-typescript 5.1.6%2Bds1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 492,516 kB
  • sloc: javascript: 2,078,951; makefile: 6; sh: 1
file content (92 lines) | stat: -rw-r--r-- 1,504 bytes parent folder | download
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
=== tests/cases/compiler/simpleRecursionWithBaseCase.ts ===
function fn1(n: number) {
>fn1 : (n: number) => number
>n : number

    if (n === 0) {
>n === 0 : boolean
>n : number
>0 : 0

        return 3;
>3 : 3

    } else {
        return fn1(n - 1);
>fn1(n - 1) : number
>fn1 : (n: number) => number
>n - 1 : number
>n : number
>1 : 1
    }
}
const num: number = fn1();
>num : number
>fn1() : number
>fn1 : (n: number) => number

function fn2(n: number) {
>fn2 : (n: number) => never
>n : number

    return fn2(n);
>fn2(n) : never
>fn2 : (n: number) => never
>n : number
}
const nev: never = fn2();
>nev : never
>fn2() : never
>fn2 : (n: number) => never

function fn3(n: number) {
>fn3 : (n: number) => number
>n : number

    if (n === 0) {
>n === 0 : boolean
>n : number
>0 : 0

        return 3;
>3 : 3

    } else {
        return fn1("hello world");
>fn1("hello world") : number
>fn1 : (n: number) => number
>"hello world" : "hello world"
    }
}

function fn4(n: number) {
>fn4 : (n: number) => any
>n : number

    if (n === 0) {
>n === 0 : boolean
>n : number
>0 : 0

        return 3;
>3 : 3

    } else {
        return notfoundsymbol("hello world");
>notfoundsymbol("hello world") : any
>notfoundsymbol : any
>"hello world" : "hello world"
    }
}

function fn5() {
>fn5 : () => any

    return [fn5][0]();
>[fn5][0]() : any
>[fn5][0] : () => any
>[fn5] : (() => any)[]
>fn5 : () => any
>0 : 0
}