1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-27 19:07:34 +00:00

LibJS: Add VM::dump_scope_chain()

This is a handy helper that dumps the current scope chain, starting at
the innermost scope.
This commit is contained in:
Andreas Kling 2021-06-21 20:54:02 +02:00
parent 4c8df58e08
commit 0d2aba07aa
2 changed files with 14 additions and 0 deletions

View file

@ -622,4 +622,17 @@ void VM::dump_backtrace() const
dbgln("-> {}", m_call_stack[i]->function_name);
}
void VM::dump_scope_chain() const
{
for (auto* scope = current_scope(); scope; scope = scope->parent()) {
dbgln("+> {} ({:p})", scope->class_name(), scope);
if (is<LexicalEnvironment>(*scope)) {
auto& lexical_environment = static_cast<LexicalEnvironment const&>(*scope);
for (auto& variable : lexical_environment.variables()) {
dbgln(" {}", variable.key);
}
}
}
}
}

View file

@ -72,6 +72,7 @@ public:
void clear_exception() { m_exception = nullptr; }
void dump_backtrace() const;
void dump_scope_chain() const;
class InterpreterExecutionScope {
public: