Index: src/ia32/lithium-codegen-ia32.cc |
diff --git a/src/ia32/lithium-codegen-ia32.cc b/src/ia32/lithium-codegen-ia32.cc |
index 8b3cb47b4a525b936cd51d41853bfd3a163b1786..1597dbaf55d2027614615a032cc61e35a148fd53 100644 |
--- a/src/ia32/lithium-codegen-ia32.cc |
+++ b/src/ia32/lithium-codegen-ia32.cc |
@@ -1746,26 +1746,34 @@ void LCodeGen::EmitClassOfTest(Label* is_true, |
__ JumpIfSmi(input, is_false); |
__ CmpObjectType(input, FIRST_SPEC_OBJECT_TYPE, temp); |
__ j(below, is_false); |
+ ASSERT(LAST_SPEC_OBJECT_TYPE == LAST_TYPE); |
Kevin Millikin (Chromium)
2011/09/07 10:13:12
STATIC_ASSERT?
rossberg
2011/09/07 14:57:31
Done.
|
+ |
+ // Assuming the following assertions, we can do the same test for |
+ // either "Object" or "Function", only the branch conditions differ. |
+ STATIC_ASSERT(NUM_OF_CALLABLE_SPEC_OBJECT_TYPES == 2); |
+ STATIC_ASSERT(FIRST_NONCALLABLE_SPEC_OBJECT_TYPE == |
+ FIRST_SPEC_OBJECT_TYPE + 1); |
+ STATIC_ASSERT(LAST_NONCALLABLE_SPEC_OBJECT_TYPE == |
+ LAST_SPEC_OBJECT_TYPE - 1); |
// Map is now in temp. |
// Functions have class 'Function'. |
- __ CmpInstanceType(temp, FIRST_CALLABLE_SPEC_OBJECT_TYPE); |
+ __ CmpInstanceType(temp, FIRST_SPEC_OBJECT_TYPE); |
Kevin Millikin (Chromium)
2011/09/07 10:13:12
Same comment about restructuring this code a bit a
rossberg
2011/09/07 14:57:31
Done. (And also on x64.)
|
+ if (class_name->IsEqualTo(CStrVector("Function"))) { |
+ __ j(equal, is_true); |
+ } else { |
+ __ j(below_equal, is_false); |
+ } |
+ __ CmpInstanceType(temp, LAST_SPEC_OBJECT_TYPE); |
if (class_name->IsEqualTo(CStrVector("Function"))) { |
- __ j(above_equal, is_true); |
+ __ j(equal, is_true); |
} else { |
__ j(above_equal, is_false); |
} |
+ // Now we are in the FIRST-LAST_NONCALLABLE_SPEC_OBJECT_TYPE range. |
// Check if the constructor in the map is a function. |
__ mov(temp, FieldOperand(temp, Map::kConstructorOffset)); |
- |
- // As long as LAST_CALLABLE_SPEC_OBJECT_TYPE is the last instance type, and |
- // FIRST_CALLABLE_SPEC_OBJECT_TYPE comes right after |
- // LAST_NONCALLABLE_SPEC_OBJECT_TYPE, we can avoid checking for the latter. |
- STATIC_ASSERT(LAST_TYPE == LAST_CALLABLE_SPEC_OBJECT_TYPE); |
- STATIC_ASSERT(FIRST_CALLABLE_SPEC_OBJECT_TYPE == |
- LAST_NONCALLABLE_SPEC_OBJECT_TYPE + 1); |
- |
// Objects with a non-function constructor have class 'Object'. |
__ CmpObjectType(temp, JS_FUNCTION_TYPE, temp2); |
if (class_name->IsEqualTo(CStrVector("Object"))) { |
@@ -4187,10 +4195,12 @@ Condition LCodeGen::EmitTypeofIs(Label* true_label, |
final_branch_condition = not_zero; |
} else if (type_name->Equals(heap()->function_symbol())) { |
- STATIC_ASSERT(LAST_TYPE == LAST_CALLABLE_SPEC_OBJECT_TYPE); |
+ STATIC_ASSERT(NUM_OF_CALLABLE_SPEC_OBJECT_TYPES == 2); |
__ JumpIfSmi(input, false_label); |
- __ CmpObjectType(input, FIRST_CALLABLE_SPEC_OBJECT_TYPE, input); |
- final_branch_condition = above_equal; |
+ __ CmpObjectType(input, JS_FUNCTION_TYPE, input); |
+ __ j(equal, true_label); |
+ __ CmpInstanceType(input, JS_FUNCTION_PROXY_TYPE); |
+ final_branch_condition = equal; |
} else if (type_name->Equals(heap()->object_symbol())) { |
__ JumpIfSmi(input, false_label); |