* 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
89 lines
1.3 KiB
Plaintext
89 lines
1.3 KiB
Plaintext
=== tests/cases/compiler/superAccess2.ts ===
|
|
class P {
|
|
>P : P
|
|
|
|
x() { }
|
|
>x : () => void
|
|
|
|
static y() { }
|
|
>y : () => void
|
|
}
|
|
|
|
class Q extends P {
|
|
>Q : Q
|
|
>P : P
|
|
|
|
xx = super;
|
|
>xx : any
|
|
>super : any
|
|
>super : P
|
|
> : any
|
|
|
|
static yy = super; // error for static initializer accessing super
|
|
>yy : any
|
|
>super : any
|
|
>super : any
|
|
> : any
|
|
|
|
// Super is not allowed in constructor args
|
|
constructor(public z = super, zz = super, zzz = () => super) {
|
|
>z : any
|
|
>super : any
|
|
>super : any
|
|
> : any
|
|
>zz : any
|
|
>super : any
|
|
>super : any
|
|
> : any
|
|
>zzz : () => any
|
|
>() => super : () => any
|
|
>super : any
|
|
>super : any
|
|
> : any
|
|
|
|
super();
|
|
>super() : void
|
|
>super : typeof P
|
|
}
|
|
|
|
foo(zz = super) {
|
|
>foo : (zz?: any) => void
|
|
>zz : any
|
|
>super : any
|
|
>super : P
|
|
> : any
|
|
|
|
super.x();
|
|
>super.x() : void
|
|
>super.x : () => void
|
|
>super : P
|
|
>x : () => void
|
|
|
|
super.y(); // error
|
|
>super.y() : any
|
|
>super.y : any
|
|
>super : P
|
|
>y : any
|
|
}
|
|
|
|
static bar(zz = super) {
|
|
>bar : (zz?: any) => void
|
|
>zz : any
|
|
>super : any
|
|
>super : typeof P
|
|
> : any
|
|
|
|
super.x(); // error
|
|
>super.x() : any
|
|
>super.x : any
|
|
>super : typeof P
|
|
>x : any
|
|
|
|
super.y();
|
|
>super.y() : void
|
|
>super.y : () => void
|
|
>super : typeof P
|
|
>y : () => void
|
|
}
|
|
}
|