OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ast.h" | 5 #include "ast.h" |
6 | 6 |
7 #include <cmath> // For isfinite. | 7 #include <cmath> // For isfinite. |
8 #include "builtins.h" | 8 #include "builtins.h" |
9 #include "code-stubs.h" | 9 #include "code-stubs.h" |
10 #include "contexts.h" | 10 #include "contexts.h" |
(...skipping 555 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
566 // TODO(rossberg): all RecordTypeFeedback functions should disappear | 566 // TODO(rossberg): all RecordTypeFeedback functions should disappear |
567 // once we use the common type field in the AST consistently. | 567 // once we use the common type field in the AST consistently. |
568 | 568 |
569 void Expression::RecordToBooleanTypeFeedback(TypeFeedbackOracle* oracle) { | 569 void Expression::RecordToBooleanTypeFeedback(TypeFeedbackOracle* oracle) { |
570 to_boolean_types_ = oracle->ToBooleanTypes(test_id()); | 570 to_boolean_types_ = oracle->ToBooleanTypes(test_id()); |
571 } | 571 } |
572 | 572 |
573 | 573 |
574 bool Call::IsUsingCallFeedbackSlot(Isolate* isolate) const { | 574 bool Call::IsUsingCallFeedbackSlot(Isolate* isolate) const { |
575 CallType call_type = GetCallType(isolate); | 575 CallType call_type = GetCallType(isolate); |
576 return call_type == LOOKUP_SLOT_CALL || call_type == OTHER_CALL; | 576 return (call_type != POSSIBLY_EVAL_CALL); |
577 } | 577 } |
578 | 578 |
579 | 579 |
580 Call::CallType Call::GetCallType(Isolate* isolate) const { | 580 Call::CallType Call::GetCallType(Isolate* isolate) const { |
581 VariableProxy* proxy = expression()->AsVariableProxy(); | 581 VariableProxy* proxy = expression()->AsVariableProxy(); |
582 if (proxy != NULL) { | 582 if (proxy != NULL) { |
583 if (proxy->var()->is_possibly_eval(isolate)) { | 583 if (proxy->var()->is_possibly_eval(isolate)) { |
584 return POSSIBLY_EVAL_CALL; | 584 return POSSIBLY_EVAL_CALL; |
585 } else if (proxy->var()->IsUnallocated()) { | 585 } else if (proxy->var()->IsUnallocated()) { |
586 return GLOBAL_CALL; | 586 return GLOBAL_CALL; |
(...skipping 562 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1149 OS::SNPrintF(buffer, "%d", Smi::cast(*value_)->value()); | 1149 OS::SNPrintF(buffer, "%d", Smi::cast(*value_)->value()); |
1150 str = arr; | 1150 str = arr; |
1151 } else { | 1151 } else { |
1152 str = DoubleToCString(value_->Number(), buffer); | 1152 str = DoubleToCString(value_->Number(), buffer); |
1153 } | 1153 } |
1154 return isolate_->factory()->NewStringFromAsciiChecked(str); | 1154 return isolate_->factory()->NewStringFromAsciiChecked(str); |
1155 } | 1155 } |
1156 | 1156 |
1157 | 1157 |
1158 } } // namespace v8::internal | 1158 } } // namespace v8::internal |
OLD | NEW |