Skip to content

Commit

Permalink
First set of linking
Browse files Browse the repository at this point in the history
  • Loading branch information
cwilso committed Feb 28, 2024
1 parent 8d24ac2 commit b2b46b7
Showing 1 changed file with 14 additions and 14 deletions.
28 changes: 14 additions & 14 deletions Stages.md
Original file line number Diff line number Diff line change
@@ -1,39 +1,39 @@
# Stages

The WHATWG's approach to "documenting reality" is ideal for nailing down [fundamental parts of the platform](https://spec.whatwg.org/) and improving interoperability and developer satisfaction. It can sometimes be daunting for newcomers, who don't know how to reliably get implementer feedback or editor time commitment. The WHATWG Stages process is an optional, opt-in process that both new and established [Contributors](./IPR%20Policy.md#contributor) can use if they want to get more formal signals on support for their [Contribution](./IPR%20Policy.md#21-contribution). This tool is generally used for medium-to-large Contributions; it's not expected that explicit stage progression will be used for every Contribution.
The WHATWG's approach to "documenting reality" is ideal for nailing down [fundamental parts of the platform](https://spec.whatwg.org/) and improving interoperability and developer satisfaction. It can sometimes be daunting for newcomers, who don't know how to reliably get implementer feedback or editor time commitment. The WHATWG Stages process is an optional, opt-in process that both new and established [Contributors](./IPR%20Policy.md#contributor) can use if they want to get more formal signals on support for their [Contribution](./IPR%20Policy.md#21-contribution). This tool is generally used for medium-to-large [Contributions](./IPR%20Policy.md#21-contribution); it's not expected that explicit stage progression will be used for every [Contribution](./IPR%20Policy.md#21-contribution).

Stages asks for explicit implementer involvement at multiple stages, starting from notification that the problem is being worked on, then sign-off on the rough API and specification, and finally agreement on the full specification text. This is Stage signals are also useful to the broader community, helping web developers monitor the Contribuions that are moving through the various stages. By explicitly signaling a Contribution's progress, including implementer involvement, the community has a better idea of what is going on in the WHATWG.
Stages asks for explicit implementer involvement at multiple stages, starting from notification that the problem is being worked on, then sign-off on the rough API and specification, and finally agreement on the full specification text. This is Stage signals are also useful to the broader community, helping web developers monitor the Contribuions that are moving through the various stages. By explicitly signaling a [Contribution](./IPR%20Policy.md#21-contribution)'s progress, including implementer involvement, the community has a better idea of what is going on in the WHATWG.

These checkpoints are modeled loosely on the [TC39 process](https://tc39.es/process-document/), which uses the concept of _stages_. Each subsequent stage implies a larger degree of consensus from the community, willingness to engage and/or implement and ship the feature in browser engines, and signals progress to web developers, drawing attention to incubations that have grown community support behind them.

## Terminology

* <dfn>Stage</dfn>: each successive stage is closer to an integrated Contribution and interoperable implementation. These stages are tracked on the issues in the relevant WHATWG GitHub repository, using labels ("stage 0", "stage 1", etc.)
* <dfn>Stage</dfn>: each successive stage is closer to an integrated [Contribution](./IPR%20Policy.md#21-contribution) and interoperable implementation. These stages are tracked on the issues in the relevant WHATWG GitHub repository, using labels ("stage 0", "stage 1", etc.)
* <dfn>Browser engine</dfn>: an independent implementation of the web platform (i.e., Chromium, Gecko, and WebKit at present).
* <dfn>Implementation interest</dfn>: a direct signal from a browser engine that a feature is on the roadmap to implement, as defined in the [Working Mode](./Working%20Mode.md#additions)].
* <dfn>Browser engine representatives</dfn>: persons delegated by a browser engine to indicate implementation interest.

## Process

* Any Contribution effectively starts at Stage 0 without any approvals, by a community member filing a new issue on a relevant WHATWG spec.
* It is expected that the Contributor will champion the Contribution, through answering questions asynchronously, providing feedback when requested, and consideration of important open questions at triage meetings.
* Anyone can review and submit feedback on Contributions.
* Any [Contribution](./IPR%20Policy.md#21-contribution) effectively starts at Stage 0 without any approvals, by a community member filing a new issue on a relevant WHATWG spec.
* It is expected that the [Contributor](./IPR%20Policy.md#contributor) will champion the [Contribution](./IPR%20Policy.md#21-contribution), through answering questions asynchronously, providing feedback when requested, and consideration of important open questions at triage meetings.
* Anyone can review and submit feedback on [Contributions](./IPR%20Policy.md#21-contribution).
* Stage level is tracked with labels on issues in the relevant specifications — “stage 0”, “stage 1”, etc.
* Stage labels (other than stage 0) should only be added by browser engine representatives, or by Editors on the relevant specification, after showing the necessary support for a level.
* This process is subject to and governed by [WHATWG Policies](./Policies.md), including the [Intellectual Property Rights Policy](./IPR%20Policy.md).
* **Advancing stages**
* The Contributor should bring the Contribution to the WHATWG to advance to the next stage by setting an “Agenda+” label on the tracking issue, and showing up to (or ensuring someone will show up to) the next triage meeting to discuss. Advancing to a new stage requires support for the decision by at least two implementers (via their browser engine representatives), and there should not be any strong implementer objections ([per the working mode](./Working%20Mode.md#additions). This support can also be gathered in any public manner, e.g. GitHub issue comments, triage meetings, etc.
* The [Contributor](./IPR%20Policy.md#contributor) should bring the [Contribution](./IPR%20Policy.md#21-contribution) to the WHATWG to advance to the next stage by setting an “Agenda+” label on the tracking issue, and showing up to (or ensuring someone will show up to) the next triage meeting to discuss. Advancing to a new stage requires support for the decision by at least two implementers (via their browser engine representatives), and there should not be any strong implementer objections ([per the working mode](./Working%20Mode.md#additions). This support can also be gathered in any public manner, e.g. GitHub issue comments, triage meetings, etc.
* Positive support to advance a stage does **not** imply:
* Commitment to eventually support a subsequent stage
* That the particular solution approach at the time of the signal or support will be the one eventually standardized (unless the advancement is to the Standardized stage)
* A negative response to advancing a stage does **not** imply:
* That the Contribution cannot continue in its current stage
* That the [Contribution](./IPR%20Policy.md#21-contribution) cannot continue in its current stage
* That a future request for support to advance a stage with a revised solution won’t succeed
* That all browsers will delay shipping the feature
* That the feature cannot continue to be incubated outside of the WHATWG
* A Contribution can advance directly to later stages without going through the earlier stages, if it's already mature enough and has sufficient support to do so.
* A [Contribution](./IPR%20Policy.md#21-contribution) can advance directly to later stages without going through the earlier stages, if it's already mature enough and has sufficient support to do so.
* **Regressing stages**
* The browser engine representatives may review Contributions and decide to regress stages—for example, if implementer support has been retracted for a particular solution (regressing from stage 3 to stage 2), or even if support has been retracted for solving the problem (i.e. a regression from stage 2 to stage 1). This situation is expected to be unusual, and should come with a very strong justification.
* The browser engine representatives may review [Contributions](./IPR%20Policy.md#21-contribution) and decide to regress stages—for example, if implementer support has been retracted for a particular solution (regressing from stage 3 to stage 2), or even if support has been retracted for solving the problem (i.e. a regression from stage 2 to stage 1). This situation is expected to be unusual, and should come with a very strong justification.

<table>
<thead>
Expand Down Expand Up @@ -67,16 +67,16 @@ Stage Name
<p>
(Incubation)
</td>
<td><ul><li>A comprehensive explainer for the Contribution, in a standards organization-approved incubation venue such as a <a href="https://www.w3.org/community/groups/">W3C CG</a> or a branch of an existing WHATWG Standard.</li>
<td><ul><li>A comprehensive explainer for the [Contribution](./IPR%20Policy.md#21-contribution), in a standards organization-approved incubation venue such as a <a href="https://www.w3.org/community/groups/">W3C CG</a> or a branch of an existing WHATWG Standard.</li>
<li>Consensus that the WHATWG is interested in exploring solutions in this problem space.</li>
<li>(At least) one implementer interested in doing prototyping work.</li>
<li>Identification of the Contributor.</li>
<li>Identification of the [Contributor](./IPR%20Policy.md#contributor).</li>
<li>Identification of a relevant WHATWG Workstream and Standard that will host the Contribution, and notification of the Workstream Editor(s).</li></ul>
</td>
<td>
<ul><li>Consensus that the problem is worth solving, and is within the scope of the WHATWG.</li>
<li>Commitment from the spec community to do work on the specification, which includes: review the spec and discussion about API improvements and adjustments.</li>
<li>The WHATWG commits to hosting a specification draft in a repository or branch (if the Contributor requests it).</li></ul>
<li>The WHATWG commits to hosting a specification draft in a repository or branch (if the [Contributor](./IPR%20Policy.md#contributor) requests it).</li></ul>
</td>
<td><ul><li>The explainer follows the guidelines at <a href="https://tag.w3.org/explainers/">https://tag.w3.org/explainers/</a>.</li></ul>
</td>
Expand All @@ -90,7 +90,7 @@ Stage Name
<li>Consensus that the rough API shape defined in the draft specification is the right approach to solve the problem, pending any significant problems found during this stage.</li></ul>
</td>
<td><ul><li>The WHATWG expects the Contribution to be developed and eventually included in the relevant WHATWG standard.</li>
<li>This stage also demonstrates commitment from the spec community to review the specification, and commitment from the Contributor to drive the addition of comprehensive tests, ideally with a prototype in at least one browser engine.</li></ul>
<li>This stage also demonstrates commitment from the spec community to review the specification, and commitment from the [Contributor](./IPR%20Policy.md#contributor) to drive the addition of comprehensive tests, ideally with a prototype in at least one browser engine.</li></ul>
</td>
<td><ul><li>The draft specification uses Web IDL to define any new JavaScript APIs, roughly matches the style of the standard it's expected to merge into, and has a processing model, including full algorithms. However, there may be rough edges or TODOs in the processing model.</li></ul>
</td>
Expand Down

0 comments on commit b2b46b7

Please sign in to comment.