* Always generate type & symbol baselines * Accept changed shadowed baselines * Accept brand new type and symbol baselines * Allow `getTypeAtLocation` to return undefined in the type writer * Accept baselines which had missing type information * Bind container for dynamically names enum members so they may be printed * Accept type/symbol baselines for enums with computed members * First pass at reducing typeWriter memory overhead * Use generators to allow for type and symbol baselines with no cache * Accept new baselines for tests whose output was fixed by better newline splitting * Hard cap on number of declarations printed, cache declaration print text * handle differing newlines better still to handle RWC newlines * Lower abridging count, accept abridged baselines * Limit max RWC error output size, limit RWC type and symbol baseline input size * Move skip logic into type and symbol baseliner to streamline error handling * Accept removal of empty baselines * Canonicalize path earlier to handle odd paths in input files * Do canonicalization earlier still, also ensure parallel perf profiles for different targets do not trample one another * No need to pathify again
51 lines
2.1 KiB
Plaintext
51 lines
2.1 KiB
Plaintext
=== tests/cases/compiler/typeArgInference2.ts ===
|
|
interface Item {
|
|
>Item : Symbol(Item, Decl(typeArgInference2.ts, 0, 0))
|
|
|
|
name: string;
|
|
>name : Symbol(Item.name, Decl(typeArgInference2.ts, 0, 16))
|
|
}
|
|
|
|
declare function foo<T extends Item>(x?: T, y?: T): T;
|
|
>foo : Symbol(foo, Decl(typeArgInference2.ts, 2, 1))
|
|
>T : Symbol(T, Decl(typeArgInference2.ts, 4, 21))
|
|
>Item : Symbol(Item, Decl(typeArgInference2.ts, 0, 0))
|
|
>x : Symbol(x, Decl(typeArgInference2.ts, 4, 37))
|
|
>T : Symbol(T, Decl(typeArgInference2.ts, 4, 21))
|
|
>y : Symbol(y, Decl(typeArgInference2.ts, 4, 43))
|
|
>T : Symbol(T, Decl(typeArgInference2.ts, 4, 21))
|
|
>T : Symbol(T, Decl(typeArgInference2.ts, 4, 21))
|
|
|
|
var z1 = foo(null); // any
|
|
>z1 : Symbol(z1, Decl(typeArgInference2.ts, 6, 3))
|
|
>foo : Symbol(foo, Decl(typeArgInference2.ts, 2, 1))
|
|
|
|
var z2 = foo(); // Item
|
|
>z2 : Symbol(z2, Decl(typeArgInference2.ts, 7, 3))
|
|
>foo : Symbol(foo, Decl(typeArgInference2.ts, 2, 1))
|
|
|
|
var z3 = foo({ name: null }); // { name: any }
|
|
>z3 : Symbol(z3, Decl(typeArgInference2.ts, 8, 3))
|
|
>foo : Symbol(foo, Decl(typeArgInference2.ts, 2, 1))
|
|
>name : Symbol(name, Decl(typeArgInference2.ts, 8, 14))
|
|
|
|
var z4 = foo({ name: "abc" }); // { name: string }
|
|
>z4 : Symbol(z4, Decl(typeArgInference2.ts, 9, 3))
|
|
>foo : Symbol(foo, Decl(typeArgInference2.ts, 2, 1))
|
|
>name : Symbol(name, Decl(typeArgInference2.ts, 9, 14))
|
|
|
|
var z5 = foo({ name: "abc", a: 5 }); // { name: string; a: number }
|
|
>z5 : Symbol(z5, Decl(typeArgInference2.ts, 10, 3))
|
|
>foo : Symbol(foo, Decl(typeArgInference2.ts, 2, 1))
|
|
>name : Symbol(name, Decl(typeArgInference2.ts, 10, 14))
|
|
>a : Symbol(a, Decl(typeArgInference2.ts, 10, 27))
|
|
|
|
var z6 = foo({ name: "abc", a: 5 }, { name: "def", b: 5 }); // error
|
|
>z6 : Symbol(z6, Decl(typeArgInference2.ts, 11, 3))
|
|
>foo : Symbol(foo, Decl(typeArgInference2.ts, 2, 1))
|
|
>name : Symbol(name, Decl(typeArgInference2.ts, 11, 14))
|
|
>a : Symbol(a, Decl(typeArgInference2.ts, 11, 27))
|
|
>name : Symbol(name, Decl(typeArgInference2.ts, 11, 37))
|
|
>b : Symbol(b, Decl(typeArgInference2.ts, 11, 50))
|
|
|