| 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 <stdlib.h> | 5 #include <stdlib.h> |
| 6 | 6 |
| 7 #include "v8.h" | 7 #include "v8.h" |
| 8 | 8 |
| 9 #include "ast.h" | 9 #include "ast.h" |
| 10 #include "bootstrapper.h" | 10 #include "bootstrapper.h" |
| (...skipping 1018 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1029 bool report_exception = catchable_by_javascript && should_report_exception; | 1029 bool report_exception = catchable_by_javascript && should_report_exception; |
| 1030 bool try_catch_needs_message = | 1030 bool try_catch_needs_message = |
| 1031 can_be_caught_externally && try_catch_handler()->capture_message_ && | 1031 can_be_caught_externally && try_catch_handler()->capture_message_ && |
| 1032 !thread_local_top()->rethrowing_message_; | 1032 !thread_local_top()->rethrowing_message_; |
| 1033 bool bootstrapping = bootstrapper()->IsActive(); | 1033 bool bootstrapping = bootstrapper()->IsActive(); |
| 1034 | 1034 |
| 1035 thread_local_top()->rethrowing_message_ = false; | 1035 thread_local_top()->rethrowing_message_ = false; |
| 1036 | 1036 |
| 1037 // Notify debugger of exception. | 1037 // Notify debugger of exception. |
| 1038 if (catchable_by_javascript) { | 1038 if (catchable_by_javascript) { |
| 1039 debugger_->OnException(exception_handle, report_exception); | 1039 debug()->OnException(exception_handle, report_exception); |
| 1040 } | 1040 } |
| 1041 | 1041 |
| 1042 // Generate the message if required. | 1042 // Generate the message if required. |
| 1043 if (report_exception || try_catch_needs_message) { | 1043 if (report_exception || try_catch_needs_message) { |
| 1044 MessageLocation potential_computed_location; | 1044 MessageLocation potential_computed_location; |
| 1045 if (location == NULL) { | 1045 if (location == NULL) { |
| 1046 // If no location was specified we use a computed one instead. | 1046 // If no location was specified we use a computed one instead. |
| 1047 ComputeLocation(&potential_computed_location); | 1047 ComputeLocation(&potential_computed_location); |
| 1048 location = &potential_computed_location; | 1048 location = &potential_computed_location; |
| 1049 } | 1049 } |
| (...skipping 463 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1513 ISOLATE_INIT_LIST(ISOLATE_INIT_EXECUTE) | 1513 ISOLATE_INIT_LIST(ISOLATE_INIT_EXECUTE) |
| 1514 #undef ISOLATE_INIT_EXECUTE | 1514 #undef ISOLATE_INIT_EXECUTE |
| 1515 | 1515 |
| 1516 #define ISOLATE_INIT_ARRAY_EXECUTE(type, name, length) \ | 1516 #define ISOLATE_INIT_ARRAY_EXECUTE(type, name, length) \ |
| 1517 memset(name##_, 0, sizeof(type) * length); | 1517 memset(name##_, 0, sizeof(type) * length); |
| 1518 ISOLATE_INIT_ARRAY_LIST(ISOLATE_INIT_ARRAY_EXECUTE) | 1518 ISOLATE_INIT_ARRAY_LIST(ISOLATE_INIT_ARRAY_EXECUTE) |
| 1519 #undef ISOLATE_INIT_ARRAY_EXECUTE | 1519 #undef ISOLATE_INIT_ARRAY_EXECUTE |
| 1520 | 1520 |
| 1521 InitializeLoggingAndCounters(); | 1521 InitializeLoggingAndCounters(); |
| 1522 debug_ = new Debug(this); | 1522 debug_ = new Debug(this); |
| 1523 debugger_ = new Debugger(this); | |
| 1524 } | 1523 } |
| 1525 | 1524 |
| 1526 | 1525 |
| 1527 void Isolate::TearDown() { | 1526 void Isolate::TearDown() { |
| 1528 TRACE_ISOLATE(tear_down); | 1527 TRACE_ISOLATE(tear_down); |
| 1529 | 1528 |
| 1530 // Temporarily set this isolate as current so that various parts of | 1529 // Temporarily set this isolate as current so that various parts of |
| 1531 // the isolate can access it in their destructors without having a | 1530 // the isolate can access it in their destructors without having a |
| 1532 // direct pointer. We don't use Enter/Exit here to avoid | 1531 // direct pointer. We don't use Enter/Exit here to avoid |
| 1533 // initializing the thread data. | 1532 // initializing the thread data. |
| (...skipping 191 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1725 | 1724 |
| 1726 delete string_stream_debug_object_cache_; | 1725 delete string_stream_debug_object_cache_; |
| 1727 string_stream_debug_object_cache_ = NULL; | 1726 string_stream_debug_object_cache_ = NULL; |
| 1728 | 1727 |
| 1729 delete external_reference_table_; | 1728 delete external_reference_table_; |
| 1730 external_reference_table_ = NULL; | 1729 external_reference_table_ = NULL; |
| 1731 | 1730 |
| 1732 delete random_number_generator_; | 1731 delete random_number_generator_; |
| 1733 random_number_generator_ = NULL; | 1732 random_number_generator_ = NULL; |
| 1734 | 1733 |
| 1735 delete debugger_; | |
| 1736 debugger_ = NULL; | |
| 1737 delete debug_; | 1734 delete debug_; |
| 1738 debug_ = NULL; | 1735 debug_ = NULL; |
| 1739 } | 1736 } |
| 1740 | 1737 |
| 1741 | 1738 |
| 1742 void Isolate::InitializeThreadLocal() { | 1739 void Isolate::InitializeThreadLocal() { |
| 1743 thread_local_top_.isolate_ = this; | 1740 thread_local_top_.isolate_ = this; |
| 1744 thread_local_top_.Initialize(); | 1741 thread_local_top_.Initialize(); |
| 1745 } | 1742 } |
| 1746 | 1743 |
| (...skipping 561 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2308 Execution::Call(this, microtask, factory()->undefined_value(), | 2305 Execution::Call(this, microtask, factory()->undefined_value(), |
| 2309 0, NULL).Check(); | 2306 0, NULL).Check(); |
| 2310 } | 2307 } |
| 2311 } | 2308 } |
| 2312 | 2309 |
| 2313 handle_scope_implementer()->DecrementCallDepth(); | 2310 handle_scope_implementer()->DecrementCallDepth(); |
| 2314 } | 2311 } |
| 2315 | 2312 |
| 2316 | 2313 |
| 2317 } } // namespace v8::internal | 2314 } } // namespace v8::internal |
| OLD | NEW |