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

Add a guideline for mixins #9016

Merged
merged 4 commits into from
Feb 11, 2021
Merged
Changes from 1 commit
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: 24 additions & 0 deletions docs/data-guidelines.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ This file contains recommendations to help you record data in a consistent and u
- [Removal of irrelevant features](#removal-of-irrelevant-features)
- [Removal of irrelevant flag data](#removal-of-irrelevant-flag-data)
- [Initial versions for browsers](#initial-versions-for-browsers)
- [Mixins](#mixins)

<!-- BEGIN TEMPLATE

Expand Down Expand Up @@ -256,3 +257,26 @@ If the table indicates an initial version of "1" and an information source says
If you're adding new data for Node.js, use `0.10.0` or later. If a feature was added in a version before `0.10.0`, use `0.10.0` anyway.

This guideline was proposed in [#6861](https://github.com/mdn/browser-compat-data/pull/6861).

## Mixins

Mixins appear in WebIDL and in specifications to define Web APIs. For web developers, they aren't observable directly; they act as helpers to avoid repeating API definitions. BCD doesn't expose mixins.
Elchi3 marked this conversation as resolved.
Show resolved Hide resolved

For example, [`HTMLHyperlinkElementUtils`](https://html.spec.whatwg.org/multipage/links.html#htmlhyperlinkelementutils) is a mixin defined in the HTML specification.

Members of this mixin are available to `HTMLAnchorElement` and `HTMLAreaElement`, that's where BCD exposes them, and thus there are two options to add mixin members to BCD:
Elchi3 marked this conversation as resolved.
Show resolved Hide resolved

1. Members of `HTMLHyperlinkElementUtils` are added directly to the `api/HTMLAnchorElement.json` and `api/HTMLAreaElement.json` files as if they were regular members of these interfaces.
Elchi3 marked this conversation as resolved.
Show resolved Hide resolved

2. (Large) Mixins have their own files in the `api/_mixins/` folder and indicate for which interface they are using file names like: `HTMLHyperlinkElementUtils__HTMLAnchorElement.json` and `HTMLHyperlinkElementUtils__HTMLAreaElement.json`.
Elchi3 marked this conversation as resolved.
Show resolved Hide resolved
Note that in these files you'll need to expose the data under the correct tree, so for `HTMLHyperlinkElementUtils__HTMLAnchorElement.json` the file needs to start like this:
Elchi3 marked this conversation as resolved.
Show resolved Hide resolved

```json
Elchi3 marked this conversation as resolved.
Show resolved Hide resolved
{
"api": {
"HTMLAnchorElement": {
"myFeatureName": {
"__compat": {
```

This guideline was proposed in [#8929](https://github.com/mdn/browser-compat-data/issues/8929), based in part on previous discussion in [#472](https://github.com/mdn/browser-compat-data/issues/472).