Skip to content

Commit

Permalink
Add HostPromiseRejectionTracker
Browse files Browse the repository at this point in the history
This is a non-observable change that will allow HTML to provide events for tracking promise rejections, as outlined in https://github.com/domenic/unhandled-rejections-browser-spec.

For more information on the original proposal and use cases (mostly on the HTML side), see https://lists.w3.org/Archives/Public/public-whatwg-archive/2014Sep/0024.html.

The corresponding HTML pull request is at whatwg/html#224.
  • Loading branch information
domenic committed Oct 6, 2015
1 parent 2e4aaa3 commit 018cd75
Showing 1 changed file with 36 additions and 1 deletion.
37 changes: 36 additions & 1 deletion spec.html
Original file line number Diff line number Diff line change
Expand Up @@ -35517,7 +35517,7 @@ <h1>IsPromise ( x )</h1>

<!-- es6num="25.4.1.7" -->
<emu-clause id="sec-rejectpromise" aoid="RejectPromise">
<h1>RejectPromise ( promise, reason)</h1>
<h1>RejectPromise ( promise, reason )</h1>
<p>When the RejectPromise abstract operation is called with arguments _promise_ and _reason_ the following steps are taken:</p>
<emu-alg>
1. Assert: the value of _promise_'s [[PromiseState]] internal slot is `"pending"`.
Expand All @@ -35526,6 +35526,7 @@ <h1>RejectPromise ( promise, reason)</h1>
1. Set the value of _promise_'s [[PromiseFulfillReactions]] internal slot to *undefined*.
1. Set the value of _promise_'s [[PromiseRejectReactions]] internal slot to *undefined*.
1. Set the value of _promise_'s [[PromiseState]] internal slot to `"rejected"`.
1. If the value of _promise_'s [[PromiseIsHandled]] internal slot is *false*, perform HostPromiseRejectionTracker(_promise_, the current Realm, `"reject"`).
1. Return TriggerPromiseReactions(_reactions_, _reason_).
</emu-alg>
</emu-clause>
Expand All @@ -35540,6 +35541,29 @@ <h1>TriggerPromiseReactions ( reactions, argument )</h1>
1. Return *undefined*.
</emu-alg>
</emu-clause>

<emu-clause id="sec-host-promise-rejection-tracker" aoid="HostPromiseRejectionTracker">
<h1>HostPromiseRejectionTracker ( promise, realm, operation )</h1>

<p>HostPromiseRejectionTracker is an implementation-defined abstract operation that allows host environments to track promise rejections.</p>

<p>An implementation of HostPromiseRejectionTracker must complete normally in all cases. The default implementation of HostPromiseRejectionTracker is to do nothing.</p>

<emu-note>
<p>HostPromiseRejectionTracker is called in two scenarios:</p>

<ul>
<li>When a promise is rejected without any handlers, it is called with its _operation_ argument set to `"reject"`.</li>
<li>When a handler is added to a rejected promise for the first time, it is called with its _operation_ argument set to `"handle"`.</li>
</ul>

<p>A typical implementation of HostPromiseRejectionTracker might try to notify developers of unhandled rejections, while also being careful to notify them if such previous notifications are later invalidated by new handlers being attached.</p>
</emu-note>

<emu-note>
<p>If _operation_ is `"handle"`, an implementation should not hold a reference to promise in a way that would interfere with garbage collection. An implementation may hold a reference to promise if operation is `"reject"`, since it is expected that rejections will be rare and not on hot code paths.</p>
</emu-note>
</emu-clause>
</emu-clause>

<!-- es6num="25.4.2" -->
Expand Down Expand Up @@ -35601,6 +35625,7 @@ <h1>Promise ( executor )</h1>
1. Set _promise_'s [[PromiseState]] internal slot to `"pending"`.
1. Set _promise_'s [[PromiseFulfillReactions]] internal slot to a new empty List.
1. Set _promise_'s [[PromiseRejectReactions]] internal slot to a new empty List.
1. Set _promise_'s [[PromiseIsHandled]] internal slot to *false*.
1. Let _resolvingFunctions_ be CreateResolvingFunctions(_promise_).
1. Let _completion_ be Call(_executor_, *undefined*, &laquo;_resolvingFunctions_.[[Resolve]], _resolvingFunctions_.[[Reject]]&raquo;).
1. If _completion_ is an abrupt completion, then
Expand Down Expand Up @@ -35881,7 +35906,9 @@ <h1>PerformPromiseThen ( promise, onFulfilled, onRejected, resultCapability )</h
1. Perform EnqueueJob(`"PromiseJobs"`, PromiseReactionJob, &laquo;_fulfillReaction_, _value_&raquo;).
1. Else if the value of _promise_'s [[PromiseState]] internal slot is `"rejected"`,
1. Let _reason_ be the value of _promise_'s [[PromiseResult]] internal slot.
1. If the value of _promise_'s [[PromiseIsHandled]] internal slot is *false*, perform HostPromiseRejectionTracker(_promise_, the current Realm, `"handle"`).
1. Perform EnqueueJob(`"PromiseJobs"`, PromiseReactionJob, &laquo;_rejectReaction_, _reason_&raquo;).
1. Set _promise_'s [[PromiseIsHandled]] internal slot to *true*.
1. Return _resultCapability_.[[Promise]].
</emu-alg>
</emu-clause>
Expand Down Expand Up @@ -35942,6 +35969,14 @@ <h1>Properties of Promise Instances</h1>
A List of PromiseReaction records to be processed when/if the promise transitions from the `"pending"` state to the `"rejected"` state.
</td>
</tr>
<tr>
<td>
[[PromiseIsHandled]]
</td>
<td>
A boolean indicating whether the promise has ever had a fulfillment or rejection handler; used in unhandled rejection tracking.
</td>
</tr>
</tbody>
</table>
</emu-table>
Expand Down

0 comments on commit 018cd75

Please sign in to comment.