TypeScript/tests/baselines/reference/classStaticBlock6.symbols
Wenlu Wang 906cbd2715
Proposal class static block support (#43370)
* Class static block (#9)

* Add types factory and parser

* Add some case

* Make class static block as a container

* Update cases

* Add visitor

* Add emitter and more compile target

* Check boundary of break and continue

* Add basic transformer

* Fix emit behavior

* Add more tests

* Add friend tests

* Update baseline

* Fix cr issues

* Accept baseline

* Add decorator and modifier check

* Add functional boundary check

* Fix conflict

* Fix computed prop name within context

* Add more tests

* Update baseline

* Avoid invalid test baseline

* Support use before initialize check

* wip

* Fix class static block context

* Fix checks

* Fix missing case

* Improve assert message

* Accept baseline

* Avoid new context

* Update diagnostic message

* Fix name collision

* Fix targets

* Avoid unnecessary files

* Add more case

* Add more test cases

* Fix strict mode function declaration

* Avoid private fields initializer if no private identifier references

* Avoid private fields and add more test case

* Add more case

* Add tests and support for related services functionality

* Fix this reference in static block

* Split parser diagnostic and binder diagnostic

Co-authored-by: Ron Buckton <ron.buckton@microsoft.com>
2021-06-25 09:24:05 -07:00

105 lines
2.3 KiB
Plaintext

=== tests/cases/conformance/classes/classStaticBlock/classStaticBlock6.ts ===
class B {
>B : Symbol(B, Decl(classStaticBlock6.ts, 0, 0))
static a = 1;
>a : Symbol(B.a, Decl(classStaticBlock6.ts, 0, 9))
}
class C extends B {
>C : Symbol(C, Decl(classStaticBlock6.ts, 2, 1))
>B : Symbol(B, Decl(classStaticBlock6.ts, 0, 0))
static {
let await = 1;
>await : Symbol(await, Decl(classStaticBlock6.ts, 6, 11))
let arguments = 1;
>arguments : Symbol(arguments, Decl(classStaticBlock6.ts, 7, 11))
let eval = 1;
>eval : Symbol(eval, Decl(classStaticBlock6.ts, 8, 11))
}
static {
await: if (true) {
}
arguments;
await;
super();
}
}
class CC {
>CC : Symbol(CC, Decl(classStaticBlock6.ts, 20, 1))
constructor () {
class C extends B {
>C : Symbol(C, Decl(classStaticBlock6.ts, 23, 20))
>B : Symbol(B, Decl(classStaticBlock6.ts, 0, 0))
static {
class CC extends B {
>CC : Symbol(CC, Decl(classStaticBlock6.ts, 25, 20))
>B : Symbol(B, Decl(classStaticBlock6.ts, 0, 0))
constructor () {
super();
>super : Symbol(B, Decl(classStaticBlock6.ts, 0, 0))
}
}
super();
}
}
}
}
async function foo () {
>foo : Symbol(foo, Decl(classStaticBlock6.ts, 35, 1))
class C extends B {
>C : Symbol(C, Decl(classStaticBlock6.ts, 37, 23))
>B : Symbol(B, Decl(classStaticBlock6.ts, 0, 0))
static {
arguments;
>arguments : Symbol(arguments)
await;
async function ff () {
>ff : Symbol(ff, Decl(classStaticBlock6.ts, 41, 18))
arguments;
>arguments : Symbol(arguments)
await;
}
}
}
}
function foo1 () {
>foo1 : Symbol(foo1, Decl(classStaticBlock6.ts, 49, 1))
class C extends B {
>C : Symbol(C, Decl(classStaticBlock6.ts, 51, 18))
>B : Symbol(B, Decl(classStaticBlock6.ts, 0, 0))
static {
arguments;
>arguments : Symbol(arguments)
function ff () {
>ff : Symbol(ff, Decl(classStaticBlock6.ts, 54, 22))
arguments;
>arguments : Symbol(arguments)
}
}
}
}