-
-
Notifications
You must be signed in to change notification settings - Fork 392
Auto linking external references
This feature is currently in beta.
You can enable automatic external reference linking (xref) in ReSpec as:
var respecConfig = {
xref: true,
};
Additional xref configuration options with usage examples can be seen here.
In most cases, you can just wrap a term in <a>
(like <a>TERM</a>
) and ReSpec will be able to link it correctly. Examples:
<a>event handler</a> <!-- https://html.spec.whatwg.org/multipage/webappapis.html#event-handlers -->
<a>URL parser</a> <!-- https://url.spec.whatwg.org/#concept-url-parser -->
<!-- The search terms here are case insensitive. -->
<!-- There is also a shorthand/inline syntax for above -->
[= event handler =] <!-- equivalent to <a>event handler</a> -->
If we want to link a term that is not defined the same way as what we want to display it to the user, we can make use of data-lt
attribute for term aliasing, as:
<a data-lt="url parser">parsing URLs</a>
<!-- shorthand syntax simplifies above as -->
[= url parser | parsing URLs =]
We can also add link to <dfn>
as shown below.
<!-- before -->
<dfn data-cite="HTML/webappapis.html#event-handlers">event handler</dfn>
<!-- now -->
<dfn class="externalDFN">event handler</dfn>
We can link IDL terms using an inline shorthand. ReSpec parses the string inside {{{ }}}
as IDL and adds corresponding external links. Examples:
<p>{{ Window }}</p>
<p>{{ Credential.[[CollectFromCredentialStore]] }}</p>
{{ Window }}
<!-- links as:
<code>
<a href="https://html.spec.whatwg.org/multipage/window-object.html#window">Window</a>
</code>
-->
{{ Window/event }} attribute.
<!--
<code>
<a href="https://dom.spec.whatwg.org/#dom-window-event">event</a>
</code>
links "event" attribute corresponding to "Window" interface (and not any other definition for "event")
-->
{{ EventTarget/addEventListener(type, callback) }}
<!--
<code>
<a href="https://dom.spec.whatwg.org/#dom-eventtarget-addeventlistener">addEventListener</a>
(<var>type</var>, <var>callback</var>)
</code>
links "addEventListener(type, callback)" method.
-->
IDL terms are case sensitive.
## Handling ambiguity
There can be cases when a term is defined in multiple specifications. Then, ReSpec will generate warnings saying "Error: Linking an ambiguous dfn". As an Editor, you will need to help ReSpec disambiguate the query.
The ambiguity could be due to a "bad context". ReSpec will point you to the terms with error, so you can make a fix, if possible.
### `data-cite`
Use [`data-cite`](data-cite) attributes to help ReSpec disambiguate results. `data-cite` attributes can be added on any element that is a parent of current linking element. The content of `data-cite` on all parent elements (other than the linking element itself) is a space separated list of spec short names that we expect the links inside that parent element to refer to.
It is recommended to add `data-cite` attribute on the `<body>`. For example, if our document refers to terms in WebIDL, Infra, DOM specs, we can add `data-cite` as:
``` html
<body data-cite="webidl infra dom">
data-cite
can be added on any element, for example, on a <section>
or <p>
. Only the closest data-cite
is used for helping in linking. The more specific the content in data-cite
is, lesser are the chances of getting an ambiguity error.
ReSpec can also make use of a common spec writing pattern to help disambiguate external terms. Example:
<p>Look in [[WEBIDL]] spec for the term <a>object</a></p>
<p>The term <a>object</a> is looked in [[html]] spec</p>
In case ReSpec cannot find find an external reference, it will give a warning saying "Error: No matching dfn found".
The warning is not necessarily due to non-existence of a term. It could be due to a "bad context". ReSpec will point you to the terms with error, so you can make a fix, if possible.
You may require to add data-cite
attributes for ReSpec to look for the term in the right spec.
💖 Support ReSpec by becoming a sponsor via Open Collective. 💖
✨ View rendered version of this documentation at https://respec.org/docs/ ✨
- addSectionLinks
- authors
- caniuse
- edDraftURI
- editors
- favicon
- format (markdown)
- formerEditors
- github
- highlightVars
- isPreview
- license
- lint
- localBiblio
- logos
- maxTocLevel
- mdn
- modificationDate
- noTOC
- otherLinks
- pluralize
- postProcess
- preProcess
- previousDiffURI
- previousMaturity
- previousPublishDate
- prevRecShortname
- prevRecURI
-
processVersion(Deprecated) - publishDate
-
refNote(Deprecated) - shortName
- specStatus
- subjectPrefix
- subtitle
- testSuiteURI
- xref
- additionalCopyrightHolders
-
addPatentNote(Deprecated) - alternateFormats
- canonicalURI
- charterDisclosureURI
- copyrightStart
- crEnd
-
darkMode(deprecated, use dark mode) - doJsonLd
- errata
- group
- implementationReportURI
- lcEnd
- level
- noRecTrack
- prevED
- submissionCommentNumber
-
wg(Deprecated) -
wgId(Deprecated) -
wgPatentPolicy(Deprecated) -
wgPatentURI(Deprecated) - wgPublicList
-
wgURI(Deprecated)
a11y
check-punctuation
local-refs-exist
no-headingless-sections
no-http-props
no-unused-vars
no-unused-dfns
informative-dfn
privsec-section
wpt-tests-exist
Handled by ReSpec for you.
- data-abbr
-
data-cite(Not recommended) - data-dfn-for
- data-dfn-type
- data-format
- data-include-format
- data-include-replace
- data-include
- data-link-for
- data-link-type
- data-local-lt
- data-lt-no-plural
- data-lt-noDefault
- data-lt
- data-number
- data-oninclude
- data-sort
- data-tests
-
data-transform(Deprecated) - data-type
- dir
- lang