left-hand-side-private-reference-readonly-accessor-property-and.js (1861B)
1 // This file was procedurally generated from the following sources: 2 // - src/logical-assignment-private/and.case 3 // - src/logical-assignment-private/default/getter.template 4 /*--- 5 description: Logical-and assignment with target being a private reference (to an accessor property with getter) 6 esid: sec-assignment-operators-runtime-semantics-evaluation 7 features: [class-fields-private, logical-assignment-operators] 8 flags: [generated] 9 info: | 10 sec-property-accessors-runtime-semantics-evaluation 11 MemberExpression : MemberExpression `.` PrivateIdentifier 12 13 1. Let _baseReference_ be the result of evaluating |MemberExpression|. 14 2. Let _baseValue_ be ? GetValue(_baseReference_). 15 3. Let _fieldNameString_ be the StringValue of |PrivateIdentifier|. 16 4. Return ! MakePrivateReference(_baseValue_, _fieldNameString_). 17 18 PutValue (V, W) 19 ... 20 5.b. If IsPrivateReference(_V_) is *true*, then 21 i. Return ? PrivateSet(_baseObj_, _V_.[[ReferencedName]], _W_). 22 23 PrivateSet (O, P, value) 24 ... 25 5.a. Assert: _entry_.[[Kind]] is ~accessor~. 26 b. If _entry_.[[Set]] is *undefined*, throw a *TypeError* exception. 27 28 29 sec-assignment-operators-runtime-semantics-evaluation 30 AssignmentExpression : LeftHandSideExpression &&= AssignmentExpression 31 1. Let _lref_ be the result of evaluating |LeftHandSideExpression|. 32 2. Let _lval_ be ? GetValue(_lref_). 33 3. Let _lbool_ be ! ToBoolean(_lval_). 34 4. If _lbool_ is *false*, return _lval_. 35 ... 36 7. Perform ? PutValue(_lref_, _rval_). 37 8. Return _rval_. 38 ---*/ 39 40 41 class C { 42 get #field() { 43 return true; 44 } 45 compoundAssignment() { 46 return this.#field &&= false; 47 } 48 } 49 50 const o = new C(); 51 assert.throws(TypeError, () => o.compoundAssignment(), "PutValue throws when storing the result if no setter"); 52 53 reportCompare(0, 0);