diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index af39787a..336b3dc2 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -23,6 +23,8 @@ Wording change does not require opening a GitHub Issue, as the change in the pul Similarly, a stylistic change does not necessarily require opening a GitHub Issue. It does, however, require buy-ins from the Working Group to proceed. The best way to propose this type of change is to attend one of the bi-weekly Web Machine Learning Working Group teleconference calls. A practical way to reach out to the Working Group to get invited to the teleconference call is to post a GitHub Issue giving a rough explanation of the proposed change and ask to be invited. +Follow the guidance in [SpecCodingConventions.md](SpecCodingConventions.md) for your change to ensure it aligns with best practices and existing conventions. + Bug fixes and new content changes should proceed as follows: 1. **Open an issue in GitHub Issues** with a brief description of the problem and a potential solution if it's not already obvious. A proposal or suggestion for improvement may need a bit more explanation with possible references to related information. An active issue is the best way to get attention. Members of the Working Group scan active issues constantly. 2. **Prepare the change in a pull request** and put a reference to the active issue(s) the change is addressing in the description. We prefer that a pull request is represented by a single type of change as outlined in the previous section for a speedy review and approval. Conversely, a specific change should also be captured by a single and not multiple pull requests. This helps to reduce the dependency between pull requests and the chance for the specification to be left in a transient state between multiple pull requests. Exceptions to this should be discussed and approved by the Working Group in one of our bi-weekly calls. diff --git a/SpecCodingConventions.md b/SpecCodingConventions.md new file mode 100644 index 00000000..c6426642 --- /dev/null +++ b/SpecCodingConventions.md @@ -0,0 +1,121 @@ +# Coding Conventions + +This document captures the WebNN spec repo conventions. The intended audience is editors and contributors to the specification. + +## Resources + +* [Writing Procedural Specs](https://garykac.github.io/procspec/) +* [Writing Specifications with Bikeshed](https://dlaliberte.github.io/bikeshed-intro/) +* [Bikeshed Docs](https://speced.github.io/bikeshed/) + +## Background Material + +The [Web IDL Standard](https://webidl.spec.whatwg.org/) standard defines the interface between JavaScript and an implementation of the standard. Web IDL is the interface between your spec and JavaScript. 99.99% of the time your spec shouldn't mention anything related to JavaScript outside of examples. (So nothing Normative). And that 0.01% is REALLY HARD to get right, leads to security issues, etc. + +The [Infra](https://infra.spec.whatwg.org/) standard captures the fundamental concepts on which specifications are built - algorithms, primitive data types, and structures. Most Normative spec text should be written in terms of these concepts. That said, Infra is not perfect or complete. If you need to go beyond it, look at other specs for inspiration - it's better to follow precedent. Look at open Infra issues and consider filing issues if you're in novel territory. + + +### High Level Spec Authoring Guidance + +* Earlier web specs gave high level description of behavior, e.g. input and output. But it turns out a lot of the implementation can be observable and thus lead to compatibility problems. Developers don't test everywhere or read warnings. Specifications must be complete and precise, and not leave room for interpretation. +* Specs are for a specific audience: implementers; if you try to write for developers, you're gonna have a bad time. They should be looking at MDN. +* If you define anything in two places you have twice the chances of getting it wrong. If you get out of sync, everything is wrong. Prioritize precision over readability. +* That said, non-normative notes are your friend. So-called "domintro" sections help reconcile a lot of the tensions above. They're developer-facing non-normative notes in the spec. Use simpler phrasing, don't worry as much about edge cases, etc. + + +### Bikeshed Guidance + +Think of Bikeshed as a compiler for your spec. + +* Like code: the less you write the lower your chances of having a bug. +* Prefer markdown to markup - shorter, more likely to catch errors. +* Use links to terms as often as possible. This has many benefits: + * It handles formatting automatically and reduces manual work. + * It removes ambiguity about what you're describing. + * It catches errors if you spell something incorrectly or the term changes. + * If there is nothing to link to, it is a signal that your text is not precise! +* The spec build should be warning-free and error-free. ("--die-on=warning") + + +### Definitions And Linking + +* Prefer Bikeshed [autolink shortcuts](https://speced.github.io/bikeshed/#autolink-shortcuts) where possible using markdown. These do basic type checking and will style the link appropriately. The most common forms are: + * `[=term=]` to link to a term + * `[=scope/term=]` to link to a scoped term (see below) + * `{{Type}}` to link to a type defined in Web IDL + * `{{Type/property}}` to link to a member defined in Web IDL + * `[[doc]]` to link to another document. +* Do not use HTML links `..."` except as a last resort - there is usually a way to create the link using Bikeshed and some error checking. +* Where possible, prefer auto-generated IDs for terms over explicit IDs (`data-lt`). + +Example: +``` + The maximum size of a collection is... + + 1. Let |max| be the [=maximum size=] of |collection|. +``` + +* When defining subsidiary terms, like properties of an object, members of an enum, etc, scope the definitions using `dfn-for` on the `dfn` or an ancestor. + +Example: +``` + A circle is a geometric shape. + +