Index: src/isolate.cc |
diff --git a/src/isolate.cc b/src/isolate.cc |
index 7cf525d3e157a052dd78f21e25df1432518ee9c1..684f03e49cd9a37eb238d1920027d225054f890f 100644 |
--- a/src/isolate.cc |
+++ b/src/isolate.cc |
@@ -2272,8 +2272,17 @@ void Isolate::ReportPromiseReject(Handle<JSObject> promise, |
Handle<Object> value, |
v8::PromiseRejectEvent event) { |
if (promise_reject_callback_ == NULL) return; |
- promise_reject_callback_(v8::Utils::PromiseToLocal(promise), |
- v8::Utils::ToLocal(value), event); |
+ Handle<JSArray> stack_trace; |
+ if (event == v8::kPromiseRejectWithNoHandler && |
+ capture_stack_trace_for_uncaught_exceptions_ && value->IsJSObject()) { |
aandrey
2014/10/07 10:49:05
I think we can drop the capture_stack_trace_for_un
|
+ Handle<JSObject> error_obj = Handle<JSObject>::cast(value); |
+ Handle<Name> key = factory()->detailed_stack_trace_symbol(); |
+ Handle<Object> property = JSObject::GetDataProperty(error_obj, key); |
+ if (property->IsJSArray()) stack_trace = Handle<JSArray>::cast(property); |
+ } |
+ promise_reject_callback_(v8::Utils::PromiseToLocal(promise), event, |
+ v8::Utils::ToLocal(value), |
+ v8::Utils::StackTraceToLocal(stack_trace)); |
} |