Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(394)

Side by Side Diff: src/runtime/runtime-promise.cc

Issue 2648873002: [inspector] added creation frame for async call chains for promises (Closed)
Patch Set: fixed usage of external reference Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 the V8 project authors. All rights reserved. 1 // Copyright 2016 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 #include "src/runtime/runtime-utils.h" 4 #include "src/runtime/runtime-utils.h"
5 5
6 #include "src/debug/debug.h" 6 #include "src/debug/debug.h"
7 #include "src/elements.h" 7 #include "src/elements.h"
8 8
9 namespace v8 { 9 namespace v8 {
10 namespace internal { 10 namespace internal {
(...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after
197 promise->set_has_handler(true); 197 promise->set_has_handler(true);
198 return isolate->heap()->undefined_value(); 198 return isolate->heap()->undefined_value();
199 } 199 }
200 200
201 RUNTIME_FUNCTION(Runtime_PromiseHookInit) { 201 RUNTIME_FUNCTION(Runtime_PromiseHookInit) {
202 HandleScope scope(isolate); 202 HandleScope scope(isolate);
203 DCHECK_EQ(2, args.length()); 203 DCHECK_EQ(2, args.length());
204 CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0); 204 CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0);
205 CONVERT_ARG_HANDLE_CHECKED(Object, parent, 1); 205 CONVERT_ARG_HANDLE_CHECKED(Object, parent, 1);
206 isolate->RunPromiseHook(PromiseHookType::kInit, promise, parent); 206 isolate->RunPromiseHook(PromiseHookType::kInit, promise, parent);
207 if (isolate->debug()->is_active()) {
208 int id = isolate->debug()->NextAsyncTaskId(promise);
209 isolate->debug()->OnAsyncTaskEvent(debug::kDebugPromiseCreated, id);
210 }
207 return isolate->heap()->undefined_value(); 211 return isolate->heap()->undefined_value();
208 } 212 }
209 213
210 RUNTIME_FUNCTION(Runtime_PromiseHookResolve) { 214 RUNTIME_FUNCTION(Runtime_PromiseHookResolve) {
211 HandleScope scope(isolate); 215 HandleScope scope(isolate);
212 DCHECK_EQ(1, args.length()); 216 DCHECK_EQ(1, args.length());
213 CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0); 217 CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0);
214 isolate->RunPromiseHook(PromiseHookType::kResolve, promise, 218 isolate->RunPromiseHook(PromiseHookType::kResolve, promise,
215 isolate->factory()->undefined_value()); 219 isolate->factory()->undefined_value());
216 return isolate->heap()->undefined_value(); 220 return isolate->heap()->undefined_value();
(...skipping 12 matching lines...) Expand all
229 HandleScope scope(isolate); 233 HandleScope scope(isolate);
230 DCHECK_EQ(1, args.length()); 234 DCHECK_EQ(1, args.length());
231 CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0); 235 CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0);
232 isolate->RunPromiseHook(PromiseHookType::kAfter, promise, 236 isolate->RunPromiseHook(PromiseHookType::kAfter, promise,
233 isolate->factory()->undefined_value()); 237 isolate->factory()->undefined_value());
234 return isolate->heap()->undefined_value(); 238 return isolate->heap()->undefined_value();
235 } 239 }
236 240
237 } // namespace internal 241 } // namespace internal
238 } // namespace v8 242 } // namespace v8
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698