Index: src/ia32/full-codegen-ia32.cc |
diff --git a/src/ia32/full-codegen-ia32.cc b/src/ia32/full-codegen-ia32.cc |
index 156c7fb159c8457d890d90a18ffc7512ef6f4bb7..cf53f4b814367fb1fd113063a816fd0f928fd8e2 100644 |
--- a/src/ia32/full-codegen-ia32.cc |
+++ b/src/ia32/full-codegen-ia32.cc |
@@ -100,7 +100,7 @@ void FullCodeGenerator::Generate(CompilationInfo* info) { |
// Copy parameters into context if necessary. |
int num_parameters = scope()->num_parameters(); |
for (int i = 0; i < num_parameters; i++) { |
- Slot* slot = scope()->parameter(i)->slot(); |
+ Slot* slot = scope()->parameter(i)->AsSlot(); |
if (slot != NULL && slot->type() == Slot::CONTEXT) { |
int parameter_offset = StandardFrameConstants::kCallerSPOffset + |
(num_parameters - 1 - i) * kPointerSize; |
@@ -118,7 +118,7 @@ void FullCodeGenerator::Generate(CompilationInfo* info) { |
} |
} |
- Variable* arguments = scope()->arguments()->AsVariable(); |
+ Variable* arguments = scope()->arguments(); |
if (arguments != NULL) { |
// Function uses arguments object. |
Comment cmnt(masm_, "[ Allocate arguments object"); |
@@ -140,9 +140,8 @@ void FullCodeGenerator::Generate(CompilationInfo* info) { |
ArgumentsAccessStub stub(ArgumentsAccessStub::NEW_OBJECT); |
__ CallStub(&stub); |
__ mov(ecx, eax); // Duplicate result. |
- Move(arguments->slot(), eax, ebx, edx); |
- Slot* dot_arguments_slot = |
- scope()->arguments_shadow()->AsVariable()->slot(); |
+ Move(arguments->AsSlot(), eax, ebx, edx); |
+ Slot* dot_arguments_slot = scope()->arguments_shadow()->AsSlot(); |
Move(dot_arguments_slot, ecx, ebx, edx); |
} |
@@ -516,7 +515,7 @@ void FullCodeGenerator::EmitDeclaration(Variable* variable, |
FunctionLiteral* function) { |
Comment cmnt(masm_, "[ Declaration"); |
ASSERT(variable != NULL); // Must have been resolved. |
- Slot* slot = variable->slot(); |
+ Slot* slot = variable->AsSlot(); |
Property* prop = variable->AsProperty(); |
if (slot != NULL) { |
switch (slot->type()) { |
@@ -1001,7 +1000,7 @@ void FullCodeGenerator::EmitDynamicLoadFromSlotFastCase( |
EmitLoadGlobalSlotCheckExtensions(slot, typeof_state, slow); |
__ jmp(done); |
} else if (slot->var()->mode() == Variable::DYNAMIC_LOCAL) { |
- Slot* potential_slot = slot->var()->local_if_not_shadowed()->slot(); |
+ Slot* potential_slot = slot->var()->local_if_not_shadowed()->AsSlot(); |
Expression* rewrite = slot->var()->local_if_not_shadowed()->rewrite(); |
if (potential_slot != NULL) { |
// Generate fast case for locals that rewrite to slots. |
@@ -1027,7 +1026,7 @@ void FullCodeGenerator::EmitDynamicLoadFromSlotFastCase( |
// variables. Then load the argument from the arguments |
// object using keyed load. |
__ mov(edx, |
- ContextSlotOperandCheckExtensions(obj_proxy->var()->slot(), |
+ ContextSlotOperandCheckExtensions(obj_proxy->var()->AsSlot(), |
slow)); |
__ mov(eax, Immediate(key_literal->handle())); |
Handle<Code> ic(Builtins::builtin(Builtins::KeyedLoadIC_Initialize)); |
@@ -1044,7 +1043,7 @@ void FullCodeGenerator::EmitVariableLoad(Variable* var) { |
// Four cases: non-this global variables, lookup slots, all other |
// types of slots, and parameters that rewrite to explicit property |
// accesses on the arguments object. |
- Slot* slot = var->slot(); |
+ Slot* slot = var->AsSlot(); |
Property* property = var->AsProperty(); |
if (var->is_global() && !var->is_this()) { |
@@ -1100,7 +1099,7 @@ void FullCodeGenerator::EmitVariableLoad(Variable* var) { |
// Assert that the object is in a slot. |
Variable* object_var = property->obj()->AsVariableProxy()->AsVariable(); |
ASSERT_NOT_NULL(object_var); |
- Slot* object_slot = object_var->slot(); |
+ Slot* object_slot = object_var->AsSlot(); |
ASSERT_NOT_NULL(object_slot); |
// Load the object. |
@@ -1809,7 +1808,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, |
// Left-hand sides that rewrite to explicit property accesses do not reach |
// here. |
ASSERT(var != NULL); |
- ASSERT(var->is_global() || var->slot() != NULL); |
+ ASSERT(var->is_global() || var->AsSlot() != NULL); |
if (var->is_global()) { |
ASSERT(!var->is_this()); |
@@ -1825,7 +1824,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, |
// Perform the assignment for non-const variables and for initialization |
// of const variables. Const assignments are simply skipped. |
Label done; |
- Slot* slot = var->slot(); |
+ Slot* slot = var->AsSlot(); |
switch (slot->type()) { |
case Slot::PARAMETER: |
case Slot::LOCAL: |
@@ -2086,14 +2085,14 @@ void FullCodeGenerator::VisitCall(Call* expr) { |
// Push global object as receiver for the call IC. |
__ push(CodeGenerator::GlobalObject()); |
EmitCallWithIC(expr, var->name(), RelocInfo::CODE_TARGET_CONTEXT); |
- } else if (var != NULL && var->slot() != NULL && |
- var->slot()->type() == Slot::LOOKUP) { |
+ } else if (var != NULL && var->AsSlot() != NULL && |
+ var->AsSlot()->type() == Slot::LOOKUP) { |
// Call to a lookup slot (dynamically introduced variable). |
Label slow, done; |
// Generate code for loading from variables potentially shadowed |
// by eval-introduced variables. |
- EmitDynamicLoadFromSlotFastCase(var->slot(), |
+ EmitDynamicLoadFromSlotFastCase(var->AsSlot(), |
NOT_INSIDE_TYPEOF, |
&slow, |
&done); |
@@ -3095,8 +3094,8 @@ void FullCodeGenerator::VisitUnaryOperation(UnaryOperation* expr) { |
context()->Plug(true); |
} else if (var != NULL && |
!var->is_global() && |
- var->slot() != NULL && |
- var->slot()->type() != Slot::LOOKUP) { |
+ var->AsSlot() != NULL && |
+ var->AsSlot()->type() != Slot::LOOKUP) { |
// Result of deleting non-global, non-dynamic variables is false. |
// The subexpression does not have side effects. |
context()->Plug(false); |
@@ -3393,13 +3392,13 @@ void FullCodeGenerator::VisitForTypeofValue(Expression* expr) { |
EmitCallIC(ic, RelocInfo::CODE_TARGET); |
context()->Plug(eax); |
} else if (proxy != NULL && |
- proxy->var()->slot() != NULL && |
- proxy->var()->slot()->type() == Slot::LOOKUP) { |
+ proxy->var()->AsSlot() != NULL && |
+ proxy->var()->AsSlot()->type() == Slot::LOOKUP) { |
Label done, slow; |
// Generate code for loading from variables potentially shadowed |
// by eval-introduced variables. |
- Slot* slot = proxy->var()->slot(); |
+ Slot* slot = proxy->var()->AsSlot(); |
EmitDynamicLoadFromSlotFastCase(slot, INSIDE_TYPEOF, &slow, &done); |
__ bind(&slow); |