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

Implement Best Practices section #50

Merged
merged 7 commits into from
Jul 6, 2022
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
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# JetBrains IDEs
/.idea/
/web/
14 changes: 14 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
.PHONY: install
install:
npm install -g respec


.PHONY: spec
spec:
respec --verbose --localhost --src spec/index.html --out web/index.html


.PHONY: serve
.ONESHELL: serve
serve:
python -m http.server --directory web 1234
26 changes: 26 additions & 0 deletions spec/code/context.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
{
"@context": {
"$base": "@base",
"$container": "@container",
"$direction": "@direction",
"$graph": "@graph",
"$id": "@id",
"$import": "@import",
"$included": "@included",
"$index": "@index",
"$json": "@json",
"$language": "@language",
"$list": "@list",
"$nest": "@nest",
"$none": "@none",
"$prefix": "@prefix",
"$propagate": "@propagate",
"$protected": "@protected",
"$reverse": "@reverse",
"$set": "@set",
"$type": "@type",
"$value": "@value",
"$version": "@version",
"$vocab": "@vocab"
}
}
13 changes: 13 additions & 0 deletions spec/code/with-convenience-context.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
"@context":
- https://prefix.cc/context
- https://yaml-ld.dev/context
- ex: https://example.org/
name:
$id: rdfs:label
$container: $language
$id: ex:Ray
$type: ex:Cat
name:
en: Ray
ua: Промiнчик
ru: Лучик
12 changes: 12 additions & 0 deletions spec/code/without-convenience-context.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
"@context":
- https://prefix.cc/context
- ex: https://example.org/
name:
"@id": rdfs:label
"@container": "@language"
"@id": ex:Ray
"@type": ex:Cat
name:
en: Ray
ua: Промiнчик
ru: Лучик
110 changes: 109 additions & 1 deletion spec/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,23 @@
"Eemeli Aro"
]
},

"json-ld-bp": {
title: "JSON-LD Best Practices",
href: "https://w3c.github.io/json-ld-bp/",
publisher: "W3C",
date: "2022-05-24",
status: "W3C Group Note",
authors: [
"Gregg Kellogg",
"Ivan Herman",
"BigBlueHat",
"A. Soroka",
"Ruben Taelman",
"David I. Lehn",
"Philippe Le Hegaret",
],
},
},

// Cross-reference definitions
Expand Down Expand Up @@ -713,6 +730,97 @@ <h3>FAQ</h3>

</p>
</section>

<section id="best-practices" class="informative">
<h2>Best Practices</h2>

<p>Here, we propose to YAML-LD users a bit of advice which, although optional, might suggest one or two
useful thoughts.</p>

<div class="practice">
<p class="practicedesc">
<span id="use-json-ld-best-practices" class="practicelab">Follow JSON-LD best practices</span>
…in order to achieve a greater level of reusability, performance, and human friendliness among YAML-LD aware
systems. The [[json-ld-bp]] document is as relevant to YAML-LD as it is to [[JSON-LD]].
</p>
</div>

<div class="practice">
<p class="practicedesc">
<span id="prebuilt-contexts" class="practicelab">Do not force users to author contexts</span>

Instead, provide pre-built contexts that the user can reference by URL for a majority of common use cases.
</p>
</div>

<p>YAML-LD is intended to simplify the authoring of Linked Data for a wide range of domain experts; its target
audience is not comprised solely of IT professionals. YAML is chosen as a medium to minimize syntactic noise,
and to keep the authored documents concise and clear. [[JSON-LD]] (and hence YAML-LD) Context comprises a special
language of its own. A requirement to <i>author</i> such a context would make the domain expert's job much
harder &mdash; which we, as system architects and developers, should try to avoid.</p>

<div class="practice">
<p class="practicedesc">
<span id="conceal-contexts" class="practicelab">Use a default context</span>
</p>

If most, or all, of a user's documents are based on one particular context, try to make it the default in order
to rescue the user from copy-pasting the same technical incantation from one document to another.
</div>

<p>For instance, according to [[json-ld-api]], the `expand()` method of a JSON-LD processor accepts an
`expandContext` argument which can be used to provide a default system context.</p>

<div class="practice">
<p class="practicedesc">
<span id="alias-keywords" class="practicelab">Alias JSON-LD keywords</span>

If possible, map JSON-LD keywords containing the `@` character to keywords that do not contain it.
</p>
</div>

<p>The `@` character is reserved in [[YAML]], and thus requires quoting (or escaping), as in the following
example:</p>

<aside class="example" data-transform="updateExample"
title="Example YAML-LD document without Convenience Context">
<pre class="yaml" data-include="code/without-convenience-context.yaml" data-include-format="text"></pre>
</aside>

<p>The need to quote these keywords has to be learnt, and introduces one more little irregularity to the document
author's life. Further, on most keyboard layouts, typing quotes will require `Shift`, which reduces typing speed,
albeit slightly.</p>

<p>In order to avoid this, the context might introduce custom mappings for the necessary keywords. For instance,
[[schema-org]] context redefines `@id` as just `id` — which seems to be much more convenient to type, and
no more difficult to remember.</p>

<div class="practice">
<p class="practicedesc">
<span id="convenience-context" class="practicelab">Use YAML-LD Convenience Context</span>
<p>YAML-LD users may use a JSON-LD context provided as part of this specification, henceforth known as the
<dfn>convenience
context</dfn>, which defines a standardized mapping of every `@`-keyword to a `$`-keyword, except `@context`.
</p>
</p>
</div>

<aside class="example" data-transform="updateExample" title="Convenience Context">
<p>Code of the <a>convenience context</a>. Available as:
<a href="https://yaml-ld.dev/context">https://yaml-ld.dev/context</a>.
</p>
<pre class="json" data-include="code/context.json" data-include-format="text"></pre>
anatoly-scherbakov marked this conversation as resolved.
Show resolved Hide resolved
</aside>

<p>The convenience context contains an alias to every JSON-LD keyword which the JSON-LD 1.1
specification permits aliasing &mdash; which means all the keywords except <code>@context</code>. The reserved `@` character is
replaced by `$`, which is not reserved and therefore does not require quoting. Consider
<strong>Example 1</strong> reformatted using the convenience context:</p>

<aside class="example" data-transform="updateExample" title="Example YAML-LD document with Convenience Context">
<pre class="yaml" data-include="code/with-convenience-context.yaml" data-include-format="text"></pre>
</aside>

<p>The applicability of this context depends on the domain and is left to the architect's best judgement.</p>
</section>
</body>
</html>