Chromium Code Reviews| 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 "src/isolate.h" | 5 #include "src/isolate.h" |
| 6 | 6 |
| 7 #include <stdlib.h> | 7 #include <stdlib.h> |
| 8 | 8 |
| 9 #include <fstream> // NOLINT(readability/streams) | 9 #include <fstream> // NOLINT(readability/streams) |
| 10 #include <sstream> | 10 #include <sstream> |
| (...skipping 2133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2144 regexp_stack_(NULL), | 2144 regexp_stack_(NULL), |
| 2145 date_cache_(NULL), | 2145 date_cache_(NULL), |
| 2146 call_descriptor_data_(NULL), | 2146 call_descriptor_data_(NULL), |
| 2147 // TODO(bmeurer) Initialized lazily because it depends on flags; can | 2147 // TODO(bmeurer) Initialized lazily because it depends on flags; can |
| 2148 // be fixed once the default isolate cleanup is done. | 2148 // be fixed once the default isolate cleanup is done. |
| 2149 random_number_generator_(NULL), | 2149 random_number_generator_(NULL), |
| 2150 rail_mode_(PERFORMANCE_ANIMATION), | 2150 rail_mode_(PERFORMANCE_ANIMATION), |
| 2151 serializer_enabled_(enable_serializer), | 2151 serializer_enabled_(enable_serializer), |
| 2152 has_fatal_error_(false), | 2152 has_fatal_error_(false), |
| 2153 initialized_from_snapshot_(false), | 2153 initialized_from_snapshot_(false), |
| 2154 is_promisehook_enabled_(false), | 2154 is_promise_hook_enabled_(false), |
| 2155 is_tail_call_elimination_enabled_(true), | 2155 is_tail_call_elimination_enabled_(true), |
| 2156 is_isolate_in_background_(false), | 2156 is_isolate_in_background_(false), |
| 2157 cpu_profiler_(NULL), | 2157 cpu_profiler_(NULL), |
| 2158 heap_profiler_(NULL), | 2158 heap_profiler_(NULL), |
| 2159 code_event_dispatcher_(new CodeEventDispatcher()), | 2159 code_event_dispatcher_(new CodeEventDispatcher()), |
| 2160 function_entry_hook_(NULL), | 2160 function_entry_hook_(NULL), |
| 2161 deferred_handles_head_(NULL), | 2161 deferred_handles_head_(NULL), |
| 2162 optimizing_compile_dispatcher_(NULL), | 2162 optimizing_compile_dispatcher_(NULL), |
| 2163 stress_deopt_count_(0), | 2163 stress_deopt_count_(0), |
| 2164 next_optimization_id_(0), | 2164 next_optimization_id_(0), |
| (...skipping 996 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3161 | 3161 |
| 3162 if (call_completed_callbacks_.is_empty()) return; | 3162 if (call_completed_callbacks_.is_empty()) return; |
| 3163 // Fire callbacks. Increase call depth to prevent recursive callbacks. | 3163 // Fire callbacks. Increase call depth to prevent recursive callbacks. |
| 3164 v8::Isolate* isolate = reinterpret_cast<v8::Isolate*>(this); | 3164 v8::Isolate* isolate = reinterpret_cast<v8::Isolate*>(this); |
| 3165 v8::Isolate::SuppressMicrotaskExecutionScope suppress(isolate); | 3165 v8::Isolate::SuppressMicrotaskExecutionScope suppress(isolate); |
| 3166 for (int i = 0; i < call_completed_callbacks_.length(); i++) { | 3166 for (int i = 0; i < call_completed_callbacks_.length(); i++) { |
| 3167 call_completed_callbacks_.at(i)(isolate); | 3167 call_completed_callbacks_.at(i)(isolate); |
| 3168 } | 3168 } |
| 3169 } | 3169 } |
| 3170 | 3170 |
| 3171 void Isolate::EnablePromiseHook() { is_promisehook_enabled_ = true; } | 3171 void Isolate::SetPromiseHook(PromiseHook hook) { |
| 3172 is_promise_hook_enabled_ = hook != nullptr; | |
|
adamk
2016/12/15 08:46:09
Is there a reason we still need to track this sepa
gsathya
2016/12/15 15:35:33
I thought the boolean was cleaner. Changed.
adamk
2016/12/15 15:43:58
I prefer this way to avoid having to do extra book
| |
| 3173 set_promise_hook(hook); | |
| 3174 } | |
| 3172 | 3175 |
| 3173 void Isolate::DisablePromiseHook() { is_promisehook_enabled_ = false; } | 3176 void Isolate::RunPromiseHook(PromiseHookType type, Handle<JSObject> promise, |
| 3177 Handle<Object> parent) { | |
| 3178 if (!is_promise_hook_enabled_) return; | |
| 3179 PromiseHook hook = promise_hook(); | |
| 3180 HandleScope scope(this); | |
|
adamk
2016/12/15 08:46:09
Where is this called from where there isn't alread
gsathya
2016/12/15 15:35:33
I don't create handlescopes in the runtime functio
adamk
2016/12/15 15:43:58
Ah, you should create HandleScopes there :)
| |
| 3181 hook(type, v8::Utils::PromiseToLocal(promise), v8::Utils::ToLocal(parent)); | |
| 3182 } | |
| 3174 | 3183 |
| 3175 void Isolate::SetPromiseRejectCallback(PromiseRejectCallback callback) { | 3184 void Isolate::SetPromiseRejectCallback(PromiseRejectCallback callback) { |
| 3176 promise_reject_callback_ = callback; | 3185 promise_reject_callback_ = callback; |
| 3177 } | 3186 } |
| 3178 | 3187 |
| 3179 | 3188 |
| 3180 void Isolate::ReportPromiseReject(Handle<JSObject> promise, | 3189 void Isolate::ReportPromiseReject(Handle<JSObject> promise, |
| 3181 Handle<Object> value, | 3190 Handle<Object> value, |
| 3182 v8::PromiseRejectEvent event) { | 3191 v8::PromiseRejectEvent event) { |
| 3183 if (promise_reject_callback_ == NULL) return; | 3192 if (promise_reject_callback_ == NULL) return; |
| (...skipping 383 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3567 // Then check whether this scope intercepts. | 3576 // Then check whether this scope intercepts. |
| 3568 if ((flag & intercept_mask_)) { | 3577 if ((flag & intercept_mask_)) { |
| 3569 intercepted_flags_ |= flag; | 3578 intercepted_flags_ |= flag; |
| 3570 return true; | 3579 return true; |
| 3571 } | 3580 } |
| 3572 return false; | 3581 return false; |
| 3573 } | 3582 } |
| 3574 | 3583 |
| 3575 } // namespace internal | 3584 } // namespace internal |
| 3576 } // namespace v8 | 3585 } // namespace v8 |
| OLD | NEW |