Commit 404bc9b6 authored by jochen's avatar jochen Committed by Commit bot

Store whether a with scope is actually a debug-eval scope in the scope info

This is required to be able to deserialize the scope chain from the
scope info alone.

BUG=v8:5215
R=marja@chromium.org,jgruber@chromium.org

Review-Url: https://codereview.chromium.org/2331323006
Cr-Commit-Position: refs/heads/master@{#39412}
parent cc7926d6
...@@ -155,18 +155,20 @@ Handle<ScopeInfo> ScopeInfo::Create(Isolate* isolate, Zone* zone, Scope* scope, ...@@ -155,18 +155,20 @@ Handle<ScopeInfo> ScopeInfo::Create(Isolate* isolate, Zone* zone, Scope* scope,
} }
// Encode the flags. // Encode the flags.
int flags = ScopeTypeField::encode(scope->scope_type()) | int flags =
CallsEvalField::encode(scope->calls_eval()) | ScopeTypeField::encode(scope->scope_type()) |
LanguageModeField::encode(scope->language_mode()) | CallsEvalField::encode(scope->calls_eval()) |
DeclarationScopeField::encode(scope->is_declaration_scope()) | LanguageModeField::encode(scope->language_mode()) |
ReceiverVariableField::encode(receiver_info) | DeclarationScopeField::encode(scope->is_declaration_scope()) |
HasNewTargetField::encode(has_new_target) | ReceiverVariableField::encode(receiver_info) |
FunctionVariableField::encode(function_name_info) | HasNewTargetField::encode(has_new_target) |
AsmModuleField::encode(asm_module) | FunctionVariableField::encode(function_name_info) |
AsmFunctionField::encode(asm_function) | AsmModuleField::encode(asm_module) |
HasSimpleParametersField::encode(has_simple_parameters) | AsmFunctionField::encode(asm_function) |
FunctionKindField::encode(function_kind) | HasSimpleParametersField::encode(has_simple_parameters) |
HasOuterScopeInfoField::encode(has_outer_scope_info); FunctionKindField::encode(function_kind) |
HasOuterScopeInfoField::encode(has_outer_scope_info) |
IsDebugEvaluateScopeField::encode(scope->is_debug_evaluate_scope());
scope_info->SetFlags(flags); scope_info->SetFlags(flags);
scope_info->SetParameterCount(parameter_count); scope_info->SetParameterCount(parameter_count);
...@@ -302,7 +304,8 @@ Handle<ScopeInfo> ScopeInfo::CreateForWithScope( ...@@ -302,7 +304,8 @@ Handle<ScopeInfo> ScopeInfo::CreateForWithScope(
FunctionVariableField::encode(NONE) | AsmModuleField::encode(false) | FunctionVariableField::encode(NONE) | AsmModuleField::encode(false) |
AsmFunctionField::encode(false) | HasSimpleParametersField::encode(true) | AsmFunctionField::encode(false) | HasSimpleParametersField::encode(true) |
FunctionKindField::encode(kNormalFunction) | FunctionKindField::encode(kNormalFunction) |
HasOuterScopeInfoField::encode(has_outer_scope_info); HasOuterScopeInfoField::encode(has_outer_scope_info) |
IsDebugEvaluateScopeField::encode(false);
scope_info->SetFlags(flags); scope_info->SetFlags(flags);
scope_info->SetParameterCount(0); scope_info->SetParameterCount(0);
...@@ -355,7 +358,8 @@ Handle<ScopeInfo> ScopeInfo::CreateGlobalThisBinding(Isolate* isolate) { ...@@ -355,7 +358,8 @@ Handle<ScopeInfo> ScopeInfo::CreateGlobalThisBinding(Isolate* isolate) {
AsmModuleField::encode(false) | AsmFunctionField::encode(false) | AsmModuleField::encode(false) | AsmFunctionField::encode(false) |
HasSimpleParametersField::encode(has_simple_parameters) | HasSimpleParametersField::encode(has_simple_parameters) |
FunctionKindField::encode(FunctionKind::kNormalFunction) | FunctionKindField::encode(FunctionKind::kNormalFunction) |
HasOuterScopeInfoField::encode(has_outer_scope_info); HasOuterScopeInfoField::encode(has_outer_scope_info) |
IsDebugEvaluateScopeField::encode(false);
scope_info->SetFlags(flags); scope_info->SetFlags(flags);
scope_info->SetParameterCount(parameter_count); scope_info->SetParameterCount(parameter_count);
scope_info->SetStackLocalCount(stack_local_count); scope_info->SetStackLocalCount(stack_local_count);
...@@ -491,6 +495,23 @@ bool ScopeInfo::HasOuterScopeInfo() { ...@@ -491,6 +495,23 @@ bool ScopeInfo::HasOuterScopeInfo() {
} }
} }
bool ScopeInfo::IsDebugEvaluateScope() {
if (length() > 0) {
return IsDebugEvaluateScopeField::decode(Flags());
} else {
return false;
}
}
void ScopeInfo::SetIsDebugEvaluateScope() {
if (length() > 0) {
DCHECK_EQ(scope_type(), WITH_SCOPE);
SetFlags(Flags() | IsDebugEvaluateScopeField::encode(true));
} else {
UNREACHABLE();
}
}
bool ScopeInfo::HasHeapAllocatedLocals() { bool ScopeInfo::HasHeapAllocatedLocals() {
if (length() > 0) { if (length() > 0) {
return ContextLocalCount() > 0; return ContextLocalCount() > 0;
......
...@@ -409,6 +409,7 @@ class Scope: public ZoneObject { ...@@ -409,6 +409,7 @@ class Scope: public ZoneObject {
// Retrieve `IsSimpleParameterList` of current or outer function. // Retrieve `IsSimpleParameterList` of current or outer function.
bool HasSimpleParameters(); bool HasSimpleParameters();
void set_is_debug_evaluate_scope() { is_debug_evaluate_scope_ = true; } void set_is_debug_evaluate_scope() { is_debug_evaluate_scope_ = true; }
bool is_debug_evaluate_scope() const { return is_debug_evaluate_scope_; }
protected: protected:
explicit Scope(Zone* zone); explicit Scope(Zone* zone);
......
...@@ -209,14 +209,13 @@ DebugEvaluate::ContextBuilder::ContextBuilder(Isolate* isolate, ...@@ -209,14 +209,13 @@ DebugEvaluate::ContextBuilder::ContextBuilder(Isolate* isolate,
} }
for (int i = context_chain_.length() - 1; i >= 0; i--) { for (int i = context_chain_.length() - 1; i >= 0; i--) {
Handle<ScopeInfo> scope_info(ScopeInfo::CreateForWithScope(
isolate, evaluation_context_->IsNativeContext()
? Handle<ScopeInfo>::null()
: Handle<ScopeInfo>(evaluation_context_->scope_info())));
scope_info->SetIsDebugEvaluateScope();
evaluation_context_ = factory->NewDebugEvaluateContext( evaluation_context_ = factory->NewDebugEvaluateContext(
evaluation_context_, evaluation_context_, scope_info, context_chain_[i].materialized_object,
ScopeInfo::CreateForWithScope(
isolate,
evaluation_context_->IsNativeContext()
? Handle<ScopeInfo>::null()
: Handle<ScopeInfo>(evaluation_context_->scope_info())),
context_chain_[i].materialized_object,
context_chain_[i].wrapped_context, context_chain_[i].whitelist); context_chain_[i].wrapped_context, context_chain_[i].whitelist);
} }
} }
......
...@@ -844,6 +844,7 @@ Handle<Context> Factory::NewDebugEvaluateContext(Handle<Context> previous, ...@@ -844,6 +844,7 @@ Handle<Context> Factory::NewDebugEvaluateContext(Handle<Context> previous,
Handle<Context> wrapped, Handle<Context> wrapped,
Handle<StringSet> whitelist) { Handle<StringSet> whitelist) {
STATIC_ASSERT(Context::WHITE_LIST_INDEX == Context::MIN_CONTEXT_SLOTS + 1); STATIC_ASSERT(Context::WHITE_LIST_INDEX == Context::MIN_CONTEXT_SLOTS + 1);
DCHECK(scope_info->IsDebugEvaluateScope());
Handle<ContextExtension> context_extension = NewContextExtension( Handle<ContextExtension> context_extension = NewContextExtension(
scope_info, extension.is_null() ? Handle<Object>::cast(undefined_value()) scope_info, extension.is_null() ? Handle<Object>::cast(undefined_value())
: Handle<Object>::cast(extension)); : Handle<Object>::cast(extension));
......
...@@ -4394,6 +4394,13 @@ class ScopeInfo : public FixedArray { ...@@ -4394,6 +4394,13 @@ class ScopeInfo : public FixedArray {
// Returns true if this ScopeInfo is linked to a outer ScopeInfo. // Returns true if this ScopeInfo is linked to a outer ScopeInfo.
bool HasOuterScopeInfo(); bool HasOuterScopeInfo();
// Returns true if this ScopeInfo was created for a debug-evaluate scope.
bool IsDebugEvaluateScope();
// Can be used to mark a ScopeInfo that looks like a with-scope as actually
// being a debug-evaluate scope.
void SetIsDebugEvaluateScope();
// Return the outer ScopeInfo if present. // Return the outer ScopeInfo if present.
ScopeInfo* OuterScopeInfo(); ScopeInfo* OuterScopeInfo();
...@@ -4525,6 +4532,8 @@ class ScopeInfo : public FixedArray { ...@@ -4525,6 +4532,8 @@ class ScopeInfo : public FixedArray {
: public BitField<FunctionKind, HasSimpleParametersField::kNext, 9> {}; : public BitField<FunctionKind, HasSimpleParametersField::kNext, 9> {};
class HasOuterScopeInfoField class HasOuterScopeInfoField
: public BitField<bool, FunctionKindField::kNext, 1> {}; : public BitField<bool, FunctionKindField::kNext, 1> {};
class IsDebugEvaluateScopeField
: public BitField<bool, HasOuterScopeInfoField::kNext, 1> {};
// Properties of variables. // Properties of variables.
class VariableModeField : public BitField<VariableMode, 0, 3> {}; class VariableModeField : public BitField<VariableMode, 0, 3> {};
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment