Index: src/runtime/runtime-promise.cc |
diff --git a/src/runtime/runtime-promise.cc b/src/runtime/runtime-promise.cc |
index f609df73fd6e7864266e54e640291a14ecefaca2..ed9b764214c3c31718436f38fe2275e7744ead79 100644 |
--- a/src/runtime/runtime-promise.cc |
+++ b/src/runtime/runtime-promise.cc |
@@ -284,5 +284,37 @@ RUNTIME_FUNCTION(Runtime_PromiseMarkAsHandled) { |
return isolate->heap()->undefined_value(); |
} |
+RUNTIME_FUNCTION(Runtime_PromiseHookInit) { |
+ DCHECK_EQ(2, args.length()); |
+ CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0); |
adamk
2016/12/15 15:43:58
You should have handle scopes here, since you're c
gsathya
2016/12/15 16:32:06
Done.
|
+ CONVERT_ARG_HANDLE_CHECKED(Object, parent, 1); |
+ isolate->RunPromiseHook(PromiseHookType::kInit, promise, parent); |
+ return isolate->heap()->undefined_value(); |
+} |
+ |
+RUNTIME_FUNCTION(Runtime_PromiseHookResolve) { |
+ DCHECK_EQ(1, args.length()); |
+ CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0); |
+ isolate->RunPromiseHook(PromiseHookType::kResolve, promise, |
+ isolate->factory()->undefined_value()); |
+ return isolate->heap()->undefined_value(); |
+} |
+ |
+RUNTIME_FUNCTION(Runtime_PromiseHookBefore) { |
+ DCHECK_EQ(1, args.length()); |
+ CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0); |
+ isolate->RunPromiseHook(PromiseHookType::kBefore, promise, |
+ isolate->factory()->undefined_value()); |
+ return isolate->heap()->undefined_value(); |
+} |
+ |
+RUNTIME_FUNCTION(Runtime_PromiseHookAfter) { |
+ DCHECK_EQ(1, args.length()); |
+ CONVERT_ARG_HANDLE_CHECKED(JSPromise, promise, 0); |
+ isolate->RunPromiseHook(PromiseHookType::kAfter, promise, |
+ isolate->factory()->undefined_value()); |
+ return isolate->heap()->undefined_value(); |
+} |
+ |
} // namespace internal |
} // namespace v8 |