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 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
//// [objectTypesIdentityWithConstructSignatures2.ts]
// object types are identical structurally
class B {
constructor(x: number) { return null; }
}
class C<T> {
constructor(x: T) { return null; }
}
interface I {
new(x: boolean): string;
}
interface I2<T> {
new(x: T): T;
}
var a: { new(x: Date): string }
var b = { new(x: RegExp) { return ''; } }; // not a construct signature, function called new
function foo1b(x: B);
function foo1b(x: B); // error
function foo1b(x: any) { }
function foo1c(x: C<string>);
function foo1c(x: C<string>); // error
function foo1c(x: any) { }
function foo2(x: I);
function foo2(x: I); // error
function foo2(x: any) { }
function foo3(x: typeof a);
function foo3(x: typeof a); // error
function foo3(x: any) { }
function foo4(x: typeof b);
function foo4(x: typeof b); // error
function foo4(x: any) { }
function foo8(x: B);
function foo8(x: I); // ok
function foo8(x: any) { }
function foo9(x: B);
function foo9(x: C<string>); // error, types are structurally equal
function foo9(x: any) { }
function foo10(x: B);
function foo10(x: typeof a); // ok
function foo10(x: any) { }
function foo11(x: B);
function foo11(x: typeof b); // ok
function foo11(x: any) { }
function foo12(x: I);
function foo12(x: C<string>); // ok
function foo12(x: any) { }
function foo12b(x: I2<string>);
function foo12b(x: C<string>); // ok
function foo12b(x: any) { }
function foo13(x: I);
function foo13(x: typeof a); // ok
function foo13(x: any) { }
function foo14(x: I);
function foo14(x: typeof b); // ok
function foo14(x: any) { }
function foo15(x: I2<string>);
function foo15(x: C<number>); // ok
function foo15(x: any) { }
//// [objectTypesIdentityWithConstructSignatures2.js]
// object types are identical structurally
var B = /** @class */ (function () {
function B(x) {
return null;
}
return B;
}());
var C = /** @class */ (function () {
function C(x) {
return null;
}
return C;
}());
var a;
var b = { "new": function (x) { return ''; } }; // not a construct signature, function called new
function foo1b(x) { }
function foo1c(x) { }
function foo2(x) { }
function foo3(x) { }
function foo4(x) { }
function foo8(x) { }
function foo9(x) { }
function foo10(x) { }
function foo11(x) { }
function foo12(x) { }
function foo12b(x) { }
function foo13(x) { }
function foo14(x) { }
function foo15(x) { }
|