906cbd2715
* 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>
41 lines
1.6 KiB
TypeScript
41 lines
1.6 KiB
TypeScript
//// [classStaticBlock11.ts]
|
|
let getX;
|
|
class C {
|
|
#x = 1
|
|
constructor(x: number) {
|
|
this.#x = x;
|
|
}
|
|
|
|
static {
|
|
// getX has privileged access to #x
|
|
getX = (obj: C) => obj.#x;
|
|
}
|
|
}
|
|
|
|
|
|
//// [classStaticBlock11.js]
|
|
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
};
|
|
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
};
|
|
var _C_x;
|
|
let getX;
|
|
class C {
|
|
constructor(x) {
|
|
_C_x.set(this, 1);
|
|
__classPrivateFieldSet(this, _C_x, x, "f");
|
|
}
|
|
}
|
|
_C_x = new WeakMap();
|
|
(() => {
|
|
// getX has privileged access to #x
|
|
getX = (obj) => __classPrivateFieldGet(obj, _C_x, "f");
|
|
})();
|