Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RFC process clarification #1971

Merged
merged 4 commits into from
Dec 18, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 18 additions & 6 deletions rfcs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,14 +66,15 @@ The "RFC" label can be used to mark PRs containing RFC/design proposals.

The RFC approval process generally follows the guidelines in the [UXL Foundation Operational Procedures](
https://github.com/uxlfoundation/uxl_operational_procedures/blob/release/Process_Documents/Organization_Operational_Process.md#review--approval-process).
Once two or more maintainers approve the PR, it is merged into the main branch
as an RFC proposed for implementation.
Once two or more maintainers approve the PR, it is merged into the main branch.

As the RFC moves to different states, use new PRs to update the RFC document
with additional information.
RFC documents can be developed iteratively at each stage. For example, an initial RFC
can be approved even if some details of the design or the API are not yet sufficiently
elaborated. In that case, subsequent revisions (new PRs) should update the document
in `rfcs/proposed`, adding the requested information.

A proposal that is subsequently implemented and released as an experimental feature
is moved into the `rfcs/experimental` folder.
is moved into the `rfcs/experimental` directory.
The RFC for such a feature should include a description
of what is required to move it from experimental to fully supported -- for
example, feedback from users, demonstrated performance improvements, etc.
Expand All @@ -84,9 +85,20 @@ changes and should therefore have a link to the section in the specification
with its formal wording.

A feature that is removed or a proposal that is abandoned or rejected will
be moved to the `rfcs/archived` folder. It should state the reasons for
be moved to the `rfcs/archived` directory. It should state the reasons for
rejection or removal.

There is no requirement that an RFC should pass all the stages in order.
A typical flow for an RFC would include at least `proposed` and `supported`;
however, any state can be skipped, depending on the progress and the needs.

For a document that describes a wide set of functionality or a general direction
and includes sub-RFCs for specific features, a few instances might simultaneously
reside in different states, adjusted as necessary to reflect the overall progress
on the direction and on its sub-proposals.

See the README files in respective directories for additional information.

## Document Style Recommendations

- Follow the document structure described in [template.md](template.md).
Expand Down
16 changes: 9 additions & 7 deletions rfcs/experimental/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,21 @@ released as experimental features in the library. An experimental
feature is expected to have an implementation that is of comparable quality
to a fully supported feature. Sufficient tests are required.

An experimental feature does not yet appear as part of the oneDPL
An experimental feature does not yet appear as part of the oneDPL
specification. Therefore, the interface and design can change.
There is no commitment to backward compatibility for experimental features.

The documents in this directory should include a list of the exit conditions
that need to be met to move the functionality from experimental to fully supported.
These conditions might include demonstrated performance improvements,
demonstrated interest from the community,
acceptance of the required specification changes, etc.
These conditions might include demonstrated performance improvements, demonstrated
interest from the community, acceptance of the required specification changes, etc.

For features that require specification changes, the document might
include wording for those changes or a link to any PRs opened
against the specification.
A document here needs to be updated if the corresponding feature undergoes
modifications while remaining experimental. Other changes, such as updates on the
exit conditions or on the implementation and usage experience, are also welcome.

For features that require specification changes prior to production, the document might
include wording for those changes or a link to any PRs opened against the specification.

Proposals in the `rfcs/experimental` directory do not remain there indefinitely.
They should move either to `rfcs/supported` when they become fully supported
Expand Down
4 changes: 3 additions & 1 deletion rfcs/proposed/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,6 @@ However, the proposed changes have not yet been implemented as a
preview or fully supported feature of the library.

RFCs in the `rfcs/proposed` directory should explain the motivation,
design, and open questions related to the proposed extension.
design, and open questions related to the proposed extension. There can be
several update iterations on a proposed RFC to clarify the necessary details
and address the questions before it is accepted for the implementation.
3 changes: 2 additions & 1 deletion rfcs/supported/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,5 @@ changes in the oneDPL specification. The RFC document should, in that case,
have a link to the formal wording in the specification.

Proposals that appear in `rfcs/supported` may be retained indefinitely to
provide insight into the design of existing features.
provide insight into the design of existing features. They could be updated
over time if the corresponding functionality is extended or modified.
17 changes: 11 additions & 6 deletions rfcs/template.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,17 @@ discussions, etc.

## Proposal

Replace the text in this section with a full and detailed description of the proposal
with highlighted consequences.
Replace the text in this section with a detailed description of the proposal
with highlighted consequences. The description can be iteratively clarified
as the proposal matures.

Depending on the kind of the proposal, the description should cover:
Depending on the kind of the proposal, the description may need to cover the following:

- New use cases supported by the extension.
- The expected performance benefit for a modification, supported with the data, if available.
- The API of extensions such as class definitions and function declarations.
- Key technical design aspects, sufficient to understand how the functionality should work
akukanov marked this conversation as resolved.
Show resolved Hide resolved
and produce the desired outcome.

A proposal should clearly outline the alternatives that were considered,
along with their pros and cons. Each alternative should be clearly separated
Expand All @@ -37,18 +40,20 @@ Pay close attention to the following aspects of the library:
- Performance implications, as performance is one of the main goals of the library.
- Dependencies and supported platforms. Does the proposal bring any new
dependencies or affect the supported configurations?
- Consistency and possible interaction with the existing library functionality.

Include short explanation and links to the related proposals, if any.
Sub-proposals could be organized as separate standalone RFCs, but this is
Sub-proposals could be organized as separate stand-alone RFCs, but this is
not mandatory. If the related change is insignificant or does not make any sense
without the original proposal, describe it in the main RFC.

Some other common subsections could be:
- Usage examples.
- Testing aspects.
- Execution plan (next steps), if approved.
- Next steps (e.g., design review, prototype, etc.), if approved.

## Open Questions

List any questions that are not sufficiently elaborated in the proposal,
need more discussion or prototyping experience, etc.
need more discussion or prototyping experience, etc. Indicate at which state
(typically, "proposed" or "experimental") a question should be addressed.
Loading