2016-04-18 22:18:34 +02:00
|
|
|
// This file was procedurally generated from the following sources:
|
|
|
|
// - src/annex-b-fns/global-update.case
|
|
|
|
// - src/annex-b-fns/global/if-decl-no-else.template
|
|
|
|
/*---
|
|
|
|
description: Variable binding value is updated following evaluation (IfStatement without an else clause in the global scope)
|
|
|
|
esid: sec-functiondeclarations-in-ifstatement-statement-clauses
|
|
|
|
flags: [generated, noStrict]
|
2016-07-12 01:37:42 +02:00
|
|
|
info: |
|
2016-04-18 22:18:34 +02:00
|
|
|
The following rules for IfStatement augment those in 13.6:
|
2016-07-12 01:37:42 +02:00
|
|
|
|
2016-04-18 22:18:34 +02:00
|
|
|
IfStatement[Yield, Return]:
|
|
|
|
if ( Expression[In, ?Yield] ) FunctionDeclaration[?Yield] else Statement[?Yield, ?Return]
|
|
|
|
if ( Expression[In, ?Yield] ) Statement[?Yield, ?Return] else FunctionDeclaration[?Yield]
|
|
|
|
if ( Expression[In, ?Yield] ) FunctionDeclaration[?Yield] else FunctionDeclaration[?Yield]
|
|
|
|
if ( Expression[In, ?Yield] ) FunctionDeclaration[?Yield]
|
2016-07-12 01:37:42 +02:00
|
|
|
|
2016-04-18 22:18:34 +02:00
|
|
|
|
|
|
|
B.3.3.2 Changes to GlobalDeclarationInstantiation
|
2016-07-12 01:37:42 +02:00
|
|
|
|
2016-04-18 22:18:34 +02:00
|
|
|
[...]
|
|
|
|
e. When the FunctionDeclaration f is evaluated, perform the following steps
|
|
|
|
in place of the FunctionDeclaration Evaluation algorithm provided in
|
|
|
|
14.1.21:
|
|
|
|
i. Let genv be the running execution context's VariableEnvironment.
|
|
|
|
ii. Let genvRec be genv's EnvironmentRecord.
|
|
|
|
iii. Let benv be the running execution context's LexicalEnvironment.
|
|
|
|
iv. Let benvRec be benv's EnvironmentRecord.
|
|
|
|
v. Let fobj be ! benvRec.GetBindingValue(F, false).
|
|
|
|
vi. Perform ? genvRec.SetMutableBinding(F, fobj, false).
|
|
|
|
vii. Return NormalCompletion(empty).
|
|
|
|
---*/
|
|
|
|
|
|
|
|
if (true) function f() { return 'declaration'; }
|
|
|
|
|
|
|
|
assert.sameValue(typeof f, 'function');
|
|
|
|
assert.sameValue(f(), 'declaration');
|