|
1 | 1 | //// [intersectionOfCallsWithSameParameters.ts]
|
2 | 2 | interface One {
|
3 |
| - overload(id: string): { one: number }; |
4 |
| - intersect(id: string): { one: number }; |
| 3 | + differentParameterType(id: string): { one: number }; |
| 4 | + differentNumberOfParameters(id: string): { one: number }; |
| 5 | + differentTypeParameterDefault<T = number>(id: string): { one: number }; |
| 6 | + differentTypeParameterConstraint<T extends { one: number }>(id: string): { one: number }; |
| 7 | + |
| 8 | + same1(id: string): { one: number }; |
| 9 | + same2<T>(id: string): { one: number }; |
| 10 | + same3<T extends { one: number }>(id: string): { one: number }; |
| 11 | + same4<T = number>(id: string): { one: number }; |
| 12 | + same5<T1 extends { one: number }, T2 = number>(id: string): { one: number }; |
5 | 13 | }
|
6 | 14 |
|
7 | 15 | interface Two {
|
8 |
| - overload(id: number): { two: number }; |
9 |
| - intersect(id: string): { two: number }; |
| 16 | + differentParameterType(id: number): { two: number }; |
| 17 | + differentNumberOfParameters(id: string, second: string): { two: number }; |
| 18 | + differentTypeParameterDefault<T = string>(id: string): { two: number }; |
| 19 | + differentTypeParameterConstraint<T extends { two: number }>(id: string): { two: number }; |
| 20 | + |
| 21 | + same1(id: string): { two: number }; |
| 22 | + same2<T>(id: string): { two: number }; |
| 23 | + same3<T extends { one: number }>(id: string): { two: number }; |
| 24 | + same4<T = number>(id: string): { two: number }; |
| 25 | + same5<T1 extends { one: number }, T2 = number>(id: string): { two: number }; |
10 | 26 | }
|
11 | 27 |
|
12 |
| -class Both implements One, Two { |
13 |
| - overload(id: number): { two: number }; |
14 |
| - overload(id: string): { one: number }; |
15 |
| - overload(id: string | number): { one: number, two: number } { |
16 |
| - return { |
17 |
| - one: 1, |
18 |
| - two: 2 |
19 |
| - }; |
20 |
| - } |
| 28 | +const i: One & Two = <any>{}; |
21 | 29 |
|
22 |
| - intersect(id: string): { one: number, two: number } { |
23 |
| - return { |
24 |
| - one: 1, |
25 |
| - two: 2 |
26 |
| - }; |
27 |
| - } |
28 |
| -} |
| 30 | +// These lines should type check; the return type should be intersected. |
| 31 | +const same1: { one: number, two: number } = i.same1('test'); |
| 32 | +const same2: { one: number, two: number } = i.same2<number>('test'); |
| 33 | +const same3: { one: number, two: number } = i.same3<{ one:number }>('test'); |
| 34 | +const same4: { one: number, two: number } = i.same4('test'); |
| 35 | +const same5: { one: number, two: number } = i.same5<{ one:number }, string>('test'); |
29 | 36 |
|
30 |
| -const b = new Both(); |
31 |
| -const intersect: { one: number, two: number } = b.intersect('test'); |
32 |
| -const overloadA: { one: number } = b.overload('test'); |
33 |
| -const overloadB: { two: number } = b.overload(4); |
34 |
| -const bAs: One & Two = b; |
35 |
| -const asIntersect: { one: number, two: number } = bAs.intersect('test'); |
36 |
| -const asOverloadA: { one: number } = bAs.overload('test'); |
37 |
| -const asOverloadB: { two: number } = bAs.overload(4); |
| 37 | +// These lines should not, because the functions should become overloads rather |
| 38 | +// than the return types intersected. |
| 39 | +const differentParameterType: { one: number, two: number } = i.differentParameterType('test'); |
| 40 | +const differentNumberOfParameters: { one: number, two: number } = i.differentNumberOfParameters('test'); |
| 41 | +const differentTypeParameterDefault: { one: number, two: number } = i.differentTypeParameterDefault('test'); |
| 42 | +const differentTypeParameterConstraint: { one: number, two: number } = i.differentTypeParameterConstraint<{ one: number }>('test'); |
38 | 43 |
|
39 | 44 |
|
40 | 45 | //// [intersectionOfCallsWithSameParameters.js]
|
41 | 46 | "use strict";
|
42 |
| -var Both = /** @class */ (function () { |
43 |
| - function Both() { |
44 |
| - } |
45 |
| - Both.prototype.overload = function (id) { |
46 |
| - return { |
47 |
| - one: 1, |
48 |
| - two: 2 |
49 |
| - }; |
50 |
| - }; |
51 |
| - Both.prototype.intersect = function (id) { |
52 |
| - return { |
53 |
| - one: 1, |
54 |
| - two: 2 |
55 |
| - }; |
56 |
| - }; |
57 |
| - return Both; |
58 |
| -}()); |
59 |
| -var b = new Both(); |
60 |
| -var intersect = b.intersect('test'); |
61 |
| -var overloadA = b.overload('test'); |
62 |
| -var overloadB = b.overload(4); |
63 |
| -var bAs = b; |
64 |
| -var asIntersect = bAs.intersect('test'); |
65 |
| -var asOverloadA = bAs.overload('test'); |
66 |
| -var asOverloadB = bAs.overload(4); |
| 47 | +var i = {}; |
| 48 | +// These lines should type check; the return type should be intersected. |
| 49 | +var same1 = i.same1('test'); |
| 50 | +var same2 = i.same2('test'); |
| 51 | +var same3 = i.same3('test'); |
| 52 | +var same4 = i.same4('test'); |
| 53 | +var same5 = i.same5('test'); |
| 54 | +// These lines should not, because the functions should become overloads rather |
| 55 | +// than the return types intersected. |
| 56 | +var differentParameterType = i.differentParameterType('test'); |
| 57 | +var differentNumberOfParameters = i.differentNumberOfParameters('test'); |
| 58 | +var differentTypeParameterDefault = i.differentTypeParameterDefault('test'); |
| 59 | +var differentTypeParameterConstraint = i.differentTypeParameterConstraint('test'); |
0 commit comments