File: nonNullFullInference.symbols

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 (71 lines) | stat: -rw-r--r-- 2,313 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
=== tests/cases/compiler/nonNullFullInference.ts ===
// https://github.com/microsoft/TypeScript/issues/19577

function testNonNullInference(numbers: number[]) {
>testNonNullInference : Symbol(testNonNullInference, Decl(nonNullFullInference.ts, 0, 0))
>numbers : Symbol(numbers, Decl(nonNullFullInference.ts, 2, 30))

    let last;
>last : Symbol(last, Decl(nonNullFullInference.ts, 3, 7))

    for (const n of numbers) {
>n : Symbol(n, Decl(nonNullFullInference.ts, 5, 14))
>numbers : Symbol(numbers, Decl(nonNullFullInference.ts, 2, 30))

        if (n % 2) {
>n : Symbol(n, Decl(nonNullFullInference.ts, 5, 14))

            return n;
>n : Symbol(n, Decl(nonNullFullInference.ts, 5, 14))
        }

        last = n;
>last : Symbol(last, Decl(nonNullFullInference.ts, 3, 7))
>n : Symbol(n, Decl(nonNullFullInference.ts, 5, 14))
    }

    last;
>last : Symbol(last, Decl(nonNullFullInference.ts, 3, 7))

    last!;
>last : Symbol(last, Decl(nonNullFullInference.ts, 3, 7))
}

function testNonNullInferenceWithArrays(numbers: number[]) {
>testNonNullInferenceWithArrays : Symbol(testNonNullInferenceWithArrays, Decl(nonNullFullInference.ts, 15, 1))
>numbers : Symbol(numbers, Decl(nonNullFullInference.ts, 17, 40))

    let result;
>result : Symbol(result, Decl(nonNullFullInference.ts, 18, 7))

    const arr = [];
>arr : Symbol(arr, Decl(nonNullFullInference.ts, 19, 9))

    for (const n of numbers) {
>n : Symbol(n, Decl(nonNullFullInference.ts, 21, 14))
>numbers : Symbol(numbers, Decl(nonNullFullInference.ts, 17, 40))

        if (n % 2) {
>n : Symbol(n, Decl(nonNullFullInference.ts, 21, 14))

            return [n];
>n : Symbol(n, Decl(nonNullFullInference.ts, 21, 14))
        }

        arr.push(n);
>arr.push : Symbol(Array.push, Decl(lib.es5.d.ts, --, --))
>arr : Symbol(arr, Decl(nonNullFullInference.ts, 19, 9))
>push : Symbol(Array.push, Decl(lib.es5.d.ts, --, --))
>n : Symbol(n, Decl(nonNullFullInference.ts, 21, 14))

        result = arr;
>result : Symbol(result, Decl(nonNullFullInference.ts, 18, 7))
>arr : Symbol(arr, Decl(nonNullFullInference.ts, 19, 9))
    }

    result;
>result : Symbol(result, Decl(nonNullFullInference.ts, 18, 7))

    result!;
>result : Symbol(result, Decl(nonNullFullInference.ts, 18, 7))
}