16450a027a
* Change the default type parameter constraint and default to unknown from {} * Relax unknown checking outside of strictNullChecks a bit * Increase strictness on index signatures with type `unknown` so inference doesnt change surprisingly * Remove redundant switch
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
/// <reference path='fourslash.ts'/>
|
|
|
|
////class A<T> { }
|
|
////class B<T> {/*B*/ }
|
|
////class C<T> { /*C*/constructor(val: T) { } }
|
|
////class D<T> { constructor(/*D*/val: T) { } }
|
|
////
|
|
////new /*Asig*/A<string>();
|
|
////new /*Bsig*/B("");
|
|
////new /*Csig*/C("");
|
|
////new /*Dsig*/D<string>();
|
|
|
|
var A = 'A';
|
|
var B = 'B';
|
|
var C = 'C';
|
|
var D = 'D'
|
|
goTo.marker(B);
|
|
edit.insert('constructor(val: T) { }');
|
|
verify.quickInfos({
|
|
Asig: "constructor A<string>(): A<string>",
|
|
Bsig: "constructor B<string>(val: string): B<string>",
|
|
Csig: "constructor C<string>(val: string): C<string>",
|
|
Dsig: "constructor D<string>(val: string): D<string>" // Cannot resolve signature. Still fill in generics based on explicit type arguments.
|
|
});
|
|
|
|
goTo.marker(C);
|
|
edit.deleteAtCaret('constructor(val: T) { }'.length);
|
|
verify.quickInfos({
|
|
Asig: "constructor A<string>(): A<string>",
|
|
Bsig: "constructor B<string>(val: string): B<string>",
|
|
Csig: "constructor C<unknown>(): C<unknown>", // Cannot resolve signature
|
|
Dsig: "constructor D<string>(val: string): D<string>" // Cannot resolve signature
|
|
});
|
|
|
|
goTo.marker(D);
|
|
edit.deleteAtCaret("val: T".length);
|
|
verify.quickInfos({
|
|
Asig: "constructor A<string>(): A<string>",
|
|
Bsig: "constructor B<string>(val: string): B<string>",
|
|
Csig: "constructor C<unknown>(): C<unknown>", // Cannot resolve signature
|
|
Dsig: "constructor D<string>(): D<string>"
|
|
});
|