Index: src/runtime.cc |
diff --git a/src/runtime.cc b/src/runtime.cc |
index 6b7a446c5c962891345f8ba32ef13bc8ce4332a7..6148cfd9e6b3996dd7875363485f01d00021c917 100644 |
--- a/src/runtime.cc |
+++ b/src/runtime.cc |
@@ -5642,13 +5642,22 @@ RUNTIME_FUNCTION(Runtime_DebugPrepareStepInIfStepping) { |
} |
-// Notify the debugger if an expcetion in a promise is not caught (yet). |
-RUNTIME_FUNCTION(Runtime_DebugPendingExceptionInPromise) { |
- ASSERT(args.length() == 2); |
+// The argument is a closure that is kept until the epilogue is called. |
+// On exception, the closure is called, which returns the promise if the |
+// exception is considered uncaught, or undefined otherwise. |
+RUNTIME_FUNCTION(Runtime_DebugPromiseHandlePrologue) { |
+ ASSERT(args.length() == 1); |
HandleScope scope(isolate); |
- CONVERT_ARG_HANDLE_CHECKED(Object, exception, 0); |
- CONVERT_ARG_HANDLE_CHECKED(JSObject, promise, 1); |
- isolate->debugger()->OnException(exception, true, promise); |
+ CONVERT_ARG_HANDLE_CHECKED(JSFunction, promise_getter, 0); |
+ isolate->debug()->PromiseHandlePrologue(promise_getter); |
+ return isolate->heap()->undefined_value(); |
+} |
+ |
+ |
+RUNTIME_FUNCTION(Runtime_DebugPromiseHandleEpilogue) { |
+ ASSERT(args.length() == 0); |
+ SealHandleScope shs(isolate); |
+ isolate->debug()->PromiseHandleEpilogue(); |
return isolate->heap()->undefined_value(); |
} |