|
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