Chromium Code Reviews| Index: src/factory.cc |
| diff --git a/src/factory.cc b/src/factory.cc |
| index 4f42888164de48ec0b5f88a01b886f27ad80065e..026ded119e1e43893b32baa99e125b71bf586a12 100644 |
| --- a/src/factory.cc |
| +++ b/src/factory.cc |
| @@ -876,7 +876,6 @@ Handle<Context> Factory::NewModuleContext(Handle<Module> module, |
| return context; |
| } |
| - |
| Handle<Context> Factory::NewFunctionContext(int length, |
| Handle<JSFunction> function) { |
| DCHECK(function->shared()->scope_info()->scope_type() == FUNCTION_SCOPE); |
| @@ -891,6 +890,20 @@ Handle<Context> Factory::NewFunctionContext(int length, |
| return context; |
| } |
| +Handle<Context> Factory::NewEvalContext(int length, |
| + Handle<JSFunction> function) { |
| + DCHECK(function->shared()->scope_info()->scope_type() == FUNCTION_SCOPE); |
|
adamk
2016/11/12 00:26:05
I would have expected this DCHECK to fail...should
Dan Ehrenberg
2016/12/07 05:41:26
Fixed the DCHECK. Added a new test which triggers
|
| + DCHECK(length >= Context::MIN_CONTEXT_SLOTS); |
| + Handle<FixedArray> array = NewFixedArray(length); |
| + array->set_map_no_write_barrier(*eval_context_map()); |
| + Handle<Context> context = Handle<Context>::cast(array); |
| + context->set_closure(*function); |
| + context->set_previous(function->context()); |
| + context->set_extension(*the_hole_value()); |
| + context->set_native_context(function->native_context()); |
| + return context; |
| +} |
| + |
| Handle<Context> Factory::NewCatchContext(Handle<JSFunction> function, |
| Handle<Context> previous, |
| Handle<ScopeInfo> scope_info, |