1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-24 18:32:32 +00:00
serenity/Userland/Libraries/LibJS/Runtime/Environment.cpp
Andreas Kling 421845b0cd LibJS: Taint variable environment chain after non-strict direct eval()
Since non-strict direct eval() can insert new bindings into a
surrounding var scope, we cannot safely cache some assumptions about
environment chain layout after eval() has taken place.

Since eval() is rare, let's do what other engines do and simply
deoptimize in its presence. This patch adds a new "permanently screwed"
flag to JS::Environment that will be set on the entire variable
environment chain upon non-strict direct eval().
2021-10-07 11:53:18 +02:00

40 lines
898 B
C++

/*
* Copyright (c) 2020-2021, Andreas Kling <kling@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibJS/Runtime/Environment.h>
#include <LibJS/Runtime/GlobalObject.h>
#include <LibJS/Runtime/VM.h>
namespace JS {
Environment::Environment(Environment* outer_environment)
: m_outer_environment(outer_environment)
{
}
void Environment::initialize(GlobalObject& global_object)
{
m_global_object = &global_object;
Cell::initialize(global_object);
}
void Environment::visit_edges(Visitor& visitor)
{
Cell::visit_edges(visitor);
visitor.visit(m_global_object);
visitor.visit(m_outer_environment);
}
void Environment::set_permanently_screwed_by_eval()
{
if (m_permanently_screwed_by_eval)
return;
m_permanently_screwed_by_eval = true;
if (outer_environment())
outer_environment()->set_permanently_screwed_by_eval();
}
}