File: intersectionTypeEquivalence.symbols

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 (63 lines) | stat: -rw-r--r-- 3,119 bytes parent folder | download | duplicates (7)
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
=== tests/cases/conformance/types/intersection/intersectionTypeEquivalence.ts ===
interface A { a: string }
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))
>a : Symbol(A.a, Decl(intersectionTypeEquivalence.ts, 0, 13))

interface B { b: string }
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))
>b : Symbol(B.b, Decl(intersectionTypeEquivalence.ts, 1, 13))

interface C { c: string }
>C : Symbol(C, Decl(intersectionTypeEquivalence.ts, 1, 25))
>c : Symbol(C.c, Decl(intersectionTypeEquivalence.ts, 2, 13))

// A & B is equivalent to B & A.
var y: A & B;
>y : Symbol(y, Decl(intersectionTypeEquivalence.ts, 5, 3), Decl(intersectionTypeEquivalence.ts, 6, 3))
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))

var y : B & A;
>y : Symbol(y, Decl(intersectionTypeEquivalence.ts, 5, 3), Decl(intersectionTypeEquivalence.ts, 6, 3))
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))

// AB & C is equivalent to A & BC, where AB is A & B and BC is B & C.
var z : A & B & C;
>z : Symbol(z, Decl(intersectionTypeEquivalence.ts, 9, 3), Decl(intersectionTypeEquivalence.ts, 10, 3), Decl(intersectionTypeEquivalence.ts, 11, 3))
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))
>C : Symbol(C, Decl(intersectionTypeEquivalence.ts, 1, 25))

var z : (A & B) & C;
>z : Symbol(z, Decl(intersectionTypeEquivalence.ts, 9, 3), Decl(intersectionTypeEquivalence.ts, 10, 3), Decl(intersectionTypeEquivalence.ts, 11, 3))
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))
>C : Symbol(C, Decl(intersectionTypeEquivalence.ts, 1, 25))

var z : A & (B & C);
>z : Symbol(z, Decl(intersectionTypeEquivalence.ts, 9, 3), Decl(intersectionTypeEquivalence.ts, 10, 3), Decl(intersectionTypeEquivalence.ts, 11, 3))
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))
>C : Symbol(C, Decl(intersectionTypeEquivalence.ts, 1, 25))

var ab : A & B;
>ab : Symbol(ab, Decl(intersectionTypeEquivalence.ts, 12, 3))
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))

var bc : B & C;
>bc : Symbol(bc, Decl(intersectionTypeEquivalence.ts, 13, 3))
>B : Symbol(B, Decl(intersectionTypeEquivalence.ts, 0, 25))
>C : Symbol(C, Decl(intersectionTypeEquivalence.ts, 1, 25))

var z1: typeof ab & C;
>z1 : Symbol(z1, Decl(intersectionTypeEquivalence.ts, 14, 3), Decl(intersectionTypeEquivalence.ts, 15, 3))
>ab : Symbol(ab, Decl(intersectionTypeEquivalence.ts, 12, 3))
>C : Symbol(C, Decl(intersectionTypeEquivalence.ts, 1, 25))

var z1: A & typeof bc;
>z1 : Symbol(z1, Decl(intersectionTypeEquivalence.ts, 14, 3), Decl(intersectionTypeEquivalence.ts, 15, 3))
>A : Symbol(A, Decl(intersectionTypeEquivalence.ts, 0, 0))
>bc : Symbol(bc, Decl(intersectionTypeEquivalence.ts, 13, 3))