func-if-stmt-else-decl-eval-func-skip-early-err.js (1481B)
1 // This file was procedurally generated from the following sources: 2 // - src/annex-b-fns/eval-func-skip-early-err.case 3 // - src/annex-b-fns/eval-func/direct-if-stmt-else-decl.template 4 /*--- 5 description: Extension not observed when creation of variable binding would produce an early error (IfStatement with a declaration in the second statement position in eval code) 6 esid: sec-functiondeclarations-in-ifstatement-statement-clauses 7 flags: [generated, noStrict] 8 info: | 9 The following rules for IfStatement augment those in 13.6: 10 11 IfStatement[Yield, Return]: 12 if ( Expression[In, ?Yield] ) FunctionDeclaration[?Yield] else Statement[?Yield, ?Return] 13 if ( Expression[In, ?Yield] ) Statement[?Yield, ?Return] else FunctionDeclaration[?Yield] 14 if ( Expression[In, ?Yield] ) FunctionDeclaration[?Yield] else FunctionDeclaration[?Yield] 15 if ( Expression[In, ?Yield] ) FunctionDeclaration[?Yield] 16 17 18 B.3.3.3 Changes to EvalDeclarationInstantiation 19 20 [...] 21 ii. If replacing the FunctionDeclaration f with a VariableStatement that 22 has F as a BindingIdentifier would not produce any Early Errors for 23 body, then 24 [...] 25 ---*/ 26 var init, after; 27 28 (function() { 29 eval( 30 'let f = 123;\ 31 init = f;if (false) ; else function f() { }after = f;' 32 ); 33 }()); 34 35 assert.sameValue(init, 123, 'binding is not initialized to `undefined`'); 36 assert.sameValue(after, 123, 'value is not updated following evaluation'); 37 38 reportCompare(0, 0);