diff options
author | Andreas Kling <kling@serenityos.org> | 2021-06-22 13:30:48 +0200 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2021-06-22 18:44:53 +0200 |
commit | aabd82d50886c14741500c03fc58fb3863b45ddb (patch) | |
tree | 21359e759fab78f2d7c6c3bf4d1f3fa106a6fc4b /Userland/Libraries/LibJS/Interpreter.cpp | |
parent | 6ed6434bab2b136a64a7e8374dbc58b467017016 (diff) | |
download | serenity-aabd82d50886c14741500c03fc58fb3863b45ddb.zip |
LibJS: Bring function environment records closer to the spec
This patch adds FunctionEnvironmentRecord as a subclass of the existing
DeclarativeEnvironmentRecord. Things that are specific to function
environment records move into there, simplifying the base.
Most of the abstract operations related to function environment records
are rewritten to match the spec exactly. I also had to implement
GetThisEnvironment() and GetSuperConstructor() to keep tests working
after the changes, so that's nice as well. :^)
Diffstat (limited to 'Userland/Libraries/LibJS/Interpreter.cpp')
-rw-r--r-- | Userland/Libraries/LibJS/Interpreter.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/Userland/Libraries/LibJS/Interpreter.cpp b/Userland/Libraries/LibJS/Interpreter.cpp index bc65abdf3c..8779ad23f7 100644 --- a/Userland/Libraries/LibJS/Interpreter.cpp +++ b/Userland/Libraries/LibJS/Interpreter.cpp @@ -9,7 +9,7 @@ #include <AK/StringBuilder.h> #include <LibJS/AST.h> #include <LibJS/Interpreter.h> -#include <LibJS/Runtime/DeclarativeEnvironmentRecord.h> +#include <LibJS/Runtime/FunctionEnvironmentRecord.h> #include <LibJS/Runtime/GlobalObject.h> #include <LibJS/Runtime/Object.h> #include <LibJS/Runtime/Reference.h> @@ -193,10 +193,10 @@ Value Interpreter::execute_statement(GlobalObject& global_object, const Statemen return last_value; } -DeclarativeEnvironmentRecord* Interpreter::current_declarative_environment_record() +FunctionEnvironmentRecord* Interpreter::current_function_environment_record() { - VERIFY(is<DeclarativeEnvironmentRecord>(vm().call_frame().environment_record)); - return static_cast<DeclarativeEnvironmentRecord*>(vm().call_frame().environment_record); + VERIFY(is<FunctionEnvironmentRecord>(vm().call_frame().environment_record)); + return static_cast<FunctionEnvironmentRecord*>(vm().call_frame().environment_record); } } |