mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 08:02:07 +00:00 
			
		
		
		
	 421845b0cd
			
		
	
	
		421845b0cd
		
	
	
	
	
		
			
			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().
		
			
				
	
	
		
			40 lines
		
	
	
	
		
			898 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			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();
 | |
| }
 | |
| 
 | |
| }
 |