An execution context contains whatever implementation specific state is necessary to track the execution progress of its associated code. Each execution context has at least the state components listed in .
-
+ Each execution context is represented as an ExecutionContext Record, with at least the fields listed in .
+
- Component
+ Field Name
|
- Purpose
+ Value Type
+ |
+
+ Meaning
|
- code evaluation state
+ [[CodeEvaluationState]]
+ |
+
+ implementation-specific
|
Any state needed to perform, suspend, and resume evaluation of the code associated with this execution context.
@@ -11362,15 +11368,21 @@ Execution Contexts
|
- Function
+ [[Function]]
+ |
+
+ a function object | *null*
|
- If this execution context is evaluating the code of a function object, then the value of this component is that function object. If the context is evaluating the code of a |Script| or |Module|, the value is *null*.
+ If this execution context is evaluating the code of a function object, then the value of this field is that function object. If the context is evaluating the code of a |Script| or |Module|, the value is *null*.
|
- Realm
+ [[Realm]]
+ |
+
+ a Realm Record
|
The Realm Record from which associated code accesses ECMAScript resources.
@@ -11378,7 +11390,10 @@ Execution Contexts
|
- ScriptOrModule
+ [[ScriptOrModule]]
+ |
+
+ a Module Record | a Script Record | *null*
|
The Module Record or Script Record from which associated code originates. If there is no originating script or module, as is the case for the original execution context created in InitializeHostDefinedRealm, the value is *null*.
@@ -11388,22 +11403,28 @@ Execution Contexts
|
Evaluation of code by the running execution context may be suspended at various points defined within this specification. Once the running execution context has been suspended a different execution context may become the running execution context and commence evaluating its code. At some later time a suspended execution context may again become the running execution context and continue evaluating its code at the point where it had previously been suspended. Transition of the running execution context status among execution contexts usually occurs in stack-like last-in/first-out manner. However, some ECMAScript features require non-LIFO transitions of the running execution context.
- The value of the Realm component of the running execution context is also called the current Realm Record. The value of the Function component of the running execution context is also called the active function object.
- Execution contexts for ECMAScript code have the additional state components listed in .
-
+ The value of the [[Realm]] field of the running execution context is also called the current Realm Record. The value of the [[Function]] field of the running execution context is also called the active function object.
+ ExecutionContext Records for ECMAScript code have the additional fields listed in .
+
- Component
+ Field Name
+ |
+
+ Value Type
|
- Purpose
+ Meaning
|
- LexicalEnvironment
+ [[LexicalEnvironment]]
+ |
+
+ an Environment Record
|
Identifies the Environment Record used to resolve identifier references made by code within this execution context.
@@ -11411,7 +11432,10 @@ Execution Contexts
|
- VariableEnvironment
+ [[VariableEnvironment]]
+ |
+
+ an Environment Record
|
Identifies the Environment Record that holds bindings created by |VariableStatement|s within this execution context.
@@ -11419,7 +11443,10 @@ Execution Contexts
|
- PrivateEnvironment
+ [[PrivateEnvironment]]
+ |
+
+ a PrivateEnvironment Record or *null*
|
Identifies the PrivateEnvironment Record that holds Private Names created by |ClassElement|s in the nearest containing class. *null* if there is no containing class.
@@ -11428,22 +11455,27 @@ Execution Contexts
|
- The LexicalEnvironment and VariableEnvironment components of an execution context are always Environment Records.
- Execution contexts representing the evaluation of generator objects have the additional state components listed in .
-
+ ExecutionContext Records representing the evaluation of generator objects have the additional fields listed in .
+
- Component
+ Field Name
+ |
+
+ Value Type
|
- Purpose
+ Meaning
|
- Generator
+ [[Generator]]
+ |
+
+ an Object
|
The generator object that this execution context is evaluating.
@@ -11452,7 +11484,7 @@ Execution Contexts
|
- In most situations only the running execution context (the top of the execution context stack) is directly manipulated by algorithms within this specification. Hence when the terms “LexicalEnvironment”, and “VariableEnvironment” are used without qualification they are in reference to those components of the running execution context.
+ In most situations only the running execution context (the top of the execution context stack) is directly manipulated by algorithms within this specification.
An execution context is purely a specification mechanism and need not correspond to any particular artefact of an ECMAScript implementation. It is impossible for ECMAScript code to directly access or observe an execution context.
@@ -11464,8 +11496,8 @@ GetActiveScriptOrModule ( )
1. If the execution context stack is empty, return *null*.
- 1. Let _ec_ be the topmost execution context on the execution context stack whose ScriptOrModule component is not *null*.
- 1. If no such execution context exists, return *null*. Otherwise, return _ec_'s ScriptOrModule.
+ 1. Let _ec_ be the topmost execution context on the execution context stack whose [[ScriptOrModule]] field is not *null*.
+ 1. If no such execution context exists, return *null*. Otherwise, return _ec_.[[ScriptOrModule]].
@@ -11482,7 +11514,7 @@
1. If _env_ is not present or if _env_ is *undefined*, then
- 1. Set _env_ to the running execution context's LexicalEnvironment.
+ 1. Set _env_ to the [[LexicalEnvironment]] field of the running execution context.
1. Assert: _env_ is an Environment Record.
1. If the code matching the syntactic production that is being evaluated is contained in strict mode code, let _strict_ be *true*; else let _strict_ be *false*.
1. Return ? GetIdentifierReference(_env_, _name_, _strict_).
@@ -11499,7 +11531,7 @@ GetThisEnvironment ( )
It finds the Environment Record that currently supplies the binding of the keyword `this`.
- 1. Let _env_ be the running execution context's LexicalEnvironment.
+ 1. Let _env_ be the [[LexicalEnvironment]] field of the running execution context.
1. [id="step-getthisenvironment-loop"] Repeat,
1. Let _exists_ be _env_.HasThisBinding().
1. If _exists_ is *true*, return _env_.
@@ -11516,7 +11548,7 @@ GetThisEnvironment ( )
ResolveThisBinding ( )
1. Let _envRec_ be GetThisEnvironment().
@@ -11528,7 +11560,7 @@ ResolveThisBinding ( )
GetNewTarget ( )
1. Let _envRec_ be GetThisEnvironment().
@@ -11575,13 +11607,13 @@ Jobs and Host Operations to Enqueue Jobs
At any particular time, _scriptOrModule_ (a Script Record, a Module Record, or *null*) is the active script or module if all of the following conditions are true:
- GetActiveScriptOrModule() is _scriptOrModule_.
- - If _scriptOrModule_ is a Script Record or Module Record, let _ec_ be the topmost execution context on the execution context stack whose ScriptOrModule component is _scriptOrModule_. The Realm component of _ec_ is _scriptOrModule_.[[Realm]].
+ - If _scriptOrModule_ is a Script Record or Module Record, let _ec_ be the topmost execution context on the execution context stack whose [[ScriptOrModule]] field is _scriptOrModule_. The [[Realm]] field of _ec_ is _scriptOrModule_.[[Realm]].
At any particular time, an execution is prepared to evaluate ECMAScript code if all of the following conditions are true:
- The execution context stack is not empty.
- - The Realm component of the topmost execution context on the execution context stack is a Realm Record.
+ - The [[Realm]] field of the topmost execution context on the execution context stack is a Realm Record.
@@ -11720,10 +11752,10 @@ InitializeHostDefinedRealm ( )
1. Let _realm_ be CreateRealm().
- 1. Let _newContext_ be a new execution context.
- 1. Set the Function of _newContext_ to *null*.
- 1. Set the Realm of _newContext_ to _realm_.
- 1. Set the ScriptOrModule of _newContext_ to *null*.
+ 1. Let _newContext_ be a new ExecutionContext Record.
+ 1. Set _newContext_.[[Function]] to *null*.
+ 1. Set _newContext_.[[Realm]] to _realm_.
+ 1. Set _newContext_.[[ScriptOrModule]] to *null*.
1. Push _newContext_ onto the execution context stack; _newContext_ is now the running execution context.
1. If the host requires use of an exotic object to serve as _realm_'s global object, let _global_ be such an object created in a host-defined manner. Otherwise, let _global_ be *undefined*, indicating that an ordinary object should be created as the global object.
1. If the host requires that the `this` binding in _realm_'s global scope return an object other than the global object, let _thisValue_ be such an object created in a host-defined manner. Otherwise, let _thisValue_ be *undefined*, indicating that _realm_'s global `this` binding should be the global object.
@@ -12883,15 +12915,15 @@
1. Assert: Type(_newTarget_) is Undefined or Object.
1. Let _callerContext_ be the running execution context.
- 1. Let _calleeContext_ be a new ECMAScript code execution context.
- 1. Set the Function of _calleeContext_ to _F_.
+ 1. Let _calleeContext_ be a new ECMAScript code ExecutionContext Record.
+ 1. Set _calleeContext_.[[Function]] to _F_.
1. Let _calleeRealm_ be _F_.[[Realm]].
- 1. Set the Realm of _calleeContext_ to _calleeRealm_.
- 1. Set the ScriptOrModule of _calleeContext_ to _F_.[[ScriptOrModule]].
+ 1. Set _calleeContext_.[[Realm]] to _calleeRealm_.
+ 1. Set _calleeContext_.[[ScriptOrModule]] to _F_.[[ScriptOrModule]].
1. Let _localEnv_ be NewFunctionEnvironment(_F_, _newTarget_).
- 1. Set the LexicalEnvironment of _calleeContext_ to _localEnv_.
- 1. Set the VariableEnvironment of _calleeContext_ to _localEnv_.
- 1. Set the PrivateEnvironment of _calleeContext_ to _F_.[[PrivateEnvironment]].
+ 1. Set _calleeContext_.[[LexicalEnvironment]] to _localEnv_.
+ 1. Set _calleeContext_.[[VariableEnvironment]] to _localEnv_.
+ 1. Set _calleeContext_.[[PrivateEnvironment]] to _F_.[[PrivateEnvironment]].
1. If _callerContext_ is not already suspended, suspend _callerContext_.
1. Push _calleeContext_ onto the execution context stack; _calleeContext_ is now the running execution context.
1. NOTE: Any exception objects produced after this point are associated with _calleeRealm_.
@@ -12913,7 +12945,7 @@
1. Let _thisMode_ be _F_.[[ThisMode]].
1. If _thisMode_ is ~lexical~, return NormalCompletion(*undefined*).
1. Let _calleeRealm_ be _F_.[[Realm]].
- 1. Let _localEnv_ be the LexicalEnvironment of _calleeContext_.
+ 1. Let _localEnv_ be _calleeContext_.[[LexicalEnvironment]].
1. If _thisMode_ is ~strict~, let _thisValue_ be _thisArgument_.
1. Else,
1. If _thisArgument_ is *undefined* or *null*, then
@@ -13022,7 +13054,7 @@
1. If _initializeResult_ is an abrupt completion, then
1. Remove _calleeContext_ from the execution context stack and restore _callerContext_ as the running execution context.
1. Return Completion(_initializeResult_).
- 1. Let _constructorEnv_ be the LexicalEnvironment of _calleeContext_.
+ 1. Let _constructorEnv_ be _calleeContext_.[[LexicalEnvironment]].
1. Let _result_ be OrdinaryCallEvaluateBody(_F_, _argumentsList_).
1. Remove _calleeContext_ from the execution context stack and restore _callerContext_ as the running execution context.
1. If _result_.[[Type]] is ~return~, then
@@ -13289,13 +13321,13 @@
1. Set _argumentsObjectNeeded_ to *false*.
1. If _strict_ is *true* or if _hasParameterExpressions_ is *false*, then
1. NOTE: Only a single Environment Record is needed for the parameters and top-level vars.
- 1. Let _env_ be the LexicalEnvironment of _calleeContext_.
+ 1. Let _env_ be _calleeContext_.[[LexicalEnvironment]].
1. Else,
1. NOTE: A separate Environment Record is needed to ensure that bindings created by direct eval calls in the formal parameter list are outside the environment where parameters are declared.
- 1. Let _calleeEnv_ be the LexicalEnvironment of _calleeContext_.
+ 1. Let _calleeEnv_ be _calleeContext_.[[LexicalEnvironment]].
1. Let _env_ be NewDeclarativeEnvironment(_calleeEnv_).
- 1. Assert: The VariableEnvironment of _calleeContext_ is _calleeEnv_.
- 1. Set the LexicalEnvironment of _calleeContext_ to _env_.
+ 1. Assert: _calleeContext_.[[VariableEnvironment]] is _calleeEnv_.
+ 1. Set _calleeContext_.[[LexicalEnvironment]] to _env_.
1. For each String _paramName_ of _parameterNames_, do
1. Let _alreadyDeclared_ be _env_.HasBinding(_paramName_).
1. NOTE: Early errors ensure that duplicate parameter names can only occur in non-strict functions that do not have parameter default values or rest parameters.
@@ -13334,7 +13366,7 @@
1. Else,
1. NOTE: A separate Environment Record is needed to ensure that closures created by expressions in the formal parameter list do not have visibility of declarations in the function body.
1. Let _varEnv_ be NewDeclarativeEnvironment(_env_).
- 1. Set the VariableEnvironment of _calleeContext_ to _varEnv_.
+ 1. Set _calleeContext_.[[VariableEnvironment]] to _varEnv_.
1. Let _instantiatedVarNames_ be a new empty List.
1. For each element _n_ of _varNames_, do
1. If _n_ is not an element of _instantiatedVarNames_, then
@@ -13350,7 +13382,7 @@
1. Let _lexEnv_ be NewDeclarativeEnvironment(_varEnv_).
1. NOTE: Non-strict functions use a separate Environment Record for top-level lexical declarations so that a direct eval can determine whether any var scoped declarations introduced by the eval code conflict with pre-existing top-level lexically scoped declarations. This is not needed for strict functions because a strict direct eval always places all declarations into a new Environment Record.
1. Else, let _lexEnv_ be _varEnv_.
- 1. Set the LexicalEnvironment of _calleeContext_ to _lexEnv_.
+ 1. Set _calleeContext_.[[LexicalEnvironment]] to _lexEnv_.
1. Let _lexDeclarations_ be the LexicallyScopedDeclarations of _code_.
1. For each element _d_ of _lexDeclarations_, do
1. NOTE: A lexically declared name cannot be the same as a function/generator declaration, formal parameter, or a var name. Lexically declared names are only instantiated here but not initialized.
@@ -13359,7 +13391,7 @@
1. Perform ! _lexEnv_.CreateImmutableBinding(_dn_, *true*).
1. Else,
1. Perform ! _lexEnv_.CreateMutableBinding(_dn_, *false*).
- 1. Let _privateEnv_ be the PrivateEnvironment of _calleeContext_.
+ 1. Let _privateEnv_ be _calleeContext_.[[PrivateEnvironment]].
1. For each Parse Node _f_ of _functionsToInitialize_, do
1. Let _fn_ be the sole element of the BoundNames of _f_.
1. Let _fo_ be InstantiateFunctionObject of _f_ with arguments _lexEnv_ and _privateEnv_.
@@ -13397,11 +13429,11 @@
1. Let _callerContext_ be the running execution context.
1. If _callerContext_ is not already suspended, suspend _callerContext_.
- 1. Let _calleeContext_ be a new execution context.
- 1. Set the Function of _calleeContext_ to _F_.
+ 1. Let _calleeContext_ be a new ExecutionContext Record.
+ 1. Set _calleeContext_.[[Function]] to _F_.
1. Let _calleeRealm_ be _F_.[[Realm]].
- 1. Set the Realm of _calleeContext_ to _calleeRealm_.
- 1. Set the ScriptOrModule of _calleeContext_ to *null*.
+ 1. Set _calleeContext_.[[Realm]] to _calleeRealm_.
+ 1. Set _calleeContext_.[[ScriptOrModule]] to *null*.
1. Perform any necessary implementation-defined initialization of _calleeContext_.
1. Push _calleeContext_ onto the execution context stack; _calleeContext_ is now the running execution context.
1. [id="step-call-builtin-function-result"] Let _result_ be the Completion Record that is the result of evaluating _F_ in a manner that conforms to the specification of _F_. _thisArgument_ is the *this* value, _argumentsList_ provides the named parameters, and the NewTarget value is *undefined*.
@@ -19523,7 +19555,7 @@ Runtime Semantics: Evaluation
1. Let _rref_ be the result of evaluating |ShiftExpression|.
1. Let _rval_ be ? GetValue(_rref_).
1. If Type(_rval_) is not Object, throw a *TypeError* exception.
- 1. Let _privateEnv_ be the running execution context's PrivateEnvironment.
+ 1. Let _privateEnv_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _privateName_ be ! ResolvePrivateIdentifier(_privateEnv_, _privateIdentifier_).
1. If ! PrivateElementFind(_privateName_, _rval_) is not ~empty~, return *true*.
1. Return *false*.
@@ -20461,16 +20493,16 @@ Runtime Semantics: Evaluation
Block : `{` StatementList `}`
- 1. Let _oldEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _oldEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _blockEnv_ be NewDeclarativeEnvironment(_oldEnv_).
1. Perform BlockDeclarationInstantiation(|StatementList|, _blockEnv_).
- 1. Set the running execution context's LexicalEnvironment to _blockEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _blockEnv_.
1. Let _blockValue_ be the result of evaluating |StatementList|.
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Return _blockValue_.
- No matter how control leaves the |Block| the LexicalEnvironment is always restored to its former state.
+ No matter how control leaves the |Block| the [[LexicalEnvironment]] is always restored to its former state.
StatementList : StatementList StatementListItem
@@ -20512,7 +20544,7 @@
1. Assert: _env_ is a declarative Environment Record.
1. Let _declarations_ be the LexicallyScopedDeclarations of _code_.
- 1. Let _privateEnv_ be the running execution context's PrivateEnvironment.
+ 1. Let _privateEnv_ be the [[PrivateEnvironment]] field of the running execution context.
1. For each element _d_ of _declarations_, do
1. For each element _dn_ of the BoundNames of _d_, do
1. If IsConstantDeclaration of _d_ is *true*, then
@@ -20533,7 +20565,7 @@ Declarations and the Variable Statement
Let and Const Declarations
- `let` and `const` declarations define variables that are scoped to the running execution context's LexicalEnvironment. The variables are created when their containing Environment Record is instantiated but may not be accessed in any way until the variable's |LexicalBinding| is evaluated. A variable defined by a |LexicalBinding| with an |Initializer| is assigned the value of its |Initializer|'s |AssignmentExpression| when the |LexicalBinding| is evaluated, not when the variable is created. If a |LexicalBinding| in a `let` declaration does not have an |Initializer| the variable is assigned the value *undefined* when the |LexicalBinding| is evaluated.
+ `let` and `const` declarations define variables that are scoped to the [[LexicalEnvironment]] field of the running execution context. The variables are created when their containing Environment Record is instantiated but may not be accessed in any way until the variable's |LexicalBinding| is evaluated. A variable defined by a |LexicalBinding| with an |Initializer| is assigned the value of its |Initializer|'s |AssignmentExpression| when the |LexicalBinding| is evaluated, not when the variable is created. If a |LexicalBinding| in a `let` declaration does not have an |Initializer| the variable is assigned the value *undefined* when the |LexicalBinding| is evaluated.
Syntax
@@ -20609,7 +20641,7 @@ Runtime Semantics: Evaluation
1. Let _rhs_ be the result of evaluating |Initializer|.
1. Let _value_ be ? GetValue(_rhs_).
- 1. Let _env_ be the running execution context's LexicalEnvironment.
+ 1. Let _env_ be the [[LexicalEnvironment]] field of the running execution context.
1. Return the result of performing BindingInitialization for |BindingPattern| using _value_ and _env_ as the arguments.
@@ -20618,7 +20650,7 @@ Runtime Semantics: Evaluation
Variable Statement
- A `var` statement declares variables that are scoped to the running execution context's VariableEnvironment. Var variables are created when their containing Environment Record is instantiated and are initialized to *undefined* when created. Within the scope of any VariableEnvironment a common |BindingIdentifier| may appear in more than one |VariableDeclaration| but those declarations collectively define only one variable. A variable defined by a |VariableDeclaration| with an |Initializer| is assigned the value of its |Initializer|'s |AssignmentExpression| when the |VariableDeclaration| is executed, not when the variable is created.
+ A `var` statement declares variables that are scoped to the [[VariableEnvironment]] field of the running execution context. Var variables are created when their containing Environment Record is instantiated and are initialized to *undefined* when created. Within the scope of any [[VariableEnvironment]] a common |BindingIdentifier| may appear in more than one |VariableDeclaration| but those declarations collectively define only one variable. A variable defined by a |VariableDeclaration| with an |Initializer| is assigned the value of its |Initializer|'s |AssignmentExpression| when the |VariableDeclaration| is executed, not when the variable is created.
Syntax
@@ -20664,7 +20696,7 @@ Runtime Semantics: Evaluation
1. [id="step-vardecllist-evaluation-putvalue"] Return ? PutValue(_lhs_, _value_).
- If a |VariableDeclaration| is nested within a with statement and the |BindingIdentifier| in the |VariableDeclaration| is the same as a property name of the binding object of the with statement's object Environment Record, then step will assign _value_ to the property instead of assigning to the VariableEnvironment binding of the |Identifier|.
+ If a |VariableDeclaration| is nested within a with statement and the |BindingIdentifier| in the |VariableDeclaration| is the same as a property name of the binding object of the with statement's object Environment Record, then step will assign _value_ to the property instead of assigning to the [[VariableEnvironment]] binding of the |Identifier|.
VariableDeclaration : BindingPattern Initializer
@@ -21079,7 +21111,7 @@ Runtime Semantics: ForLoopEvaluation
ForStatement : `for` `(` LexicalDeclaration Expression? `;` Expression? `)` Statement
- 1. Let _oldEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _oldEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _loopEnv_ be NewDeclarativeEnvironment(_oldEnv_).
1. Let _isConst_ be IsConstantDeclaration of |LexicalDeclaration|.
1. Let _boundNames_ be the BoundNames of |LexicalDeclaration|.
@@ -21088,14 +21120,14 @@ Runtime Semantics: ForLoopEvaluation
1. Perform ! _loopEnv_.CreateImmutableBinding(_dn_, *true*).
1. Else,
1. Perform ! _loopEnv_.CreateMutableBinding(_dn_, *false*).
- 1. Set the running execution context's LexicalEnvironment to _loopEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _loopEnv_.
1. Let _forDcl_ be the result of evaluating |LexicalDeclaration|.
1. If _forDcl_ is an abrupt completion, then
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Return Completion(_forDcl_).
1. If _isConst_ is *false*, let _perIterationLets_ be _boundNames_; otherwise let _perIterationLets_ be « ».
1. Let _bodyResult_ be ForBodyEvaluation(the first |Expression|, the second |Expression|, |Statement|, _perIterationLets_, _labelSet_).
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Return Completion(_bodyResult_).
@@ -21140,7 +21172,7 @@
1. If _perIterationBindings_ has any elements, then
- 1. Let _lastIterationEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _lastIterationEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _outer_ be _lastIterationEnv_.[[OuterEnv]].
1. Assert: _outer_ is not *null*.
1. Let _thisIterationEnv_ be NewDeclarativeEnvironment(_outer_).
@@ -21148,7 +21180,7 @@
1. Perform ! _thisIterationEnv_.CreateMutableBinding(_bn_, *false*).
1. Let _lastValue_ be ? _lastIterationEnv_.GetBindingValue(_bn_, *true*).
1. Perform _thisIterationEnv_.InitializeBinding(_bn_, _lastValue_).
- 1. Set the running execution context's LexicalEnvironment to _thisIterationEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _thisIterationEnv_.
1. Return *undefined*.
@@ -21382,15 +21414,15 @@
- 1. Let _oldEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _oldEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. If _uninitializedBoundNames_ is not an empty List, then
1. Assert: _uninitializedBoundNames_ has no duplicate entries.
1. Let _newEnv_ be NewDeclarativeEnvironment(_oldEnv_).
1. For each String _name_ of _uninitializedBoundNames_, do
1. Perform ! _newEnv_.CreateMutableBinding(_name_, *false*).
- 1. Set the running execution context's LexicalEnvironment to _newEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _newEnv_.
1. Let _exprRef_ be the result of evaluating _expr_.
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Let _exprValue_ be ? GetValue(_exprRef_).
1. If _iterationKind_ is ~enumerate~, then
1. If _exprValue_ is *undefined* or *null*, then
@@ -21423,7 +21455,7 @@
1. If _iteratorKind_ is not present, set _iteratorKind_ to ~sync~.
- 1. Let _oldEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _oldEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _V_ be *undefined*.
1. Let _destructuring_ be IsDestructuring of _lhs_.
1. If _destructuring_ is *true* and if _lhsKind_ is ~assignment~, then
@@ -21444,7 +21476,7 @@
1. Assert: _lhs_ is a |ForDeclaration|.
1. Let _iterationEnv_ be NewDeclarativeEnvironment(_oldEnv_).
1. Perform ForDeclarationBindingInstantiation for _lhs_ passing _iterationEnv_ as the argument.
- 1. Set the running execution context's LexicalEnvironment to _iterationEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _iterationEnv_.
1. If _destructuring_ is *false*, then
1. Assert: _lhs_ binds a single name.
1. Let _lhsName_ be the sole element of BoundNames of _lhs_.
@@ -21467,7 +21499,7 @@
1. Assert: _lhs_ is a |ForDeclaration|.
1. Let _status_ be ForDeclarationBindingInitialization of _lhs_ with arguments _nextValue_ and _iterationEnv_.
1. If _status_ is an abrupt completion, then
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. If _iteratorKind_ is ~async~, return ? AsyncIteratorClose(_iteratorRecord_, _status_).
1. If _iterationKind_ is ~enumerate~, then
1. Return _status_.
@@ -21475,7 +21507,7 @@
1. Assert: _iterationKind_ is ~iterate~.
1. Return ? IteratorClose(_iteratorRecord_, _status_).
1. Let _result_ be the result of evaluating _stmt_.
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. If LoopContinues(_result_, _labelSet_) is *false*, then
1. If _iterationKind_ is ~enumerate~, then
1. Return Completion(UpdateEmpty(_result_, _V_)).
@@ -21799,15 +21831,15 @@ Runtime Semantics: Evaluation
1. Let _val_ be the result of evaluating |Expression|.
1. Let _obj_ be ? ToObject(? GetValue(_val_)).
- 1. Let _oldEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _oldEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _newEnv_ be NewObjectEnvironment(_obj_, *true*, _oldEnv_).
- 1. Set the running execution context's LexicalEnvironment to _newEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _newEnv_.
1. Let _C_ be the result of evaluating |Statement|.
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Return Completion(UpdateEmpty(_C_, *undefined*)).
- No matter how control leaves the embedded |Statement|, whether normally or by some form of abrupt completion or exception, the LexicalEnvironment is always restored to its former state.
+ No matter how control leaves the embedded |Statement|, whether normally or by some form of abrupt completion or exception, the [[LexicalEnvironment]] is always restored to its former state.
@@ -21937,16 +21969,16 @@ Runtime Semantics: Evaluation
1. Let _exprRef_ be the result of evaluating |Expression|.
1. Let _switchValue_ be ? GetValue(_exprRef_).
- 1. Let _oldEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _oldEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _blockEnv_ be NewDeclarativeEnvironment(_oldEnv_).
1. Perform BlockDeclarationInstantiation(|CaseBlock|, _blockEnv_).
- 1. Set the running execution context's LexicalEnvironment to _blockEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _blockEnv_.
1. Let _R_ be CaseBlockEvaluation of |CaseBlock| with argument _switchValue_.
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Return _R_.
- No matter how control leaves the |SwitchStatement| the LexicalEnvironment is always restored to its former state.
+ No matter how control leaves the |SwitchStatement| the [[LexicalEnvironment]] is always restored to its former state.
CaseClause : `case` Expression `:`
@@ -22149,17 +22181,17 @@ Runtime Semantics: CatchClauseEvaluation
With parameter _thrownValue_.
Catch : `catch` `(` CatchParameter `)` Block
- 1. Let _oldEnv_ be the running execution context's LexicalEnvironment.
+ 1. Let _oldEnv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _catchEnv_ be NewDeclarativeEnvironment(_oldEnv_).
1. For each element _argName_ of the BoundNames of |CatchParameter|, do
1. Perform ! _catchEnv_.CreateMutableBinding(_argName_, *false*).
- 1. Set the running execution context's LexicalEnvironment to _catchEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _catchEnv_.
1. Let _status_ be BindingInitialization of |CatchParameter| with arguments _thrownValue_ and _catchEnv_.
1. If _status_ is an abrupt completion, then
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Return Completion(_status_).
1. Let _B_ be the result of evaluating |Block|.
- 1. Set the running execution context's LexicalEnvironment to _oldEnv_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _oldEnv_.
1. Return Completion(_B_).
Catch : `catch` Block
@@ -22167,7 +22199,7 @@ Runtime Semantics: CatchClauseEvaluation
1. Return the result of evaluating |Block|.
- No matter how control leaves the |Block| the LexicalEnvironment is always restored to its former state.
+ No matter how control leaves the |Block| the [[LexicalEnvironment]] is always restored to its former state.
@@ -22644,8 +22676,8 @@ Runtime Semantics: InstantiateOrdinaryFunctionExpression
FunctionExpression : `function` `(` FormalParameters `)` `{` FunctionBody `}`
1. If _name_ is not present, set _name_ to *""*.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |FunctionExpression|.
1. Let _closure_ be OrdinaryFunctionCreate(%Function.prototype%, _sourceText_, |FormalParameters|, |FunctionBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform SetFunctionName(_closure_, _name_).
@@ -22656,10 +22688,10 @@ Runtime Semantics: InstantiateOrdinaryFunctionExpression
1. Assert: _name_ is not present.
1. Set _name_ to StringValue of |BindingIdentifier|.
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _funcEnv_ be NewDeclarativeEnvironment(_scope_).
1. Perform _funcEnv_.CreateImmutableBinding(_name_, *false*).
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |FunctionExpression|.
1. Let _closure_ be OrdinaryFunctionCreate(%Function.prototype%, _sourceText_, |FormalParameters|, |FunctionBody|, ~non-lexical-this~, _funcEnv_, _privateScope_).
1. Perform SetFunctionName(_closure_, _name_).
@@ -22786,8 +22818,8 @@ Runtime Semantics: InstantiateArrowFunctionExpression
ArrowFunction : ArrowParameters `=>` ConciseBody
1. If _name_ is not present, set _name_ to *""*.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |ArrowFunction|.
1. [id="step-arrowfunction-evaluation-functioncreate"] Let _closure_ be OrdinaryFunctionCreate(%Function.prototype%, _sourceText_, |ArrowParameters|, |ConciseBody|, ~lexical-this~, _scope_, _privateScope_).
1. Perform SetFunctionName(_closure_, _name_).
@@ -22915,8 +22947,8 @@ Runtime Semantics: DefineMethod
1. Let _propKey_ be the result of evaluating |ClassElementName|.
1. ReturnIfAbrupt(_propKey_).
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. If _functionPrototype_ is present, then
1. Let _prototype_ be _functionPrototype_.
1. Else,
@@ -22940,8 +22972,8 @@ Runtime Semantics: MethodDefinitionEvaluation
1. Let _propKey_ be the result of evaluating |ClassElementName|.
1. ReturnIfAbrupt(_propKey_).
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |MethodDefinition|.
1. Let _formalParameterList_ be an instance of the production FormalParameters : [empty].
1. Let _closure_ be OrdinaryFunctionCreate(%Function.prototype%, _sourceText_, _formalParameterList_, |FunctionBody|, ~non-lexical-this~, _scope_, _privateScope_).
@@ -22958,8 +22990,8 @@ Runtime Semantics: MethodDefinitionEvaluation
1. Let _propKey_ be the result of evaluating |ClassElementName|.
1. ReturnIfAbrupt(_propKey_).
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |MethodDefinition|.
1. Let _closure_ be OrdinaryFunctionCreate(%Function.prototype%, _sourceText_, |PropertySetParameterList|, |FunctionBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform MakeMethod(_closure_, _object_).
@@ -22975,8 +23007,8 @@ Runtime Semantics: MethodDefinitionEvaluation
1. Let _propKey_ be the result of evaluating |ClassElementName|.
1. ReturnIfAbrupt(_propKey_).
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |GeneratorMethod|.
1. Let _closure_ be OrdinaryFunctionCreate(%GeneratorFunction.prototype%, _sourceText_, |UniqueFormalParameters|, |GeneratorBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform MakeMethod(_closure_, _object_).
@@ -22991,8 +23023,8 @@ Runtime Semantics: MethodDefinitionEvaluation
1. Let _propKey_ be the result of evaluating |ClassElementName|.
1. ReturnIfAbrupt(_propKey_).
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncGeneratorMethod|.
1. Let _closure_ be ! OrdinaryFunctionCreate(%AsyncGeneratorFunction.prototype%, _sourceText_, |UniqueFormalParameters|, |AsyncGeneratorBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform ! MakeMethod(_closure_, _object_).
@@ -23007,8 +23039,8 @@ Runtime Semantics: MethodDefinitionEvaluation
1. Let _propKey_ be the result of evaluating |ClassElementName|.
1. ReturnIfAbrupt(_propKey_).
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncMethod|.
1. Let _closure_ be ! OrdinaryFunctionCreate(%AsyncFunction.prototype%, _sourceText_, |UniqueFormalParameters|, |AsyncFunctionBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform ! MakeMethod(_closure_, _object_).
@@ -23151,8 +23183,8 @@ Runtime Semantics: InstantiateGeneratorFunctionExpression
GeneratorExpression : `function` `*` `(` FormalParameters `)` `{` GeneratorBody `}`
1. If _name_ is not present, set _name_ to *""*.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |GeneratorExpression|.
1. Let _closure_ be OrdinaryFunctionCreate(%GeneratorFunction.prototype%, _sourceText_, |FormalParameters|, |GeneratorBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform SetFunctionName(_closure_, _name_).
@@ -23164,10 +23196,10 @@ Runtime Semantics: InstantiateGeneratorFunctionExpression
1. Assert: _name_ is not present.
1. Set _name_ to StringValue of |BindingIdentifier|.
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _funcEnv_ be NewDeclarativeEnvironment(_scope_).
1. Perform _funcEnv_.CreateImmutableBinding(_name_, *false*).
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |GeneratorExpression|.
1. Let _closure_ be OrdinaryFunctionCreate(%GeneratorFunction.prototype%, _sourceText_, |FormalParameters|, |GeneratorBody|, ~non-lexical-this~, _funcEnv_, _privateScope_).
1. Perform SetFunctionName(_closure_, _name_).
@@ -23365,8 +23397,8 @@ Runtime Semantics: InstantiateAsyncGeneratorFunctionExpression
1. If _name_ is not present, set _name_ to *""*.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncGeneratorExpression|.
1. Let _closure_ be ! OrdinaryFunctionCreate(%AsyncGeneratorFunction.prototype%, _sourceText_, |FormalParameters|, |AsyncGeneratorBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform SetFunctionName(_closure_, _name_).
@@ -23380,10 +23412,10 @@ Runtime Semantics: InstantiateAsyncGeneratorFunctionExpression
1. Assert: _name_ is not present.
1. Set _name_ to StringValue of |BindingIdentifier|.
- 1. Let _scope_ be the running execution context's LexicalEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _funcEnv_ be ! NewDeclarativeEnvironment(_scope_).
1. Perform ! _funcEnv_.CreateImmutableBinding(_name_, *false*).
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncGeneratorExpression|.
1. Let _closure_ be ! OrdinaryFunctionCreate(%AsyncGeneratorFunction.prototype%, _sourceText_, |FormalParameters|, |AsyncGeneratorBody|, ~non-lexical-this~, _funcEnv_, _privateScope_).
1. Perform ! SetFunctionName(_closure_, _name_).
@@ -23818,8 +23850,8 @@ Runtime Semantics: ClassFieldDefinitionEvaluation
1. ReturnIfAbrupt(_name_).
1. If |Initializer_opt| is present, then
1. Let _formalParameterList_ be an instance of the production FormalParameters : [empty].
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the empty sequence of Unicode code points.
1. Let _initializer_ be ! OrdinaryFunctionCreate(%Function.prototype%, _sourceText_, _formalParameterList_, |Initializer|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform MakeMethod(_initializer_, _homeObject_).
@@ -23873,11 +23905,11 @@ Runtime Semantics: ClassDefinitionEvaluation
ClassTail : ClassHeritage? `{` ClassBody? `}`
- 1. Let _env_ be the LexicalEnvironment of the running execution context.
+ 1. Let _env_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _classScope_ be NewDeclarativeEnvironment(_env_).
1. If _classBinding_ is not *undefined*, then
1. Perform _classScope_.CreateImmutableBinding(_classBinding_, *true*).
- 1. Let _outerPrivateEnvironment_ be the running execution context's PrivateEnvironment.
+ 1. Let _outerPrivateEnvironment_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _classPrivateEnvironment_ be NewPrivateEnvironment(_outerPrivateEnvironment_).
1. If |ClassBody_opt| is present, then
1. For each String _dn_ of the PrivateBoundIdentifiers of |ClassBody_opt|, do
@@ -23890,10 +23922,10 @@ Runtime Semantics: ClassDefinitionEvaluation
1. Let _protoParent_ be %Object.prototype%.
1. Let _constructorParent_ be %Function.prototype%.
1. Else,
- 1. Set the running execution context's LexicalEnvironment to _classScope_.
- 1. NOTE: The running execution context's PrivateEnvironment is _outerPrivateEnvironment_ when evaluating |ClassHeritage|.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _classScope_.
+ 1. NOTE: The running execution context's [[PrivateEnvironment]] is _outerPrivateEnvironment_ when evaluating |ClassHeritage|.
1. Let _superclassRef_ be the result of evaluating |ClassHeritage|.
- 1. Set the running execution context's LexicalEnvironment to _env_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _env_.
1. Let _superclass_ be ? GetValue(_superclassRef_).
1. If _superclass_ is *null*, then
1. Let _protoParent_ be *null*.
@@ -23906,8 +23938,8 @@ Runtime Semantics: ClassDefinitionEvaluation
1. Let _proto_ be ! OrdinaryObjectCreate(_protoParent_).
1. If |ClassBody_opt| is not present, let _constructor_ be ~empty~.
1. Else, let _constructor_ be ConstructorMethod of |ClassBody|.
- 1. Set the running execution context's LexicalEnvironment to _classScope_.
- 1. Set the running execution context's PrivateEnvironment to _classPrivateEnvironment_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _classScope_.
+ 1. Set the [[PrivateEnvironment]] field of the running execution context to _classPrivateEnvironment_.
1. If _constructor_ is ~empty~, then
1. Let _defaultConstructor_ be a new Abstract Closure with no parameters that captures nothing and performs the following steps when called:
1. Let _args_ be the List of arguments that was passed to this function by [[Call]] or [[Construct]].
@@ -23942,8 +23974,8 @@ Runtime Semantics: ClassDefinitionEvaluation
1. Else,
1. Let _field_ be ClassElementEvaluation of _e_ with arguments _F_ and *false*.
1. If _field_ is an abrupt completion, then
- 1. Set the running execution context's LexicalEnvironment to _env_.
- 1. Set the running execution context's PrivateEnvironment to _outerPrivateEnvironment_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _env_.
+ 1. Set the [[PrivateEnvironment]] field of the running execution context to _outerPrivateEnvironment_.
1. Return Completion(_field_).
1. Set _field_ to _field_.[[Value]].
1. If _field_ is a PrivateElement, then
@@ -23963,7 +23995,7 @@ Runtime Semantics: ClassDefinitionEvaluation
1. Else if _field_ is a ClassFieldDefinition Record, then
1. If IsStatic of _e_ is *false*, append _field_ to _instanceFields_.
1. Else, append _field_ to _staticFields_.
- 1. Set the running execution context's LexicalEnvironment to _env_.
+ 1. Set the [[LexicalEnvironment]] field of the running execution context to _env_.
1. If _classBinding_ is not *undefined*, then
1. Perform _classScope_.InitializeBinding(_classBinding_, _F_).
1. Set _F_.[[PrivateMethods]] to _instancePrivateMethods_.
@@ -23973,9 +24005,9 @@ Runtime Semantics: ClassDefinitionEvaluation
1. For each element _fieldRecord_ of _staticFields_, do
1. Let _result_ be DefineField(_F_, _fieldRecord_).
1. If _result_ is an abrupt completion, then
- 1. Set the running execution context's PrivateEnvironment to _outerPrivateEnvironment_.
+ 1. Set the [[PrivateEnvironment]] field of the running execution context to _outerPrivateEnvironment_.
1. Return _result_.
- 1. Set the running execution context's PrivateEnvironment to _outerPrivateEnvironment_.
+ 1. Set the [[PrivateEnvironment]] field of the running execution context to _outerPrivateEnvironment_.
1. Return _F_.
@@ -23987,7 +24019,7 @@ Runtime Semantics: BindingClassDeclarationEvaluation
1. Let _className_ be StringValue of |BindingIdentifier|.
1. Let _value_ be ? ClassDefinitionEvaluation of |ClassTail| with arguments _className_ and _className_.
1. Set _value_.[[SourceText]] to the source text matched by |ClassDeclaration|.
- 1. Let _env_ be the running execution context's LexicalEnvironment.
+ 1. Let _env_ be the [[LexicalEnvironment]] field of the running execution context.
1. Perform ? InitializeBoundName(_className_, _value_, _env_).
1. Return _value_.
@@ -24028,7 +24060,7 @@ Runtime Semantics: Evaluation
ClassElementName : PrivateIdentifier
1. Let _privateIdentifier_ be StringValue of |PrivateIdentifier|.
- 1. Let _privateEnvRec_ be the running execution context's PrivateEnvironment.
+ 1. Let _privateEnvRec_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _names_ be _privateEnvRec_.[[Names]].
1. Assert: Exactly one element of _names_ is a Private Name whose [[Description]] is _privateIdentifier_.
1. Let _privateName_ be the Private Name in _names_ whose [[Description]] is _privateIdentifier_.
@@ -24139,8 +24171,8 @@ Runtime Semantics: InstantiateAsyncFunctionExpression
1. If _name_ is not present, set _name_ to *""*.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncFunctionExpression|.
1. Let _closure_ be ! OrdinaryFunctionCreate(%AsyncFunction.prototype%, _sourceText_, |FormalParameters|, |AsyncFunctionBody|, ~non-lexical-this~, _scope_, _privateScope_).
1. Perform SetFunctionName(_closure_, _name_).
@@ -24152,10 +24184,10 @@ Runtime Semantics: InstantiateAsyncFunctionExpression
1. Assert: _name_ is not present.
1. Set _name_ to StringValue of |BindingIdentifier|.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _funcEnv_ be ! NewDeclarativeEnvironment(_scope_).
1. Perform ! _funcEnv_.CreateImmutableBinding(_name_, *false*).
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncFunctionExpression|.
1. Let _closure_ be ! OrdinaryFunctionCreate(%AsyncFunction.prototype%, _sourceText_, |FormalParameters|, |AsyncFunctionBody|, ~non-lexical-this~, _funcEnv_, _privateScope_).
1. Perform ! SetFunctionName(_closure_, _name_).
@@ -24304,8 +24336,8 @@ Runtime Semantics: InstantiateAsyncArrowFunctionExpression
1. If _name_ is not present, set _name_ to *""*.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncArrowFunction|.
1. Let _parameters_ be |AsyncArrowBindingIdentifier|.
1. Let _closure_ be ! OrdinaryFunctionCreate(%AsyncFunction.prototype%, _sourceText_, _parameters_, |AsyncConciseBody|, ~lexical-this~, _scope_, _privateScope_).
@@ -24317,8 +24349,8 @@ Runtime Semantics: InstantiateAsyncArrowFunctionExpression
1. If _name_ is not present, set _name_ to *""*.
- 1. Let _scope_ be the LexicalEnvironment of the running execution context.
- 1. Let _privateScope_ be the running execution context's PrivateEnvironment.
+ 1. Let _scope_ be the [[LexicalEnvironment]] field of the running execution context.
+ 1. Let _privateScope_ be the [[PrivateEnvironment]] field of the running execution context.
1. Let _sourceText_ be the source text matched by |AsyncArrowFunction|.
1. Let _head_ be the |AsyncArrowHead| that is covered by |CoverCallExpressionAndAsyncArrowHead|.
1. Let _parameters_ be the |ArrowFormalParameters| of _head_.
@@ -24868,13 +24900,13 @@
1. Let _globalEnv_ be _scriptRecord_.[[Realm]].[[GlobalEnv]].
- 1. Let _scriptContext_ be a new ECMAScript code execution context.
- 1. Set the Function of _scriptContext_ to *null*.
- 1. Set the Realm of _scriptContext_ to _scriptRecord_.[[Realm]].
- 1. Set the ScriptOrModule of _scriptContext_ to _scriptRecord_.
- 1. Set the VariableEnvironment of _scriptContext_ to _globalEnv_.
- 1. Set the LexicalEnvironment of _scriptContext_ to _globalEnv_.
- 1. Set the PrivateEnvironment of _scriptContext_ to *null*.
+ 1. Let _scriptContext_ be a new ECMAScript code ExecutionContext Record.
+ 1. Set _scriptContext_.[[Function]] to *null*.
+ 1. Set _scriptContext_.[[Realm]] to _scriptRecord_.[[Realm]].
+ 1. Set _scriptContext_.[[ScriptOrModule]] to _scriptRecord_.
+ 1. Set _scriptContext_.[[VariableEnvironment]] to _globalEnv_.
+ 1. Set _scriptContext_.[[LexicalEnvironment]] to _globalEnv_.
+ 1. Set _scriptContext_.[[PrivateEnvironment]] to *null*.
1. Suspend the currently running execution context.
1. Push _scriptContext_ onto the execution context stack; _scriptContext_ is now the running execution context.
1. Let _scriptBody_ be _scriptRecord_.[[ECMAScriptCode]].
@@ -26200,14 +26232,14 @@ InitializeEnvironment ( )
1. Call _env_.InitializeBinding(_in_.[[LocalName]], _namespace_).
1. Else,
1. Call _env_.CreateImportBinding(_in_.[[LocalName]], _resolution_.[[Module]], _resolution_.[[BindingName]]).
- 1. Let _moduleContext_ be a new ECMAScript code execution context.
- 1. Set the Function of _moduleContext_ to *null*.
+ 1. Let _moduleContext_ be a new ECMAScript code ExecutionContext Record.
+ 1. Set _moduleContext_.[[Function]] to *null*.
1. Assert: _module_.[[Realm]] is not *undefined*.
- 1. Set the Realm of _moduleContext_ to _module_.[[Realm]].
- 1. Set the ScriptOrModule of _moduleContext_ to _module_.
- 1. Set the VariableEnvironment of _moduleContext_ to _module_.[[Environment]].
- 1. Set the LexicalEnvironment of _moduleContext_ to _module_.[[Environment]].
- 1. Set the PrivateEnvironment of _moduleContext_ to *null*.
+ 1. Set _moduleContext_.[[Realm]] to _module_.[[Realm]].
+ 1. Set _moduleContext_.[[ScriptOrModule]] to _module_.
+ 1. Set _moduleContext_.[[VariableEnvironment]] to _module_.[[Environment]].
+ 1. Set _moduleContext_.[[LexicalEnvironment]] to _module_.[[Environment]].
+ 1. Set _moduleContext_.[[PrivateEnvironment]] to *null*.
1. Set _module_.[[Context]] to _moduleContext_.
1. Push _moduleContext_ onto the execution context stack; _moduleContext_ is now the running execution context.
1. Let _code_ be _module_.[[ECMAScriptCode]].
@@ -26271,7 +26303,7 @@
<button type="button" onclick="import('./foo.mjs')">Click me</button>
-
there will be no active script or module at the time the `import()` expression runs. More generally, this can happen in any situation where the host pushes execution contexts with *null* ScriptOrModule components onto the execution context stack.
+ there will be no active script or module at the time the `import()` expression runs. More generally, this can happen in any situation where the host pushes an ExecutionContext Record with a *null* [[ScriptOrModule]] field onto the execution context stack.
The implementation of HostResolveImportedModule must conform to the following requirements:
@@ -26917,7 +26949,7 @@ Runtime Semantics: Evaluation
1. Let _value_ be ? BindingClassDeclarationEvaluation of |ClassDeclaration|.
1. Let _className_ be the sole element of BoundNames of |ClassDeclaration|.
1. If _className_ is *"\*default\*"*, then
- 1. Let _env_ be the running execution context's LexicalEnvironment.
+ 1. Let _env_ be the [[LexicalEnvironment]] field of the running execution context.
1. Perform ? InitializeBoundName(*"\*default\*"*, _value_, _env_).
1. Return NormalCompletion(~empty~).
@@ -26928,7 +26960,7 @@ Runtime Semantics: Evaluation
1. Else,
1. Let _rhs_ be the result of evaluating |AssignmentExpression|.
1. Let _value_ be ? GetValue(_rhs_).
- 1. Let _env_ be the running execution context's LexicalEnvironment.
+ 1. Let _env_ be the [[LexicalEnvironment]] field of the running execution context.
1. Perform ? InitializeBoundName(*"\*default\*"*, _value_, _env_).
1. Return NormalCompletion(~empty~).
@@ -27065,7 +27097,7 @@ eval ( _x_ )
1. Assert: The execution context stack has at least two elements.
1. Let _callerContext_ be the second to top element of the execution context stack.
- 1. Let _callerRealm_ be _callerContext_'s Realm.
+ 1. Let _callerRealm_ be _callerContext_.[[Realm]].
1. Return ? PerformEval(_x_, _callerRealm_, *false*, *false*).
@@ -27112,22 +27144,22 @@
1. Let _runningContext_ be the running execution context.
1. NOTE: If _direct_ is *true*, _runningContext_ will be the execution context that performed the direct eval. If _direct_ is *false*, _runningContext_ will be the execution context for the invocation of the `eval` function.
1. If _direct_ is *true*, then
- 1. Let _lexEnv_ be NewDeclarativeEnvironment(_runningContext_'s LexicalEnvironment).
- 1. Let _varEnv_ be _runningContext_'s VariableEnvironment.
- 1. Let _privateEnv_ be _runningContext_'s PrivateEnvironment.
+ 1. Let _lexEnv_ be NewDeclarativeEnvironment(_runningContext_.[[LexicalEnvironment]]).
+ 1. Let _varEnv_ be _runningContext_.[[VariableEnvironment]].
+ 1. Let _privateEnv_ be _runningContext_.[[PrivateEnvironment]].
1. Else,
1. Let _lexEnv_ be NewDeclarativeEnvironment(_evalRealm_.[[GlobalEnv]]).
1. Let _varEnv_ be _evalRealm_.[[GlobalEnv]].
1. Let _privateEnv_ be *null*.
1. If _strictEval_ is *true*, set _varEnv_ to _lexEnv_.
1. If _runningContext_ is not already suspended, suspend _runningContext_.
- 1. Let _evalContext_ be a new ECMAScript code execution context.
- 1. Set _evalContext_'s Function to *null*.
- 1. Set _evalContext_'s Realm to _evalRealm_.
- 1. Set _evalContext_'s ScriptOrModule to _runningContext_'s ScriptOrModule.
- 1. Set _evalContext_'s VariableEnvironment to _varEnv_.
- 1. Set _evalContext_'s LexicalEnvironment to _lexEnv_.
- 1. Set _evalContext_'s PrivateEnvironment to _privateEnv_.
+ 1. Let _evalContext_ be a new ECMAScript code ExecutionContext Record.
+ 1. Set _evalContext_.[[Function]] to *null*.
+ 1. Set _evalContext_.[[Realm]] to _evalRealm_.
+ 1. Set _evalContext_.[[ScriptOrModule]] to _runningContext_.[[ScriptOrModule]].
+ 1. Set _evalContext_.[[VariableEnvironment]] to _varEnv_.
+ 1. Set _evalContext_.[[LexicalEnvironment]] to _lexEnv_.
+ 1. Set _evalContext_.[[PrivateEnvironment]] to _privateEnv_.
1. Push _evalContext_ onto the execution context stack; _evalContext_ is now the running execution context.
1. Let _result_ be EvalDeclarationInstantiation(_body_, _varEnv_, _lexEnv_, _privateEnv_, _strictEval_).
1. If _result_.[[Type]] is ~normal~, then
@@ -27139,7 +27171,7 @@
1. Return Completion(_result_).
- The eval code cannot instantiate variable or function bindings in the variable environment of the calling context that invoked the eval if either the code of the calling context or the eval code is strict mode code. Instead such bindings are instantiated in a new VariableEnvironment that is only accessible to the eval code. Bindings introduced by `let`, `const`, or `class` declarations are always instantiated in a new LexicalEnvironment.
+ The eval code cannot instantiate variable or function bindings in the variable environment of the calling context that invoked the eval if either the code of the calling context or the eval code is strict mode code. Instead such bindings are instantiated in a new [[VariableEnvironment]] that is only accessible to the eval code. Bindings introduced by `let`, `const`, or `class` declarations are always instantiated in a new [[LexicalEnvironment]].
@@ -28427,7 +28459,7 @@
1. Assert: The execution context stack has at least two elements.
1. Let _callerContext_ be the second to top element of the execution context stack.
- 1. Let _callerRealm_ be _callerContext_'s Realm.
+ 1. Let _callerRealm_ be _callerContext_.[[Realm]].
1. Let _calleeRealm_ be the current Realm Record.
1. Perform ? HostEnsureCanCompileStrings(_callerRealm_, _calleeRealm_).
1. If _newTarget_ is *undefined*, set _newTarget_ to _constructor_.
@@ -43117,8 +43149,8 @@
1. Assert: The value of _generator_.[[GeneratorState]] is *undefined*.
1. Let _genContext_ be the running execution context.
- 1. Set the Generator component of _genContext_ to _generator_.
- 1. Set the code evaluation state of _genContext_ such that when evaluation is resumed for that execution context the following steps will be performed:
+ 1. Set _genContext_.[[Generator]] to _generator_.
+ 1. Set _genContext_.[[CodeEvaluationState]] such that when evaluation is resumed for that execution context the following steps will be performed:
1. If _generatorBody_ is a Parse Node, then
1. Let _result_ be the result of evaluating _generatorBody_.
1. Else,
@@ -43223,8 +43255,8 @@ GetGeneratorKind ( )
1. Let _genContext_ be the running execution context.
- 1. If _genContext_ does not have a Generator component, return ~non-generator~.
- 1. Let _generator_ be the Generator component of _genContext_.
+ 1. If _genContext_ does not have a [[Generator]] field, return ~non-generator~.
+ 1. Let _generator_ be _genContext_.[[Generator]].
1. If _generator_ has an [[AsyncGeneratorState]] internal slot, return ~async~.
1. Else, return ~sync~.
@@ -43242,11 +43274,11 @@
1. Assert: _iterNextObj_ is an Object that implements the IteratorResult interface.
1. Let _genContext_ be the running execution context.
1. Assert: _genContext_ is the execution context of a generator.
- 1. Let _generator_ be the value of the Generator component of _genContext_.
+ 1. Let _generator_ be _genContext_.[[Generator]].
1. Assert: GetGeneratorKind() is ~sync~.
1. Set _generator_.[[GeneratorState]] to ~suspendedYield~.
1. Remove _genContext_ from the execution context stack and restore the execution context that is at the top of the execution context stack as the running execution context.
- 1. Set the code evaluation state of _genContext_ such that when evaluation is resumed with a Completion _resumptionValue_ the following steps will be performed:
+ 1. Set _genContext_.[[CodeEvaluationState]] such that when evaluation is resumed with a Completion _resumptionValue_ the following steps will be performed:
1. Return _resumptionValue_.
1. NOTE: This returns to the evaluation of the |YieldExpression| that originally called this abstract operation.
1. Return NormalCompletion(_iterNextObj_).
@@ -43286,10 +43318,10 @@
1. Set _generator_.[[GeneratorBrand]] to _generatorBrand_.
1. Set _generator_.[[GeneratorState]] to *undefined*.
1. Let _callerContext_ be the running execution context.
- 1. Let _calleeContext_ be a new execution context.
- 1. Set the Function of _calleeContext_ to *null*.
- 1. Set the Realm of _calleeContext_ to the current Realm Record.
- 1. Set the ScriptOrModule of _calleeContext_ to _callerContext_'s ScriptOrModule.
+ 1. Let _calleeContext_ be a new ExecutionContext Record.
+ 1. Set _calleeContext_.[[Function]] to *null*.
+ 1. Set _calleeContext_.[[Realm]] to the current Realm Record.
+ 1. Set _calleeContext_.[[ScriptOrModule]] to _callerContext_.[[ScriptOrModule]].
1. If _callerContext_ is not already suspended, suspend _callerContext_.
1. Push _calleeContext_ onto the execution context stack; _calleeContext_ is now the running execution context.
1. Perform ! GeneratorStart(_generator_, _closure_).
@@ -43470,8 +43502,8 @@
1. Assert: _generator_ is an AsyncGenerator instance.
1. Assert: _generator_.[[AsyncGeneratorState]] is *undefined*.
1. Let _genContext_ be the running execution context.
- 1. Set the Generator component of _genContext_ to _generator_.
- 1. Set the code evaluation state of _genContext_ such that when evaluation is resumed for that execution context the following steps will be performed:
+ 1. Set _genContext_.[[Generator]] to _generator_.
+ 1. Set _genContext_.[[CodeEvaluationState]] such that when evaluation is resumed for that execution context the following steps will be performed:
1. If _generatorBody_ is a Parse Node, then
1. Let _result_ be the result of evaluating _generatorBody_.
1. Else,
@@ -43548,10 +43580,10 @@
1. Else,
1. Assert: _completion_.[[Type]] is ~normal~.
1. If _realm_ is present, then
- 1. Let _oldRealm_ be the running execution context's Realm.
- 1. Set the running execution context's Realm to _realm_.
+ 1. Let _oldRealm_ be the [[Realm]] field of the running execution context.
+ 1. Set the [[Realm]] field of the running execution context to _realm_.
1. Let _iteratorResult_ be ! CreateIterResultObject(_value_, _done_).
- 1. Set the running execution context's Realm to _oldRealm_.
+ 1. Set the [[Realm]] field of the running execution context to _oldRealm_.
1. Else,
1. Let _iteratorResult_ be ! CreateIterResultObject(_value_, _done_).
1. Perform ! Call(_promiseCapability_.[[Resolve]], *undefined*, « _iteratorResult_ »).
@@ -43608,13 +43640,13 @@
1. Let _genContext_ be the running execution context.
1. Assert: _genContext_ is the execution context of a generator.
- 1. Let _generator_ be the value of the Generator component of _genContext_.
+ 1. Let _generator_ be _genContext_.[[Generator]].
1. Assert: GetGeneratorKind() is ~async~.
1. Set _value_ to ? Await(_value_).
1. Let _completion_ be NormalCompletion(_value_).
1. Assert: The execution context stack has at least two elements.
1. Let _previousContext_ be the second to top element of the execution context stack.
- 1. Let _previousRealm_ be _previousContext_'s Realm.
+ 1. Let _previousRealm_ be _previousContext_.[[Realm]].
1. Perform ! AsyncGeneratorCompleteStep(_generator_, _completion_, *false*, _previousRealm_).
1. Let _queue_ be _generator_.[[AsyncGeneratorQueue]].
1. If _queue_ is not empty, then
@@ -43625,7 +43657,7 @@
1. Else,
1. Set _generator_.[[AsyncGeneratorState]] to ~suspendedYield~.
1. Remove _genContext_ from the execution context stack and restore the execution context that is at the top of the execution context stack as the running execution context.
- 1. Set the code evaluation state of _genContext_ such that when evaluation is resumed with a Completion _resumptionValue_ the following steps will be performed:
+ 1. Set _genContext_.[[CodeEvaluationState]] such that when evaluation is resumed with a Completion _resumptionValue_ the following steps will be performed:
1. Return AsyncGeneratorUnwrapYieldResumption(_resumptionValue_).
1. NOTE: When the above step returns, it returns to the evaluation of the |YieldExpression| production that originally called this abstract operation.
1. Return *undefined*.
@@ -43713,10 +43745,10 @@
1. Set _generator_.[[GeneratorBrand]] to _generatorBrand_.
1. Set _generator_.[[AsyncGeneratorState]] to *undefined*.
1. Let _callerContext_ be the running execution context.
- 1. Let _calleeContext_ be a new execution context.
- 1. Set the Function of _calleeContext_ to *null*.
- 1. Set the Realm of _calleeContext_ to the current Realm Record.
- 1. Set the ScriptOrModule of _calleeContext_ to _callerContext_'s ScriptOrModule.
+ 1. Let _calleeContext_ be a new ExecutionContext Record.
+ 1. Set _calleeContext_.[[Function]] to *null*.
+ 1. Set _calleeContext_.[[Realm]] to the current Realm Record.
+ 1. Set _calleeContext_.[[ScriptOrModule]] to _callerContext_.[[ScriptOrModule]].
1. If _callerContext_ is not already suspended, suspend _callerContext_.
1. Push _calleeContext_ onto the execution context stack; _calleeContext_ is now the running execution context.
1. Perform ! AsyncGeneratorStart(_generator_, _closure_).
@@ -43840,7 +43872,7 @@
1. Let _runningContext_ be the running execution context.
1. Let _asyncContext_ be a copy of _runningContext_.
1. NOTE: Copying the execution state is required for the step below to resume its execution. It is ill-defined to resume a currently executing context.
- 1. Set the code evaluation state of _asyncContext_ such that when evaluation is resumed for that execution context the following steps will be performed:
+ 1. Set _asyncContext_.[[CodeEvaluationState]] such that when evaluation is resumed for that execution context the following steps will be performed:
1. Let _result_ be the result of evaluating _asyncFunctionBody_.
1. Assert: If we return here, the async function either threw an exception or performed an implicit or explicit return; all awaiting is done.
1. Remove _asyncContext_ from the execution context stack and restore the execution context that is at the top of the execution context stack as the running execution context.
@@ -46244,8 +46276,8 @@ Changes to FunctionDeclarationInstantiation
1. Perform _varEnv_.InitializeBinding(_F_, *undefined*).
1. Append _F_ to _instantiatedVarNames_.
1. When the |FunctionDeclaration| _f_ is evaluated, perform the following steps in place of the |FunctionDeclaration| Evaluation algorithm provided in :
- 1. Let _fenv_ be the running execution context's VariableEnvironment.
- 1. Let _benv_ be the running execution context's LexicalEnvironment.
+ 1. Let _fenv_ be the [[VariableEnvironment]] field of the running execution context.
+ 1. Let _benv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _fobj_ be ! _benv_.GetBindingValue(_F_, *false*).
1. Perform ! _fenv_.SetMutableBinding(_F_, _fobj_, *false*).
1. Return NormalCompletion(~empty~).
@@ -46269,8 +46301,8 @@ Changes to GlobalDeclarationInstantiation
1. Perform ? _env_.CreateGlobalVarBinding(_F_, *false*).
1. Append _F_ to _declaredFunctionOrVarNames_.
1. When the |FunctionDeclaration| _f_ is evaluated, perform the following steps in place of the |FunctionDeclaration| Evaluation algorithm provided in :
- 1. Let _genv_ be the running execution context's VariableEnvironment.
- 1. Let _benv_ be the running execution context's LexicalEnvironment.
+ 1. Let _genv_ be the [[VariableEnvironment]] field of the running execution context.
+ 1. Let _benv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _fobj_ be ! _benv_.GetBindingValue(_F_, *false*).
1. Perform ? _genv_.SetMutableBinding(_F_, _fobj_, *false*).
1. Return NormalCompletion(~empty~).
@@ -46311,8 +46343,8 @@ Changes to EvalDeclarationInstantiation
1. Perform ! _varEnv_.InitializeBinding(_F_, *undefined*).
1. Append _F_ to _declaredFunctionOrVarNames_.
1. When the |FunctionDeclaration| _f_ is evaluated, perform the following steps in place of the |FunctionDeclaration| Evaluation algorithm provided in :
- 1. Let _genv_ be the running execution context's VariableEnvironment.
- 1. Let _benv_ be the running execution context's LexicalEnvironment.
+ 1. Let _genv_ be the [[VariableEnvironment]] field of the running execution context.
+ 1. Let _benv_ be the [[LexicalEnvironment]] field of the running execution context.
1. Let _fobj_ be ! _benv_.GetBindingValue(_F_, *false*).
1. Perform ? _genv_.SetMutableBinding(_F_, _fobj_, *false*).
1. Return NormalCompletion(~empty~).