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>
75 lines
2.2 KiB
TypeScript
75 lines
2.2 KiB
TypeScript
//// [classStaticBlock17.ts]
|
|
let friendA: { getX(o: A): number, setX(o: A, v: number): void };
|
|
|
|
class A {
|
|
#x: number;
|
|
|
|
constructor (v: number) {
|
|
this.#x = v;
|
|
}
|
|
|
|
getX () {
|
|
return this.#x;
|
|
}
|
|
|
|
static {
|
|
friendA = {
|
|
getX(obj) { return obj.#x },
|
|
setX(obj, value) { obj.#x = value }
|
|
};
|
|
}
|
|
};
|
|
|
|
class B {
|
|
constructor(a: A) {
|
|
const x = friendA.getX(a); // ok
|
|
friendA.setX(a, x + 1); // ok
|
|
}
|
|
};
|
|
|
|
const a = new A(41);
|
|
const b = new B(a);
|
|
a.getX();
|
|
|
|
//// [classStaticBlock17.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 _A_x;
|
|
let friendA;
|
|
class A {
|
|
constructor(v) {
|
|
_A_x.set(this, void 0);
|
|
__classPrivateFieldSet(this, _A_x, v, "f");
|
|
}
|
|
getX() {
|
|
return __classPrivateFieldGet(this, _A_x, "f");
|
|
}
|
|
}
|
|
_A_x = new WeakMap();
|
|
(() => {
|
|
friendA = {
|
|
getX(obj) { return __classPrivateFieldGet(obj, _A_x, "f"); },
|
|
setX(obj, value) { __classPrivateFieldSet(obj, _A_x, value, "f"); }
|
|
};
|
|
})();
|
|
;
|
|
class B {
|
|
constructor(a) {
|
|
const x = friendA.getX(a); // ok
|
|
friendA.setX(a, x + 1); // ok
|
|
}
|
|
}
|
|
;
|
|
const a = new A(41);
|
|
const b = new B(a);
|
|
a.getX();
|