Copyright © 2010-2019 W3C® (MIT, ERCIM, Keio, Beihang). W3C liability, trademark and permissive document license rules apply.
This specification defines a set of algorithms for programmatic transformations of JSON-LD documents. Restructuring data according to the defined transformations often dramatically simplifies its usage. Furthermore, this document proposes an Application Programming Interface (API) for developers implementing the specified algorithms.
This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current W3C publications and the latest revision of this technical report can be found in the W3C technical reports index at https://www.w3.org/TR/.
This document has been developed by the JSON-LD Working Group and was derived from the JSON-LD Community Group's Final Report.
There is a live JSON-LD playground that is capable of demonstrating the features described in this document.
This document was published by the JSON-LD Working Group as a Working Draft. This document is intended to become a W3C Recommendation.
GitHub Issues are preferred for discussion of this specification. Alternatively, you can send comments to our mailing list. Please send them to public-json-ld-wg@w3.org (archives).
Publication as a Working Draft does not imply endorsement by the W3C Membership. This is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to cite this document as other than work in progress.
This document was produced by a group operating under the W3C Patent Policy. W3C maintains a public list of any patent disclosures made in connection with the deliverables of the group; that page also includes instructions for disclosing a patent. An individual who has actual knowledge of a patent which the individual believes contains Essential Claim(s) must disclose the information in accordance with section 6 of the W3C Patent Policy.
This document is governed by the 1 March 2019 W3C Process Document.
This document is one of three JSON-LD 1.1 Recommendations produced by the JSON-LD Working Group:
This section is non-normative.
This document is a detailed specification of the JSON-LD processing algorithms. The document is primarily intended for the following audiences:
To understand the basics in this specification you must first be familiar with JSON, which is detailed in [RFC8259]. You must also understand the JSON-LD syntax defined in the JSON-LD 1.1 Syntax specification [JSON-LD11], which is the base syntax used by all of the algorithms in this document. To understand the API and how it is intended to operate in a programming environment, it is useful to have working knowledge of the JavaScript programming language [ECMASCRIPT] and WebIDL [WEBIDL]. To understand how JSON-LD maps to RDF, it is helpful to be familiar with the basic RDF concepts [RDF11-CONCEPTS].
This section is non-normative.
There are a number of ways that one may participate in the development of this specification:
This section is non-normative.
The following typographic conventions are used in this specification:
markupmarkup definition reference markup external definition referenceNotes are in light green boxes with a green left border and with a "Note" header in green. Notes are always informative.
Examples are in light khaki boxes, with khaki left border, and with a numbered "Example" header in khaki. Examples are always informative. The content of the example is in monospace font and may be syntax colored. Examples may have tabbed navigation buttons to show the results of transforming an example into other representations.
This document uses the following terms as defined in external specifications and defines terms specific to JSON-LD.
Terms imported from ECMAScript Language Specification [ECMASCRIPT], The JavaScript Object Notation (JSON) Data Interchange Format [RFC8259], Infra Standard [INFRA], and Web IDL [WEBIDL]
true and false that are used
    to express one of two possible states.In the internal representation a JSON object is described as a map (see [INFRA]), composed of entries with key/value pairs.
In the Application Programming Interface, a map is described using a [WEBIDL] dictionary.
@context where the value,
    or the @id of the value, is null,
    explicitly decouples a term's association with an IRI.
    A map entry in the body of a JSON-LD document
    whose value is null
    has the same meaning as if the map entry was not defined.
    If @value, @list, or @set is set to null in expanded form,
    then the entire JSON object is ignored.true, or false.Terms imported from Internationalized Resource Identifiers (IRIs) [RFC3987]
@type,
    and values of terms defined to be vocabulary relative
    are resolved relative to the vocabulary mapping,
    not the base IRI.Terms imported from RDF 1.1 Concepts and Abstract Syntax [RDF11-CONCEPTS], RDF Schema 1.1 [RDF-SCHEMA], and Linked Data Design Issues [LINKED-DATA]
_:._:.rdf:langString, an optional language tag.@language key
    whose value MUST be a string representing a [BCP47] language code or null.@graph entry,
    and MAY also have @id, and @index entries.
    A simple graph object
    is a graph object which does not have an @id entry.
    Note that node objects may have a @graph entry,
    but are not considered graph objects if they include any other entries.
    A top-level object consisting of @graph is also not a graph object.
    Note that a node object may also represent a named graph it it includes other properties.@container set to @id.
    The values of the id map MUST be node objects,
    and its keys are interpreted as IRIs representing
    the @id of the associated node object.
    If a value in the id map contains a key expanding to @id,
    it's value MUST be equivalent to the referencing key in the id map.@included or an alias of @included
    and the value is one ore more node objects.@container set to @index,
    whose values MUST be any of the following types:
    string,
    number,
    true,
    false,
    null,
    node object,
    value object,
    list object,
    set object, or
    an array of zero or more of the above possibilities.
  rdf:JSON.
    In the value object representation, the value of @type is @json.
    JSON literals represent values which are valid JSON [RFC8259].
    See JSON datatype in JSON-LD 1.1.
  true or false,
    a typed value,
    or a language-tagged string.
    It represents an RDF literal.
  @container set to @language,
    whose keys MUST be strings representing [BCP47] language codes
    and the values MUST be any of the following types:
    null,
    string, or
    an array of zero or more of the above possibilities.
  @list key.
    It may also have an @index key, but no other entries.@context keyword.@value, @list, or @set keywords, or@graph and @context.@version entry in a context,
    or via explicit API option,
    other processing modes can be accessed.
    This specification extends JSON-LD 1.0
    via the json-ld-1.1 processing mode.@context entry. It has the same form as an embedded context.
    When the term is used as a type, it defines a type-scoped context,
    when used as a property it defines a property-scoped context.
  @set entry.
    It may also have an @index key, but no other entries.@container set to @type,
    whose keys are interpreted as IRIs
    representing the @type of the associated node object;
    the value MUST be a node object, or array of node objects.
    If the value contains a term expanding to @type,
    it's values are merged with the map value when expanding.@value entry.@vocab key
    whose value MUST be an IRI, a compact IRI, a term, or null.The Following terms are used within specific algorithms.
This section is non-normative.
Note that in the examples used in this document, output is of necessity shown in serialized form as JSON. While the algorithms describe operations on the JSON-LD internal representation, when they as displayed as examples, the JSON serialization is used. In particular, the internal representation use of maps are represented using JSON objects.
{
  "@context": {
    "name": "http://xmlns.com/foaf/0.1/name",
    "knows": "http://xmlns.com/foaf/0.1/knows"
  },
  "@id": "http://me.markus-lanthaler.com/",
  "name": "Markus Lanthaler",
  "knows": [
    {
      "name": "Dave Longley"
    }
  ]
}
        In the internal representation, the example above would be of a
      map containing @context, @id, name, and knows entries,
      with either maps, strings, or arrays of
      maps or strings values. In the JSON serialization, JSON objects are used
      for maps, while arrays and strings are serialized using a
      convention common to many programming languages.
This section is non-normative.
The JSON-LD 1.1 Syntax specification [JSON-LD11] defines a syntax to express Linked Data in JSON. Because there is more than one way to express Linked Data using this syntax, it is often useful to be able to transform JSON-LD documents so that they may be more easily consumed by specific applications.
To allow these algorithms to be adapted for syntaxes other than JSON, the algorithms operate on the JSON-LD internal representation, which uses the generic concepts of arrays, maps, strings, numbers, booleans, and null to describe the data represented by a JSON document. Algorithms act on this internal representation with API entry points responsible for transforming between the concrete and internal representations.
JSON-LD uses contexts to allow Linked Data to be expressed in a way that is specifically tailored to a particular person or application. By providing a context, JSON data can be expressed in a way that is a natural fit for a particular person or application whilst also indicating how the data should be understood at a global scale. In order for people or applications to share data that was created using a context that is different from their own, a JSON-LD processor must be able to transform a document from one context to another. Instead of requiring JSON-LD processors to write specific code for every imaginable context switching scenario, it is much easier to specify a single algorithm that can remove any context. Similarly, another algorithm can be specified to subsequently apply any context. These two algorithms represent the most basic transformations of JSON-LD documents. They are referred to as expansion and compaction, respectively.
JSON-LD 1.1 introduces new features that are
    compatible with JSON-LD 1.0 [JSON-LD10],
    but if processed by a JSON-LD 1.0 processor may produce different results.
    In order to detect this JSON-LD 1.1 requires that the processing
    mode be explicitly set to json-ld-1.1, either through the
    processingMode API option, or using the
    @version map entry within a context.
There are four major types of transformation that are discussed in this document: expansion, compaction, flattening, and RDF serialization/deserialization.
This section is non-normative.
The algorithm that removes context is called expansion. Before performing any other transformations on a JSON-LD document, it is easiest to remove any context from it and to make data structures more regular.
To get an idea of how context and data structuring affects the same data, here is an example of JSON-LD that uses only terms and is fairly compact:
The next input example uses one IRI to express a property and an array to encapsulate another, but leaves the rest of the information untouched.
Note that both inputs are valid JSON-LD and both represent the same information. The difference is in their context information and in the data structures used. A JSON-LD processor can remove context and ensure that the data is more regular by employing expansion.
Expansion has two important goals: removing any contextual
      information from the document, and ensuring all values are represented
      in a regular form. These goals are accomplished by expanding all entry keys
      to absolute IRIs and by expressing all
      values in arrays in
      expanded form. Expanded form is the most verbose
      and regular way of expressing of values in JSON-LD; all contextual
      information from the document is instead stored locally with each value.
      Running the Expansion algorithm
      (expand())
      operation) against the above examples results in the following output:
[
  {
    "@id": "http://me.markus-lanthaler.com/",
    "http://xmlns.com/foaf/0.1/name": [
      { "@value": "Markus Lanthaler" }
    ],
    "http://xmlns.com/foaf/0.1/homepage": [
      { "@id": "http://www.markus-lanthaler.com/" }
    ]
  }
]
        The example above is the JSON-LD serialization of the output of the expansion algorithm, where the algorithm's use of maps are replaced with JSON objects.
Note that in the output above all context definitions have been removed, all terms and compact IRIs have been expanded to absolute IRIs, and all JSON-LD values are expressed in arrays in expanded form. While the output is more verbose and difficult for a human to read, it establishes a baseline that makes JSON-LD processing easier because of its very regular structure.
This section is non-normative.
While expansion removes context from a given input, compaction's primary function is to perform the opposite operation: to express a given input according to a particular context. Compaction applies a context that specifically tailors the way information is expressed for a particular person or application. This simplifies applications that consume JSON or JSON-LD by expressing the data in application-specific terms, and it makes the data easier to read by humans.
Compaction uses a developer-supplied context to shorten IRIs to terms or compact IRIs and JSON-LD values expressed in expanded form to simple values such as strings or numbers.
For example, assume the following expanded JSON-LD input document:
[
  {
    "@id": "http://me.markus-lanthaler.com/",
    "http://xmlns.com/foaf/0.1/name": [
      { "@value": "Markus Lanthaler" }
    ],
    "http://xmlns.com/foaf/0.1/homepage": [
      { "@id": "http://www.markus-lanthaler.com/" }
    ]
  }
]
        Additionally, assume the following developer-supplied JSON-LD context:
{
  "@context": {
    "name": "http://xmlns.com/foaf/0.1/name",
    "homepage": {
      "@id": "http://xmlns.com/foaf/0.1/homepage",
      "@type": "@id"
    }
  }
}
        Running the Compaction Algorithm
      (compact())
      operation) given the context supplied above against the JSON-LD input
      document provided above would result in the following output:
The example above is the JSON-LD serialization of the output of the compaction algorithm, where the algorithm's use of maps are replaced with JSON objects.
Note that all IRIs have been compacted to
      terms as specified in the context,
      which has been injected into the output. While compacted output is
      useful to humans, it is also used to generate structures that are easy to
      program against. Compaction enables developers to map any expanded document
      into an application-specific compacted document. While the context provided
      above mapped http://xmlns.com/foaf/0.1/name to name, it
      could also have been mapped to any other term provided by the developer.
This section is non-normative.
While expansion ensures that a document is in a uniform structure, flattening goes a step further to ensure that the shape of the data is deterministic. In expanded documents, the properties of a single node may be spread across a number of different maps. By flattening a document, all properties of a node are collected in a single map and all blank nodes are labeled with a blank node identifier. This may drastically simplify the code required to process JSON-LD data in certain applications.
For example, assume the following JSON-LD input document:
{
  "@context": {
    "name": "http://xmlns.com/foaf/0.1/name",
    "knows": "http://xmlns.com/foaf/0.1/knows"
  },
  "@id": "http://me.markus-lanthaler.com/",
  "name": "Markus Lanthaler",
  "knows": [
    {"name": "Dave Longley"}
  ]
}
        Running the Flattening Algorithm
      (flatten())
      operation) with a context set to null to prevent compaction
      returns the following document:
The example above is the JSON-LD serialization of the output of the flattening algorithm, where the algorithm's use of maps are replaced with JSON objects.
Note how in the output above all properties of a node are collected in a
      single map and how the blank node representing
      "Dave Longley" has been assigned the blank node identifier
      _:b0.
To make it easier for humans to read or for certain applications to process it, a flattened document can be compacted by passing a context. Using the same context as the input document, the flattened and compacted document looks as follows:
Please note that the result of flattening and compacting a document
      is always a map,
      (represented as a JSON object when serialized),
      which contains an @graph
      entry that represents the default graph.
This section is non-normative.
JSON-LD can be used to serialize RDF data as described in [RDF11-CONCEPTS]. This ensures that data can be round-tripped to and from any RDF syntax without any loss in fidelity.
For example, assume the following RDF input serialized in Turtle [TURTLE]:
<http://me.markus-lanthaler.com/> <http://xmlns.com/foaf/0.1/name> "Markus Lanthaler" . <http://me.markus-lanthaler.com/> <http://xmlns.com/foaf/0.1/homepage> <http://www.markus-lanthaler.com/> .
Using the Serialize RDF as JSON-LD Algorithm a developer could transform this document into expanded JSON-LD:
[
  {
    "@id": "http://me.markus-lanthaler.com/",
    "http://xmlns.com/foaf/0.1/name": [
      { "@value": "Markus Lanthaler" }
    ],
    "http://xmlns.com/foaf/0.1/homepage": [
      { "@id": "http://www.markus-lanthaler.com/" }
    ]
  }
]
        The example above is the JSON-LD serialization of the output of the Serialize RDF as JSON-LD Algorithm, where the algorithm's use of maps are replaced with JSON objects.
Note that the output above could easily be compacted using the technique outlined in the previous section. It is also possible to deserialize the JSON-LD document back to RDF using the Deserialize JSON-LD to RDF Algorithm.
As well as sections marked as non-normative, all authoring guidelines, diagrams, examples, and notes in this specification are non-normative. Everything else in this specification is normative.
The key words MAY, MUST, MUST NOT, and SHOULD in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.
There are two classes of products that can claim conformance to this specification: JSON-LD Processors, and RDF Serializers/Deserializers.
A conforming JSON-LD Processor is a system which can perform the Expansion, Compaction, and Flattening operations in a manner consistent with the algorithms defined in this specification.
JSON-LD Processors MUST NOT attempt to correct malformed IRIs or language tags; however, they MAY issue validation warnings. IRIs are not modified other than conversion between relative and absolute IRIs.
A conforming RDF Serializer/Deserializer is a system that can deserialize JSON-LD to RDF and serialize RDF as JSON-LD as defined in this specification.
The algorithms in this specification are generally written with more concern for clarity than efficiency. Thus, JSON-LD Processors may implement the algorithms given in this specification in any way desired, so long as the end result is indistinguishable from the result that would be obtained by the specification's algorithms.
In algorithm steps that describe operations on keywords, those steps also apply to keyword aliases.
Implementers can partially check their level of conformance to this specification by successfully passing the test cases of the JSON-LD test suite [JSON-LD-TESTS]. Note, however, that passing all the tests in the test suite does not imply complete conformance to this specification. It only implies that the implementation conforms to aspects tested by the test suite.
This specification makes use of the following namespace prefixes:
| Prefix | IRI | 
|---|---|
| rdf | http://www.w3.org/1999/02/22-rdf-syntax-ns# | 
| xsd | http://www.w3.org/2001/XMLSchema# | 
When processing a JSON-LD data structure, each processing rule is applied using information provided by the active context. This section describes how to produce an active context.
The active context contains the active term definitions which specify how keys and values have to be interpreted as well as the current base IRI, the vocabulary mapping, the default language, and an optional previous context, used when a non-propagated context is defined. Each term definition consists of:
A term definition can not only be used to map a term to an IRI, but also to map a term to a keyword, in which case it is referred to as a keyword alias.
When processing, active context is initialized without any term definitions, vocabulary mapping, or default language. If a local context is encountered during processing, a new active context is created by cloning the existing active context. Then the information from the local context is merged into the new active context. Given that local contexts may contain references to remote contexts, this includes their retrieval.
This section is non-normative.
First we prepare a new active context result by cloning the current active context. Then we normalize the form of the original local context to an array. Local contexts may be in the form of a map, a string, or an array containing a combination of the two. Finally we process each context contained in the local context array as follows.
Unless specified using
        processingMode API option,
        the processing mode is set using the @version entry
        in a local context and
        affects the behavior of algorithms including expansion and compaction.
If context is a string, it represents a reference to
        a remote context. We dereference the remote context and replace context
        with the value of the @context entry of the top-level object in the
        retrieved JSON-LD document.
        If there's no such entry, an
        invalid remote context
        has been detected. Otherwise, we process context by recursively using
        this algorithm ensuring that there is no cyclical reference.
If context is a map,
        it is a context definition.
        We first update the
        base IRI, the vocabulary mapping, processing mode, and the
        default language by processing three specific keywords:
        @base, @vocab, @version, and @language.
        These are handled before any other entries in the local context because
        they affect how the other entries are processed.
        If context contains @import, it is retrieved and is reverse-merged
          into the containing context, allowing JSON-LD 1.0 contexts to be uplifed to JSON-LD 1.1.
        Please note that @base is ignored when processing remote contexts.
If context is not to be propagated, a reference to the previous context is retained so that it may be rolled back when a new node object is entered. By default, all contexts are propagated, other than type-scoped contexts.
Then, for every other entry in local context, we update the term definition in result. Since term definitions in a local context may themselves contain terms or compact IRIs, we may need to recurse. When doing so, we must ensure that there is no cyclical dependency, which is an error. After we have processed any term definition dependencies, we update the current term definition, which may be a keyword alias.
Finally, we return result as the new active context.
This algorithm specifies how a new active context is updated
        with a local context. The algorithm takes two required
        and three optional
        input variables.
        The required inputs are an active context and a local context.
        The optional inputs are an array remote contexts,
        defaulting to a new empty array, which is used to detect cyclical context inclusions,
        
          override protected, defaulting to false,
          which is used to allow changes to protected terms,
          and propagate, defaulting to true
          to mark term definitions associated with non-propagated contexts..
      
@propagate,
          its value MUST be boolean true or false,
          set propagate to that value.false, and result
          does not have a previous context, set previous context
          in result to active context.null:
              false and active context
                  contains any protected term definitions,
                  an invalid context nullification
                  has been detected and processing is aborted.false.
                  Continue with the next context.
                  In JSON-LD 1.0, the base IRI was given
                    a default value here; this is now described conditionally
                    in § 9. The Application Programming Interface.context overflow
                  error has been detected and processing is aborted;
                  otherwise, add context to remote contexts.LoadDocumentCallback, passing context
                  for url,
                  and http://www.w3.org/ns/json-ld#context for profile
                  and for requestProfile.loading remote context failed
                  error has been detected and processing is aborted. If the dereferenced document has no
                  top-level map with an @context entry, an
                  invalid remote context
                  has been detected and processing is aborted; otherwise,
                  set context to the value of that entry.invalid local context
              error has been detected and processing is aborted.@version entry:
              1.1,
                  an invalid @version value
                  has been detected, and processing is aborted.json-ld-1.0,
                  a processing mode conflict
                  error has been detected and processing is aborted.json-ld-1.1, if not already set.@import entry:
              json-ld-1.0,
                  an invalid context entry
                  error has been detected and processing is aborted.invalid @import value
                  error has been detected and processing is aborted.@import against
                  the base IRI which is established as specified in
                  section 5.1 Establishing a Base URI
                  of [RFC3986]. Only the basic algorithm in
                  section 5.2
                  of [RFC3986] is used; neither
                  Syntax-Based Normalization nor
                  Scheme-Based Normalization
                  are performed. Characters additionally allowed in IRI
                  references are treated in the same way that unreserved
                  characters are treated in URI references, per
                  section 6.5
                  of [RFC3987].LoadDocumentCallback, passing import
                  for url,
                  and http://www.w3.org/ns/json-ld#context for profile
                  and for requestProfile.loading remote context failed
                  error has been detected and processing is aborted.@context entry,
                  or if the value of @context is not a context definition
                  (i.e., it is not an map),
                  an invalid remote context
                  has been detected and processing is aborted; otherwise,
                  set import context to the value of that entry.@import entry,
                  an invalid context entry
                  error has been detected and processing is aborted.@base entry and remote contexts is empty, i.e., the currently
              being processed context is not a remote context:
              @base entry.null, remove the
                  base IRI of result.null,
                  set the base IRI of result to the result of
                  resolving value against the current base IRI
                  of result.invalid base IRI
                  error has been detected and processing is aborted.@vocab entry:
              @vocab entry.true for vocab, and
                    true for document relative.
                  .
                  If it is not an IRI, or a blank node identifier, an
                  invalid vocab mapping
                  error has been detected and processing is aborted.
                  @vocab is obsolete,
                    and may be removed in a future version of JSON-LD.@language entry:
              @language entry.null, remove
                  any default language from result.invalid default language
                  error has been detected and processing is aborted.@propagate entry:
              json-ld-1.0,
                  an invalid context entry
                  error has been detected and processing is aborted.true or false,
                  an invalid @propagate value
                  error has been detected and processing is aborted.@base,
              @import,
              @language,
              @propagate,
              @protected,
              @version, or
              @vocab,
              invoke the
              Create Term Definition algorithm,
              passing result for active context,
              context for local context, key,
              defined,
              
                the value of the @protected
                entry from context, if any, for protected,
                and propagate
              .
            This algorithm is called from the Context Processing algorithm to create a term definition in the active context for a term being processed in a local context.
This section is non-normative.
Term definitions are created by parsing the information in the given local context for the given term. If the given term is a compact IRI, it may omit an IRI mapping by depending on its prefix having its own term definition. If the prefix is an entry in the local context, then its term definition must first be created, through recursion, before continuing. Because a term definition can depend on other term definitions, a mechanism must be used to detect cyclical dependencies. The solution employed here uses a map, defined, that keeps track of whether or not a term has been defined or is currently in the process of being defined. This map is checked before any recursion is attempted.
After all dependencies for a term have been defined, the rest of the information in the local context for the given term is taken into account, creating the appropriate IRI mapping, container mapping, and type mapping or language mapping for the term.
The algorithm has four required and three optional inputs.
        The required inputs are
        an active context, a local context,
        a term, and a map defined.
        The optional inputs are
          protected which defaults to false,
          override protected, defaulting to false,
          which is used to allow changes to protected terms,
          and propagate, defaulting to true..
        
true (indicating that the
          term definition has already been created), return. Otherwise,
          if the value is false, a
          cyclic IRI mapping
          error has been detected and processing is aborted.false. This indicates that the term definition
          is now being created but is not yet complete.json-ld-1.1
          and term is @type, value
          MUST be a map with the entry @container
          and value @set. Any other value means that a
          keyword redefinition error has
          been detected and processing is aborted.keyword redefinition
          error has been detected and processing is aborted.null,
          convert it to a map consisting of a single entry whose
          key is @id and whose value is null.@id and whose value is value.
          Set simple term to true.invalid term definition
          error has been detected and processing is aborted.
          Set simple term to false.@protected entry in value
          is true, or there is no @protected entry in value
          and the protected parameter is true,
          set the protected in definition to true.@type:
          @type entry, which MUST be a string. Otherwise, an
              invalid type mapping
              error has been detected and processing is aborted.true for vocab,
              local context, and defined. If the expanded type is
              neither @id, nor @vocab,
              nor, if processing mode is json-ld-1.1, @json nor @none,
              nor an absolute IRI, an
              invalid type mapping
              error has been detected and processing is aborted.@reverse:
          @id or @nest, entries, an
              invalid reverse property
              error has been detected and processing is aborted.@reverse entry
              is not a string, an
              invalid IRI mapping
              error has been detected and processing is aborted.@reverse entry for value, true
              for vocab,
              local context, and defined. If the result
              is neither an absolute IRI nor a blank node identifier,
              i.e., it contains no colon (:), an
              invalid IRI mapping
              error has been detected and processing is aborted.@container entry,
              set the container mapping of definition
              to its value; if its value is neither @set, nor
              @index, nor null, an
              invalid reverse property
              error has been detected (reverse properties only support set- and
              index-containers) and processing is aborted.true.true and return.false.@id and its value
          does not equal term:
          @id entry
              is null, the term is not used for IRI expansion, but is
              retained to be able to detect future redefinitions of this term.@id entry is not a string, an
              invalid IRI mapping
              error has been detected and processing is aborted.@id entry for
              value, true for vocab,
              local context, and defined. If the resulting
              IRI mapping is neither a keyword, nor an
              absolute IRI, nor a blank node identifier, an
              invalid IRI mapping
              error has been detected and processing is aborted; if it equals @context, an
              invalid keyword alias
              error has been detected and processing is aborted.:)
              anywhere but as the last character of term,
              and the result of expanding term
              using the IRI Expansion algorithm
              is not the same as the IRI mapping of definition,
              an invalid IRI mapping
              error has been detected and processing is aborted.:),
              simple term is true, and the,
              IRI mapping of definition ends with a URI
              gen-delim character,
              set the prefix flag in definition to true.:):
          @type, set the IRI mapping
          of definition to @type.invalid IRI mapping
          error been detected and processing is aborted.@container:
          @container entry, which MUST be either
              @graph,
              @id,
              @index,
              @language,
              @list,
              @set, or
              @type.
              
                or an array containing exactly any one of those
                keywords, an array containing @graph and
                either @id or @index optionally
                including @set, or an array containing a
                combination of @set and any of
                @index, @id, @type,
                @language in any order
              .
              Otherwise, an
              invalid container mapping
              has been detected and processing is aborted.json-ld-1.0 and the container value
              is @graph, @id, or @type, or is otherwise not a string, an
              invalid container mapping
              has been detected and processing is aborted.@type:
              @id.@id nor @vocab,
                  an invalid type mapping
                  error has been detected and processing is aborted.@index:
          json-ld-1.0 or
              container mapping does not include @index,
              an invalid term definition
              has been detected and processing is aborted.@index entry, which MUST a string expanding to an absolute IRI.
              Otherwise, an
              invalid term definition
              has been detected and processing is aborted.@context:
          json-ld-1.0, an
              invalid term definition
              has been detected and processing is aborted.@context entry, which is treated as a local context.true for override protected.
              If any error is detected, an
              invalid scoped context error
              has been detected and processing is aborted.
              The result of the Context Processing algorithm is discarded; it is called to detect errors at definition time. If used, the context will be re-processed and applied to the active context as part of expansion or compaction.
@language and
          does not contain the entry @type:
          @language entry, which MUST be either null
              or a string. Otherwise, an
              invalid language mapping
              error has been detected and processing is aborted.@nest:
          json-ld-1.0, an
              invalid term definition
              has been detected and processing is aborted.@nest entry, which MUST be a string and
              MUST NOT be a keyword other than @nest. Otherwise, an
              invalid @nest value
              error has been detected and processing is aborted.@prefix:
          json-ld-1.0, or if
              term contains a colon (:), an
              invalid term definition
              has been detected and processing is aborted.@prefix entry, which MUST be a boolean. Otherwise, an
              invalid @prefix value
              error has been detected and processing is aborted.@id,
          @reverse, @container,
          @context, @language, @nest,
          @prefix, or @type, an
          invalid term definition error has
          been detected and processing is aborted.false
          and previous definition exists and is protected;
          protected term redefinition error has been detected,
              and processing is aborted.true.In JSON-LD documents, some keys and values may represent IRIs. This section defines an algorithm for transforming a string that represents an IRI into an absolute IRI or blank node identifier. It also covers transforming keyword aliases into keywords.
IRI expansion may occur during context processing or during any of the other JSON-LD algorithms. If IRI expansion occurs during context processing, then the local context and its related defined map from the Context Processing algorithm are passed to this algorithm. This allows for term definition dependencies to be processed via the Create Term Definition algorithm.
This section is non-normative.
In order to expand value to an absolute IRI, we must
        first determine if it is null, a term, a
        keyword alias, or some form of IRI. Based on what
        we find, we handle the specific kind of expansion; for example, we expand
        a keyword alias to a keyword and a term
        to an absolute IRI according to its IRI mapping
        in the active context. While inspecting value we
        may also find that we need to create term definition
        dependencies because we're running this algorithm during context processing.
        We can tell whether or not we're running during context processing by
        checking local context against null.
        We know we need to create a term definition in the
        active context when value is
        an entry in the local context and the defined map
        does not have an entry for value with an associated value of
        true. The defined map is used during
        Context Processing to keep track of
        which terms have already been defined or are
        in the process of being defined. We create a
        term definition by using the
        Create Term Definition algorithm.
The algorithm takes two required and four optional input variables. The
        required inputs are an active context and a value
        to be expanded. The optional inputs are two flags,
        document relative and vocab, that specifying
        whether value can be interpreted as a relative IRI
        against the document's base IRI or the
        active context's
        vocabulary mapping, respectively, and
        a local context and a map defined to be used when
        this algorithm is used during Context Processing.
        If not passed, the two flags are set to false and
        local context and defined are initialized to null.
null,
          return value as is.null, it contains
          an entry with a key that equals value, and the value of the entry
          for value in defined is not true,
          invoke the Create Term Definition algorithm,
          passing active context, local context,
          value as term, and defined. This will ensure that
          a term definition is created for value in
          active context during Context Processing.
        true and the
          active context has a term definition for
          value, return the associated IRI mapping.:), it is either
          an absolute IRI, a compact IRI, or a
          blank node identifier:
          :)._)
              or suffix begins with double-forward-slash
              (//), return value as it is already an
              absolute IRI or a blank node identifier.null, it
              contains a prefix entry, and the value
              of the prefix entry in defined
              is not true, invoke the
              Create Term Definition algorithm,
              passing active context,
              local context, prefix as term,
              and defined. This will ensure that a
              term definition is created for prefix
              in active context during
              Context Processing.null IRI mapping
                and the prefix flag of the term definition is true,
              return the result of concatenating the IRI mapping
              associated with prefix and suffix.
              A more conservative change, although more involved,
                would to restrict looking at the prefix flag unless
                the processing mode is json-ld-1.1.
true, and
          active context has a vocabulary mapping,
          return the result of concatenating the vocabulary mapping
          with value.true
          set value to the result of resolving value against
          the base IRI. Only the basic algorithm in
          section 5.2
          of [RFC3986] is used; neither
          Syntax-Based Normalization nor
          Scheme-Based Normalization
          are performed. Characters additionally allowed in IRI references are treated
          in the same way that unreserved characters are treated in URI references, per
          section 6.5
          of [RFC3987].This algorithm expands a JSON-LD document, such that all context definitions are removed, all terms and compact IRIs are expanded to absolute IRIs, blank node identifiers, or keywords and all JSON-LD values are expressed in arrays in expanded form.
This section is non-normative.
Starting with its root element, we can process the JSON-LD document recursively, until we have a fully expanded result. When expanding an element, we can treat each one differently according to its type, in order to break down the problem:
null, there is nothing
          to expand.Finally, after ensuring result is in an array, we return result.
The algorithm takes three required and three optional input variables.
        The required inputs are an active context,
        an active property, and an element to be expanded.
        The optional inputs are the
          frameExpansion
          flag allowing special forms of input used for frame expansion,
          the ordered flag, used to order
          map entry keys lexicographically, where noted,
          and the from map flag, used to control reverting
          previous term definitions in the active context associated with non-propagated contexts.
        To begin, the active property is set to null,
        and element is set to the JSON-LD input.
        If not passed, the both flags are set to false.
The algorithm also performs processing steps specific to expanding
        a JSON-LD Frame. For a frame, the @id and
        @type entries can accept an array of IRIs or
        an empty map. The entries of a value object can also
        accept an array of strings, or an empty map.
        Framing also uses additional keyword entries:
        (@explicit, @default,
        @embed, @explicit, @omitDefault, or
        @requireAll) which are preserved through expansion.
        Special processing for a JSON-LD Frame is invoked when the
        frameExpansion flag is set to true.
As mentioned in Terms [JSON-LD11],
        to avoid forward-compatibility issues, terms should not start with an
        @ character as future versions of JSON-LD may introduce
        additional keywords.
        This algorithm will treat such terms like any other term, i.e., they are ignored unless mapped to an IRI.
        Implementations of this algorithm may consider providing a
        runtime flag to show a warning if such terms are encountered.
The use of empty terms ("") is not
        allowed as not all programming languages are able to handle empty JSON keys.
        Implementations of this algorithm may consider providing a
        runtime flag to show a warning if such terms are encountered.
The use of blank node identifiers to label properties is obsolete, and may be removed in a future version of JSON-LD. Implementations of this algorithm may consider providing a runtime flag to show a warning if such terms are encountered.
null, return null.@default,
          set the frameExpansion flag to false.null or @graph,
              drop the free-floating scalar by returning null.frameExpansion
                    ordered,
                    and from map flags.@list,
                  and expanded item is an
                  array, set expanded item to a new
                  map containing the entry
                  @list where the value is the original
                  expanded item.false,
          and element does not contain a entry expanding to @value,
          and element does not consist of a single entry expanding to @id,
          set active context to previous context from active context,
          as the scope of a term-scoped context does not apply when processing new node objects.@context, set
          active context to the result of the
          Context Processing algorithm,
          passing active context and the value of the
          @context entry as local context.@type using the
          IRI Expansion algorithm,
          passing active context, key for
          value, and true for vocab:
          true for propagate.@type, ordering entries lexicographically by key.
        ordered is true:
          @context, continue to
              the next key.true for vocab.null or it neither
              contains a colon (:) nor it is a keyword,
              drop key by continuing to the next key.@reverse, an
                  invalid reverse property map
                  error has been detected and processing is aborted.@included or @type,
                  a colliding keywords
                  error has been detected and processing is aborted.@id and
                  value is not a string, an
                  invalid @id value
                  error has been detected and processing is aborted. Otherwise,
                  set expanded value to the result of using the
                  IRI Expansion algorithm,
                  passing active context, value, and true
                  for document relative.
                  
                    When the frameExpansion flag is set, value
                    may be an empty map, or an array of one
                    or more strings. expanded value will be
                    an array of one or more of these, with string
                    values expanded using the IRI Expansion Algorithm.@type and value
                  is neither a string nor an array of
                  strings, an
                  invalid type value
                  error has been detected and processing is aborted. Otherwise,
                  set expanded value to the result of using the
                  IRI Expansion algorithm, passing
                  type-scoped context for active context,
                  true for vocab,
                  and true for document relative to expand the value
                  or each of its items.
                  If result already has an entry for @type,
                    prepend the value of @type in result to expanded value,
                    transforming it into an array, if necessary.
                  
                    When the frameExpansion flag is set, value
                    may also be an empty map.
                  
                  
                @graph, set
                  expanded value to the result of using this algorithm
                  recursively passing active context, @graph
                  for active property, value for element,
                  and the frameExpansion
                    and ordered flags,
                  
                    ensuring that expanded value is an array of one or more maps.@included
                  and processing mode is json-ld-1.1,
                  set expanded value to the result of using
                  this algorithm recursively passing active context,
                  active property, value for element,
                  and the frameExpansion
                  and ordered flags,
                  ensuring that the result is an array.
                  If any element of included result is not a node object,
                  an invalid @included value
                  error has been detected and processing is aborted.
                  If result already has an entry for @include,
                  prepend the value of @include in result to expanded value.@value,
                  processing mode is json-ld-1.1, and
                    input type is @json,
                    set expanded value to value.
                    Otherwise, if
                  value is not a scalar or null, an
                  invalid value object value
                  error has been detected and processing is aborted. Otherwise,
                  set expanded value to value. If expanded value
                  is null, set the @value
                  entry of result to null and continue with the
                  next key from element. Null values need to be preserved
                  in this case as the meaning of an @type entry depends
                  on the existence of an @value entry.
                  
                    When the frameExpansion flag is set, value
                    may also be an empty map or an array of
                    scalar values. expanded value will be null, or an
                    array of one or more scalar values.@language and
                  value is not a string, an
                  invalid language-tagged string
                  error has been detected and processing is aborted.
                  
                    Otherwise, set expanded value to lowercased value.
                    When the frameExpansion flag is set, value
                    may also be an empty map or an array of zero or
                    strings. expanded value will be an
                    array of one or more string values converted to lower case.@index and
                  value is not a string, an
                  invalid @index value
                  error has been detected and processing is aborted. Otherwise,
                  set expanded value to value.@list:
                  null or
                      @graph, continue with the next key
                      from element to remove the free-floating list.frameExpansion
                        and ordered flags.@set, set
                  expanded value to the result of using this algorithm
                  recursively, passing active context,
                  active property, value for element,
                  and the frameExpansion
                    and ordered flags.@reverse and
                  value is not a map, an
                  invalid @reverse value
                  error has been detected and processing is aborted. Otherwise
                  @reverse as active property,
                      value as element,
                      and the frameExpansion
                        and ordered flags.@reverse entry,
                      i.e., properties that are reversed twice, execute for each of its
                      property and item the following steps:
                      
                    @reverse:
                      @reverse entry, create
                          one and set its value to an empty map.@reverse entry in result
                          using the variable reverse map.@reverse:
                          invalid reverse property value
                                  has been detected and processing is aborted.@nest,
                  add key to nests, initializing it to an empty array,
                  if necessary.
                  Continue with the next key from element.frameExpansion flag is set,
                  if expanded property is any other
                  framing keyword (@explicit, @default,
                  @embed, @explicit, @omitDefault, or
                  @requireAll),
                  set expanded value to the result of performing the
                  Expansion Algorithm
                  recursively, passing active context,
                  active property, value for element,
                  and the frameExpansion
                    and ordered flags.null, set
                  the expanded property entry of result to
                  expanded value.@json,
              set expanded value to a new map, set the entry
              @value to value, and set the entry @type to @json.@language and
              value is a map then value
              is expanded from a language map
              as follows:
              ordered is true:
                  null,
                          otherwise an
                          invalid language map value
                          error has been detected and processing is aborted.@value-item)
                          and (@language-lowercased
                          language),
                          unless item is null.
                          If language is @none,
                            or expands to @none, do not set the @language entry.@index,
              @type, or @id and
              value is a map then value
              is expanded from an map as follows:
              @index, if it does not exist.ordered is true:
                  @type:
                      true
                      for vocab.frameExpansion
                        and ordered flags.@graph,
                          set item to a new map containing the key-value pair
                          @graph-item,
                          ensuring that the value is represented using an array.@index,
                          index key is not @index,
                          item does not have an entry @index
                          and expanded index is not @none,
                          set index property values to the concatenation of
                          expanded index with any existing values of
                          index key in item.
                          Add the key-value pair (expanded index-index property values) to item.
                          If item is a value object,
                          it MUST NOT contain any extra properties;
                          an invalid value object
                          error has been detected and processing is aborted.@index,
                          item does not have an entry @index,
                          and expanded index is not @none,
                          add the key-value pair (@index-index) to item.@id
                          and item does not have the entry @id,
                          add the key-value pair (@id-expanded index) to item,
                          where expanded index is set to the result of using the
                          IRI Expansion algorithm,
                          passing active context, index, and true
                          for document relative, unless expanded index
                          is already set to @none.@type
                          set types to the concatenation of expanded index
                          with any existing values of @type in item.
                          If expanded index is @none,
                          do not concatenate expanded index to types.
                          Add the key-value pair (@type-types) to item.frameExpansion
                and ordered flags.null, ignore key
              by continuing to the next key from element.@list and
              expanded value is not already a list object,
              convert expanded value to a list object
              by first setting it to an array containing only
              expanded value if it is not already an array,
              and then by setting it to a map containing
              the key-value pair @list-expanded value.@graph, convert expanded value into an array, if necessary,
              then convert each value ev in expanded value into a
              graph object:
              @graph-ev
                  where ev is represented as an array.@reverse entry, create
                  one and initialize its value to an empty map.@reverse entry in result
                  using the variable reverse map.invalid reverse property value
                      has been detected and processing is aborted.@value, an
                      invalid @nest value error
                      has been detected and processing is aborted.@value:
          @value, @language, @type,
              and @index. It must not contain both a
              @language entry and an @type entry.
              Otherwise, an
              invalid value object
              error has been detected and processing is aborted.@value entry is
              null, then set result to null.@type entry
              is @json, then the @value entry may
              contain any value, and is treated as a JSON literal.@value entry
              is not a string and result contains the entry
              @language, an
              invalid language-tagged value
              error has been detected (only strings
              can be language-tagged) and processing is aborted.@type entry
              and its value is not an IRI, an
              invalid typed value
              error has been detected and processing is aborted.@type
          and its associated value is not an array, set it to
          an array containing only the associated value.@set
          or @list:
          @index. Otherwise, an
              invalid set or list object
              error has been detected and processing is aborted.@set, then
              set result to the entry's associated value.@language, set result to null.null or @graph,
          drop free-floating values as follows:
          
        If, after the above algorithm is run, the result is a
        map that contains only an @graph entry, set the
        result to the value of @graph's value. Otherwise, if the result
        is null, set it to an empty array. Finally, if
        the result is not an array, then set the result to an
        array containing only the result.
Some values in JSON-LD can be expressed in a compact form. These values are required to be expanded at times when processing JSON-LD documents. A value is said to be in expanded form after the application of this algorithm.
This section is non-normative.
If active property has a type mapping in the
        active context set to @id or @vocab,
        and the value is a string,
        a map with a single entry @id whose
        value is the result of using the
        IRI Expansion algorithm on value
        is returned.
Otherwise, the result will be a map containing
        an @value entry whose value is the passed value.
        Additionally, an @type entry will be included if there is a
        type mapping associated with the active property
        or an @language entry if value is a
        string and there is language mapping associated
        with the active property.
Note that values interpreted as IRIs fall into two categories:
        those that are document relative, and those that are
        vocabulary relative. Properties and values of @type,
        along with terms marked as "@type": "@vocab"
        are vocabulary relative, meaning that they need to be either
        a defined term, a compact IRI
        where the prefix is a term,
        or a string which is turned into an absolute IRI using
        the vocabulary mapping.
The algorithm takes three required inputs: an active context, an active property, and a value to expand.
@id,
          and the value is a string,
          return a new
          map containing a single entry where the
          key is @id and the value is the result of using the
          IRI Expansion algorithm, passing
          active context, value, and true for
          document relative.@vocab,
          and the value is a string,
          return a new
          map containing a single entry where the
          key is @id and the value is the result of using the
          IRI Expansion algorithm, passing
          active context, value, true for
          vocab, and true for
          document relative.@value entry whose value is set to
          value.@id, @vocab, or @none,
          add an @type entry to
          result and set its value to the value associated with the
          type mapping.@language to result and set its
              value to the language code associated with the
              language mapping; unless the
              language mapping is set to null in
              which case no such entry is added.@language
              to result and set its value to the
              default language.This algorithm compacts a JSON-LD document, such that the given context is applied. This must result in shortening any applicable IRIs to terms or compact IRIs, any applicable keywords to keyword aliases, and any applicable JSON-LD values expressed in expanded form to simple values such as strings or numbers.
This section is non-normative.
Starting with its root element, we can process the JSON-LD document recursively, until we have a fully compacted result. When compacting an element, we can treat each one differently according to its type, in order to break down the problem:
@index or @language
          maps.The final output is a map with an @context
        entry, if a non-empty context was given, where the map
        is either result or a wrapper for it where result appears
        as the value of an (aliased) @graph entry because result
        contained two or more items in an array.
The algorithm takes four required and two optional input variables.
        The required inputs are an active context,
        an inverse context, an active property,
        and an element to be compacted.
        The optional inputs are the
          compactArrays flag
          and the ordered flag, used to order
          map entry keys lexicographically, where noted.
        To begin, the active context is set to the result of
        performing Context Processing
        on the passed context, the inverse context is
        set to the result of performing the
        Inverse Context Creation algorithm
        on active context, the active property is
        set to null, element is set to the result of
        performing the Expansion algorithm
        on the JSON-LD input.
        If not passed, the both flags are set to false.
compactArrays
                    and ordered flags.null, then append
                  it to result.1),
              
                active property is not @graph or @set,
                or the container mapping for active property in
                active context does not include @list or @set,
              
              and compactArrays
              is true, set result to its only item.@value entry,
          and element does not consist of a single @id entry,
          set active context to previous context from active context,
          as the scope of a term-scoped context does not apply when processing new node objects.true for override protected.@value or @id
          entry and the result of using the
          Value Compaction algorithm,
          passing active context, inverse context,
          active property,and element as value is
          a scalar,
          or the term definition for active property
            has a type mapping of @json,
          return that result.@list,
          return the result of using this algorithm recursively, passing
          active context, inverse context,
          active property, value of @list
          in element for element,
          and the compactArrays
            and ordered flags.true if
          active property equals @reverse,
          otherwise to false.@type entry,
          create a new array compacted types initialized
          by transforming each expanded type of that entry
          into it's compacted form using the IRI Compaction algorithm,
          passing active context, inverse context,
          expanded type for var, true for vocab,
          and false for propagate.
          Then, for each term
          in compacted types ordered lexicographically:
          ordered is true:
          @id:
              true for vocab.@type:
              true for vocab.@type array:
                  true for vocab.1), then
                      set compacted value to its only item.true for vocab.json-ld-1.1,
                  and the term definition for alias in the
                  active context has a container mapping including @set,
                  ensure that compacted value is an array.@reverse:
              @reverse for
                  active property, expanded value
                  for element,
                  and the compactArrays
                    and ordered flags.@set or
                          compactArrays
                          is false, and value is not an
                          array, set value to a new
                          array containing only value.@reverse for var,
                      and true for vocab.@preserve
              then:
              compactArrays
                    and ordered flags.@preserve
                  in result unless expanded value is an empty array.@index and
              active property has a container mapping
              in active context that includes @index,
              then the compacted result will be inside of an @index
              container, drop the @index entry by continuing
              to the next expanded property.@index,
              @value, or @language:
              true for vocab.true for vocab, and
                  inside reverse.@nest, or a term in the
                  active context that expands to @nest,
                  otherwise an invalid @nest
                  value error has been detected, and processing is aborted.
                  If result does not have a nest term entry,
                  initialize it to an empty map (nest object).
                  If nest object does not have an item active property entry,
                  set this entry's
                  value in nest object to an empty
                  array.Otherwise, if the entry's value is not an
                  array, then set it to one containing only the value.true for vocab, and
                  inside reverse.@nest, or a term in the
                  active context that expands to @nest,
                  otherwise an invalid @nest
                  value error has been detected, and processing is aborted.
                  Set nest result to the value of nest term in result,
                  initializing it to a new map, if necessary; otherwise
                  set nest result to result.null. If there
                  is a container mapping for
                  item active property in active context,
                  set container to the first
                  such value other than @set.true or false depending on if the container mapping for
                  item active property in active context
                  includes @set or if item active property
                  is @graph or @list.@list
                  and is not a graph object containing @list,
                  otherwise pass the value of the entry for element.
                  Along with the compactArrays
                    and ordered flags@list:
                      @list for var, and compacted item
                          for value and the value is the original compacted item.@index, then add an entry
                          to compacted item where the key is the
                          result of the IRI Compaction algorithm,
                          passing active context, inverse context,
                          @index as var, and the value associated with the
                          @index entry in expanded item as value.@graph and @id:
                      @id in expanded item
                          or @none if no such value exists as var, with vocab set to true
                          if there is no @id entry in expanded item.true,
                          set compacted item to an array containing that value.@graph and @index
                      and expanded item is a simple graph object:
                      @index in
                          expanded item or @none, if no such
                          value exists.true,
                          set compacted item to an array containing that value.@graph
                      and expanded item is a simple graph object
                      the value cannot be represented as a map object.
                      true,
                          set compacted item to an array containing that value.@included as
                          var, and true for
                          vocab and the original compacted item as the value. @graph
                      or otherwise does not match one of the previous cases, redo compacted item.
                      @graph as
                          var, and true for
                          vocab using the original
                          compacted item as a value.@id entry,
                          add the key resulting from calling the IRI Compaction algorithm
                          passing active context, inverse context, @id as
                          var, and true for
                          vocab using the value resulting from calling the IRI Compaction algorithm
                          passing active context, inverse context, the value of @id
                          in expanded item as
                          var.@index entry,
                          add the key resulting from calling the IRI Compaction algorithm
                          passing active context, inverse context, @index as
                          var, and true for
                          vocab using the value of @index
                          in expanded item.true,
                          set compacted item to an array
                          containing that value.@language,
                  @index, @id,
                    or @type
                    and container does not include @graph:
                  @language, @index, @id, or @type
                      based on the contents of container, as var, and true
                      for vocab.@index, if no such value exists.@language and
                      expanded item contains a
                      @value entry, then set compacted item
                      to the value associated with its @value entry.
                      Set map key to the value of @language in expanded item, if any.@index
                      and index key is @index,
                      set map key to the value of @index in expanded item, if any,
                      and remove container key from compacted item.@index
                      and index key is not @index,
                      set map key to the first value of container key in compacted item, if any.
                      If there are remaining values in compacted item
                      for container key, set the value of
                      container key in compacted item
                      to those remaining values. Otherwise, remove that
                      entry from compacted item.
                    @id, set
                      map key to the value of container key in
                      compacted item and remove container key from compacted item.@type:
                      @id, set compacted item
                          to the result of using
                          this algorithm recursively, passing
                          active context, inverse context,
                          item active property for active property,
                          and a map composed of the single entry for @id from expanded item for element.
                          
                        true,
                      set compacted item to an array containing that value.null, set it to the result of calling the
                      IRI Compaction algorithm
                      passing active context, inverse context, @none as
                      var, and true for
                      vocab.compactArrays
                      is false, as array is true and
                      compacted item is not an array,
                      set it to a new array
                      containing only compacted item.If, after the algorithm outlined above is run, result
        is an empty array, replace it with a new map.
        Otherwise, if result is an array, replace it with a new
        map with a single entry whose key is the result
        of using the IRI Compaction algorithm,
        passing active context, inverse context, and
        @graph as var and whose value is the array
        result.
Finally, if a non-empty context has been passed,
        add an @context entry to result and set its value
        to the passed context.
When there is more than one term that could be chosen to compact an IRI, it has to be ensured that the term selection is both deterministic and represents the most context-appropriate choice whilst taking into consideration algorithmic complexity.
In order to make term selections, the concept of an inverse context is introduced. An inverse context is essentially a reverse lookup table that maps container mapping, type mappings, and language mappings to a simple term for a given active context. A inverse context only needs to be generated for an active context if it is being used for compaction.
To make use of an inverse context, a list of preferred container mapping and the type mapping or language mapping are gathered for a particular value associated with an IRI. These parameters are then fed to the Term Selection algorithm, which will find the term that most appropriately matches the value's mappings.
This section is non-normative.
To create an inverse context for a given
        active context, each term in the
        active context is visited, ordered by length, shortest
        first (ties are broken by choosing the lexicographically least
        term). For each term, an entry is added to
        the inverse context for each possible combination of
        container mapping and type mapping
        or language mapping that would legally match the
        term. Illegal matches include differences between a
        value's type mapping or language mapping and
        that of the term. If a term has no
        container mapping, type mapping, or
        language mapping (or some combination of these), then it
        will have an entry in the inverse context using the special
        key @none. This allows the
        Term Selection algorithm to fall back
        to choosing more generic terms when a more
        specifically-matching term is not available for a particular
        IRI and value combination.
The algorithm takes one required input: the active context that the inverse context is being created for.
@none. If the
          active context has a default language,
          set default language to it.null,
              term cannot be selected during compaction,
              so continue to the next term.@none.
              
                If the container mapping is not empty, set container
                to the concatenation of all values of the container mapping
                in lexicographically order
              .@language and its value is a new empty
              map, the second entry is @type
              and its value is a new empty map,
              and the third entry is @any
                and its value is a new map with the entry
                @none set to the term being processed.@none:
              @language
                  entry in type/language map using the variable
                  language map.@any
                  entry, create one and set its value to the term
                  being processed.@type
                  entry in type/language map using the variable
                  type map.@any
                  entry, create one and set its value to the term
                  being processed.@type
                  entry in type/language map using the variable
                  type map.null):
              @language
                  entry in type/language map using the variable
                  language map.null,
                  set language to @null; otherwise set it
                  to the language code in language mapping.@language
                  entry in type/language map using the variable
                  language map.@none
                  entry, create one and set its value to the term
                  being processed.@type
                  entry in type/language map using the variable
                  type map.@none
                  entry, create one and set its value to the term
                  being processed.This algorithm compacts an IRI to a term or compact IRI, or a keyword to a keyword alias. A value that is associated with the IRI may be passed in order to assist in selecting the most context-appropriate term.
This section is non-normative.
If the passed IRI is null, we simply
        return null. Otherwise, we first try to find a term
        that the IRI or keyword can be compacted to if
        it is relative to active context's
        vocabulary mapping. In order to select the most appropriate
        term, we may have to collect information about the passed
        value. This information includes which
        container mapping
        would be preferred for expressing the value, and what its
        type mapping or language mapping is. For
        JSON-LD lists, the type mapping
        or language mapping will be chosen based on the most
        specific values that work for all items in the list. Once this
        information is gathered, it is passed to the
        Term Selection algorithm, which will
        return the most appropriate term to use.
If no term was found that could be used to compact the
        IRI, an attempt is made to compact the IRI using the
        active context's vocabulary mapping,
        if there is one. If the IRI could not be compacted, an
        attempt is made to find a compact IRI.
        A term will be used to create a compact IRI
          only if the term definition contains the prefix flag
          with the value true.
        If there is no appropriate compact IRI,
        and the compactToRelative option is true,
        the IRI is
        transformed to a relative IRI using the document's
        base IRI. Finally, if the IRI or
        keyword still could not be compacted, it is returned
        as is.
In the case were this algorithm would return the input IRI as is, and that IRI can be mistaken for a compact IRI in the active context, this algorithm will raise an error, because it has no way to return an unambiguous representation of the original IRI.
This algorithm takes three required inputs and three optional inputs.
        The required inputs are an active context, an inverse context,
        and the var to be compacted. The optional inputs are a value associated
        with the var, a vocab flag which specifies whether the
        passed var should be compacted using the
        active context's
        vocabulary mapping, and a reverse flag which specifies whether
        a reverse property is being compacted. If not passed, value is set to
        null and vocab and reverse are both set to
        false.
null, return null.true and var is an
          entry of inverse context:
          @none.@preserve, use the first
              element from the value of @preserve as value.@language,
              and type/language value to @null. These two
              variables will keep track of the preferred
              type mapping or language mapping for
              a term, based on what is compatible with value.@index entry,
              and value is not a graph object
              then append the values @index and @index@set to containers.true, set type/language
              to @type, type/language value to
              @reverse, and append @set to containers.@index is not an entry in value, then
                  append @list to containers.@list entry in value.null. If
                  list is empty, set common language to
                  default language.@none and
                      item type to @none.@value entry:
                      
                    @id.null, set it
                      to item language.@value entry, then set common language
                      to @none because list items have conflicting
                      languages.null, set it
                      to item type.@none because list items have conflicting
                      types.@none and
                      common type is @none, then
                      stop processing items in the list because it has been
                      detected that there is no common language or type amongst
                      the items.null, set it to
                  @none.null, set it to
                  @none.@none then set
                  type/language to @type and
                  type/language value to common type.@index entry,
                  append the values @graph@index and @graph@index@set
                  to containers.@id entry,
                  append the values @graph@id and @graph@id@set
                  to containers.@graph @graph@set,
                  and @set
                  to containers.@index entry,
                  append the values @graph@index and @graph@index@set
                  to containers.@id entry,
                  append the values @graph@id and @graph@id@set
                  to containers.@index and @index@set
                  to containers.@type
                  and set type/language value to @id.@language entry
                      and does not contain an @index entry,
                      then set type/language value to its associated
                      value and, append @language
                      and @language@set to
                      containers.@type entry, then set type/language value to
                      its associated value and set type/language to
                      @type.@type
                  and set type/language value to @id,
                  and append @id, @id@set,
                    @type, and @set@type,
                  to containers.@set to containers.@none to containers. This represents
              the non-existence of a container mapping, and it will
              be the last container mapping value to be checked as it
              is the most generic.json-ld-1.1 and value does not contain an @index entry, append
              @index and @index@set to containers.
            json-ld-1.1 and value contains only an @value entry, append
              @language and @language@set to containers.
            null, set it to
              @null. This is the key under which null values
              are stored in the inverse context entry.@reverse, append
              @reverse to preferred values.@id or @reverse
              and value has an @id entry:
              @id entry in value for
                  var, and true for vocab has a
                  term definition in the active context
                  with an IRI mapping that equals the value associated
                  with the @id entry in value,
                  then append @vocab, @id, and
                  @none, in that order, to preferred values.@id, @vocab, and
                  @none, in that order, to preferred values.@none, in
              that order, to preferred values.
              If value is an empty list object,
                set type/language to @any.@any to preferred values.null, return term.true and
          active context has a vocabulary mapping:
          null. This variable will be used to
          store the created compact IRI, if any.null,
              its IRI mapping equals var, its
              IRI mapping is not a substring at the beginning of
              var,
               or the term definition does not contain
                the prefix flag having a value of true,
              the term cannot be used as a prefix.
              Continue with the next term.:), and the substring of var
              that follows after the value of the
              term definition's
              IRI mapping.null, candidate is
              shorter or the same length but lexicographically less than
              compact IRI and candidate does not have a
              term definition in active context, or if the
              term definition has an IRI mapping
              that equals var and value is null,
              set compact IRI to candidate.null, return compact IRI.true,
          and var has no IRI authority (beginning with double-forward-slash (//),
          an IRI confused with prefix error has been detected,
          and processing is aborted.false,
          transform var to a relative IRI using
          the base IRI from active context, if it exists.This algorithm, invoked via the IRI Compaction algorithm, makes use of an active context's inverse context to find the term that is best used to compact an IRI. Other information about a value associated with the IRI is given, including which container mapping and which type mapping or language mapping would be best used to express the value.
This section is non-normative.
The inverse context's entry for the IRI will be first searched according to the preferred container mapping, in the order that they are given. Amongst terms with a matching container mapping, preference will be given to those with a matching type mapping or language mapping, over those without a type mapping or language mapping. If there is no term with a matching container mapping then the term without a container mapping that matches the given type mapping or language mapping is selected. If there is still no selected term, then a term with no type mapping or language mapping will be selected if available. No term will be selected that has a conflicting type mapping or language mapping. Ties between terms that have the same mappings are resolved by first choosing the shortest terms, and then by choosing the lexicographically least term. Note that these ties are resolved automatically because they were previously resolved when the Inverse Context Creation algorithm was used to create the inverse context.
This algorithm has five required inputs. They are: an inverse context, a keyword or IRI var, an array containers that represents an ordered list of preferred container mapping, a string type/language that indicates whether to look for a term with a matching type mapping or language mapping, and an array representing an ordered list of preferred values for the type mapping or language mapping to look for.
null.This section is non-normative.
The following examples are intended to illustrate how the term selection algorithm behaves for different term definitions and values. It is not comprehensive, but intended to illustrate different parts of the algorithm.
If the term definition has "@container": "@language", it will only match a
          value object having no @type.
If the term definition has a datatype, it will only match a value object having a matching datatype.
Expansion transforms all values into expanded form in JSON-LD. This algorithm performs the opposite operation, transforming a value into compacted form. This algorithm compacts a value according to the term definition in the given active context that is associated with the value's associated active property.
This section is non-normative.
The value to compact has either an @id or an
        @value entry.
For the former case, if the type mapping of
        active property is set to @id or @vocab
        and value consists of only an @id entry and, if
        the container mapping of active property
        includes @index, an @index entry, value
        can be compacted to a string by returning the result of
        using the IRI Compaction algorithm
        to compact the value associated with the @id entry.
        Otherwise, value cannot be compacted and is returned as is.
For the latter case, it might be possible to compact value
        just into the value associated with the @value entry.
        This can be done if the active property has a matching
        type mapping or language mapping and there
        is either no @index entry or the container mapping
        of active property includes @index. It can
        also be done if @value is the only entry in value
        (apart an @index entry in case the container mapping
        of active property includes @index) and
        either its associated value is not a string, there is
        no default language, or there is an explicit
        null language mapping for the
        active property.
This algorithm has four required inputs: an active context, an inverse context, an active property, and a value to be compacted.
@index entry and the
          container mapping associated to active property
          includes @index, decrease number entries by
          1.2, return
          value as it cannot be compacted.@none,
          leave value as is, as value compaction is disabled.
          @type in value with the result of using the
              IRI compaction algorithm,
              passing active context, inverse context,
              the value of the @type entry for var, and
              true for vocab.true for vocab.@id entry:
          1 and
              the type mapping of active property
              is set to @id, return the result of using the
              IRI compaction algorithm,
              passing active context, inverse context,
              and the value of the @id entry for var.1 and
              the type mapping of active property
              is set to @vocab, return the result of using the
              IRI compaction algorithm,
              passing active context, inverse context,
              the value of the @id entry for var, and
              true for vocab.@type entry whose
          value matches the type mapping of active property,
          return the value associated with the @value entry
          of value.@language entry whose
          value matches the language mapping of
          active property, return the value associated with the
          @value entry of value.1 and either
          the value of the @value entry is not a string,
          or the active context has no default language,
          or the language mapping of active property
          is set to null, return the value associated with the
          @value entry.@type in value with the result of using the
              IRI compaction algorithm,
              passing active context, inverse context,
              the value of the @type entry for var, and
              true for vocab.true for vocab.This algorithm flattens an expanded JSON-LD document by collecting all properties of a node in a single map and labeling all blank nodes with blank node identifiers. This resulting uniform shape of the document, may drastically simplify the code required to process JSON-LD data in certain applications.
This section is non-normative.
First, a node map is generated using the Node Map Generation algorithm which collects all properties of a node in a single map. In the next step, the node map is converted to a JSON-LD document in flattened document form. Finally, if a context has been passed, the flattened document is compacted using the Compaction algorithm before being returned.
The algorithm takes one required and two optional input variables.
        The required input is an element to flatten.
        The optional inputs are the context used to compact the flattened document
        and the ordered flag, used to order
          map entry keys lexicographically, where noted.
        If not passed, context is set to null
        and, the ordered flag is set to false.
This algorithm uses the Generate Blank Node Identifier algorithm to generate new blank node identifiers and relabel existing blank node identifiers. The Generate Blank Node Identifier algorithm maintains an identifier map to ensure that blank node identifiers in the source document are consistently remapped to new blank node identifiers avoiding collisions. Thus, before this algorithm is run, the identifier map is reset.
@default and whose value is
          an empty map.@default
          entry of node map, which is a map representing
          the default graph.@default,
          ordered lexicographically by graph name
          if ordered is true,
          perform the following steps:
          @id entry whose value is set to graph name.@graph entry to entry and set it to an
              empty array.ordered is true,
              add node to the @graph entry of entry,
              unless the only entry of node is @id.ordered is true,
          add node to flattened,
          unless the only entry of node is @id.null, return flattened.ordered flag
          ensuring that the compaction result has only the @graph keyword (or its alias)
          at the top-level other than @context, even if the context is empty or if there is only one element to
          put in the @graph array. This ensures that the returned
          document has a deterministic structure.This algorithm creates a map node map holding an indexed
      representation of the graphs and nodes
      represented in the passed expanded document. All nodes that are not
      uniquely identified by an IRI get assigned a (new) blank node identifier.
      The resulting node map will have an map entry for every graph in the document whose
      value is another object with a entry for every node represented in the document.
      The default graph is stored under the @default entry, all other graphs are
      stored under their graph name.
This section is non-normative.
The algorithm recursively runs over an expanded JSON-LD document to
        collect all entries of a node
        in a single map. The algorithm updates a
        map node map whose keys represent the
        graph names used in the document
        (the default graph is stored under the @default entry)
        and whose associated values are maps
        which index the nodes in the
        graph. If a
        entry's value is a node object,
        it is replaced by a node object consisting of only an
        @id entry. If a node object has no @id
        entry or it is identified by a blank node identifier,
        a new blank node identifier is generated. This relabeling
        of blank node identifiers is
        also done for properties and values of
        @type.
The algorithm takes as input an expanded JSON-LD document element and a reference to
        a map node map. Furthermore it has the optional parameters
        active graph (which defaults to @default), an active subject,
        active property, and a reference to a map list. If
        not passed, active subject, active property, and list are
        set to null.
null, set node to null
          otherwise reference the active subject entry of graph using the
          variable subject node.@type entry, perform for each
          item the following steps:
          @value entry, perform the following steps:
          null:
              @list entry of list.@list entry, perform
          the following steps:
          @list whose value is initialized to an empty array.@list entry for element, node map, active graph,
              active subject, active property, and
              result for list.null,
              append result to the value of the active property entry
              of subject node.@list entry of list.@id entry, set id
              to its value and remove the entry from element. If id
              is a blank node identifier, replace it with a newly
              generated blank node identifier
              passing id for identifier.null for identifier.@id whose
              value is id.null, perform the following steps:
              @id whose value is id.null:
                  @list entry of list.@type entry, append
              each item of its associated array to the
              array associated with the @type entry of
              node unless it is already in that array. Finally
              remove the @type entry from element.@index entry, set the @index
              entry of node to its value. If node has already an
              @index entry with a different value, a
              conflicting indexes
              error has been detected and processing is aborted. Otherwise, continue by
              removing the @index entry from element.@reverse entry:
              @id whose
                  value is id.@reverse entry of
                  element.@reverse entry from element.@graph entry, recursively invoke this
              algorithm passing the value of the @graph entry for element,
              node map, and id for active graph before removing
              the @graph entry from element.@included entry,
              recursively invoke this algorithm passing the value of the `@included entry for element,
              node map, and active graph
              before removing the @included entry from element.This algorithm is used to generate new blank node identifiers or to relabel an existing blank node identifier to avoid collision by the introduction of new ones.
This section is non-normative.
The simplest case is if there exists already a blank node identifier
        in the identifier map for the passed identifier, in which
        case it is simply returned. Otherwise, a new blank node identifier
        is generated. If the passed identifier is not null,
        an entry is created in the identifier map associating the
        identifier with the blank node identifier.
The algorithm takes a single input variable identifier which may
        be null. The algorithm
        maintains an identifier map to relabel existing
        blank node identifiers to new blank node identifiers,
        which is reset when the invoking algorithm is initialized.
null and has an entry in the
          identifier map, return the mapped identifier.null, create a new entry
          for identifier in identifier map and set its value
          to the new blank node identifier.
      One way of generating new blank node identifiers is to maintain a counter
      and increment it when generating a new identifier and appending it to
      a string such as _:b.
    
This algorithm creates a new map of subjects to nodes using all graphs contained in the graph map created using the Node Map Generation algorithm to create merged node objects containing information defined for a given subject in each graph contained in the node map.
This section describes algorithms to deserialize a JSON-LD document to an RDF dataset and vice versa. The algorithms are designed for in-memory implementations with random access to map elements.
This algorithm deserializes a JSON-LD document to an RDF dataset. Please note that RDF does not allow a blank node to be used as a property, while JSON-LD does. Therefore, by default triples that would have contained blank nodes as properties are discarded when interpreting JSON-LD as RDF.
The use of blank node identifiers to label properties is obsolete, and may be removed in a future version of JSON-LD.
Implementations MUST generate only well-formed triples and graph names:
This section is non-normative.
The JSON-LD document is expanded and converted to a node map using the
        Node Map Generation algorithm.
        This allows each graph represented within the document to be
        extracted and flattened, making it easier to process each
        node object.
        Each graph from the node map is processed to extract triple,
        to which any (non-default) graph name is applied to create an RDF dataset.
        Each node object in the node map has an @id entry
        which corresponds to the subject,
        the other entries represent predicates.
        Each entry value is either an IRI or blank node identifier
        or can be transformed to anRDF literal
        to generate an triple.
        Lists are transformed into an RDF collection
        using the List to RDF Conversion algorithm.
The algorithm takes a map node map, which
        is the result of the Node Map Generation algorithm and
        an RDF dataset dataset into which new graphs and triples are added.
        Unless the produceGeneralizedRdf option
        is set to true, triple
        containing a blank node predicate
        are excluded from output.
The use of blank node identifiers to label properties is obsolete,
        and may be removed in a future version of JSON-LD,
        as is the support for generalized RDF Datasets
        and thus the produceGeneralizedRdf option may be also be removed.
@default, set
              set triples to the value of the defaultGraph
              attribute of dataset.
              Otherwise, initialize graph as an empty RdfGraph
              and add to dataset using its
              add method along with graph name
              for graphName.@type, then for each
                      type in values,
                      create a new RdfTriple
                      composed of subject, rdf:type for predicate,
                      and type for object
                      and add to triples
                      using its add method,
                      unless type is not well-formed.produceGeneralizedRdf option is not true,
                      continue with the next property-values pair.
                      produceGeneralizedRdf option may be also be removed.null, indicating a
                          non-well-formed resource
                          that has to be ignored.RdfTriple instances from
                          list triples to triples using
                          its using its add method.This algorithm takes a node object, list object, or value object
      and transforms it into an resource to be used as the object of an triple.
      If a node object containing a relative IRI is passed to
      the algorithm, null is returned which then causes the resulting
      triple to be ignored.
      If the input is a list object, it will also
        return the triples created from that input.
This section is non-normative.
Value objects are transformed to
        RDF literals as described in
        § 8.6 Data Round Tripping
        whereas node objects are transformed
        to IRIs,
        blank node identifiers,
        or null.
The algorithm takes as two arguments item which MUST be either a value object, list object, or node object and list triples, which is an empty array.
@id entry is
          not well-formed, return
          null.@id entry.@list entry from
          item and list triples.
        @value
          entry in item.
        @type entry of item or null if
          item does not have such a entry.null.@language
          entry which is not well-formed, return null.@json,
          convert value to the canonical lexical form
          using the result of transforming the internal representation of value
          to JSON and set datatype to rdf:JSON.
          true or
          false, set value to the string
          true or false which is the
          canonical lexical form as described in
          § 8.6 Data Round Tripping
          If datatype is null, set it to
          xsd:boolean.xsd:double, convert value to a
          string in canonical lexical form of
          an xsd:double as defined in [XMLSCHEMA11-2]
          and described in
          § 8.6 Data Round Tripping.
          If datatype is null, set it to
          xsd:double.xsd:integer, convert value to a
          string in canonical lexical form of
          an xsd:integer as defined in [XMLSCHEMA11-2]
          and described in
          § 8.6 Data Round Tripping.
          If datatype is null, set it to
          xsd:integer.null, set it to
          xsd:string or rdf:langString, depending on if
          item has an @language entry.@language entry, add the value associated with the
          @language entry as the language tag of literal.List Conversion is the process of taking a list object and transforming it into an RDF collection as defined in RDF Semantics [RDF11-MT].
This section is non-normative.
For each element of the list a new blank node identifier
        is allocated which is used to generate rdf:first and
        rdf:rest. The
        algorithm returns the list head, which is either the first allocated
        blank node identifier or rdf:nil if the
        list is empty. If a list element represents a relative IRI,
        the corresponding rdf:first triple is omitted.
The algorithm takes two inputs: an array list and an empty array list triples used for returning the generated triples.
rdf:nil.null, append a triple
              composed of subject, rdf:first, and object
              to list triples.rdf:nil. Append a
              triple composed of subject,
              rdf:rest, and rest to list triples.rdf:nil if bnodes is empty.This algorithm serializes an RDF dataset consisting of a default graph and zero or more named graphs into a JSON-LD document.
In the RDF abstract syntax, RDF literals have a lexical form, as defined in [RDF11-CONCEPTS]. The form of these literals is used when creating JSON-LD values based on these literals.
This section is non-normative.
Iterate through each graph in the dataset, converting each
        RDF collection into a list
        and generating a JSON-LD document in expanded form for all
        RDF literals, IRIs
        and blank node identifiers.
        If the useNativeTypes flag is set to true,
        RDF literals with a
        datatype IRI
        that equals xsd:integer or xsd:double are converted
        to a JSON numbers and RDF literals
        with a datatype IRI
        that equals xsd:boolean are converted to true or
        false based on their
        lexical form
        as described in
        § 8.6 Data Round Tripping.
        Unless the useRdfType flag is set to true, rdf:type
        predicates will be serialized as @type as long as the associated object is
        either an IRI or blank node identifier.
The algorithm takes one required and three optional inputs: an RDF dataset  dataset
        and the three flags useNativeTypes, useRdfType,
        and the ordered flag, used to order
          map entry keys lexicographically, where noted
        that all default to false.
The dataset is iterable to iterate over graphs and graph names
        contained within the RdfDataset. Each graph is also iterable
        for iterating over triples contained within the RdfGraph.
@default whose value references
          default graph.@default, otherwise to the
              graph name associated with graph.@id
              whose value is name.@id whose value is
                  set to subject.@id whose value is
                  set to object.rdf:type, the
                  useRdfType flag is not true, and object
                  is an IRI or blank node identifier,
                  append object to the value of the @type
                  entry of node; unless such an item already exists.
                  If no such entry exists, create one
                  and initialize it to an array whose only item is
                  object. Finally, continue to the next
                  triple.useNativeTypes.rdf:nil, it represents
                  the termination of an RDF collection:
                  
                false.rdf:nil entry, continue
              with the next name-graph object pair as the graph does
              not contain any lists that need to be converted.rdf:nil entry
              of graph object.usages entry of
              nil, perform the following steps:
              node entry of usage, property to
                  the value of the property entry of usage,
                  and head to the value of the value entry
                  of usage.rdf:rest,
                  the value of the @id entry
                    of node is a blank node identifier,
                  the value of the entry of referenced once associated with the @id
                  entry of node is a map,
                  node has rdf:first and rdf:rest entries,
                  both of which have as value an array consisting of a single element,
                  and node has no other entries apart from an optional @type
                  entry whose value is an array with a single item equal to
                  rdf:List,
                  node represents a well-formed list node.
                  Perform the following steps to traverse the list backwards towards its head:
                  rdf:first entry of
                      node to the list array.@id entry of
                      node to the list nodes array.@id
                      entry of node.node entry
                      of node usage, property to the value of the
                      property entry of node usage, and
                      head to the value of the value entry
                      of node usage.@id entry of node is an
                      IRI instead of a blank node identifier,
                      exit the while loop.@id entry from head.@list entry to head and initialize
                  its value to the list array.ordered is true:
          
        This algorithm transforms an RDF literal to a JSON-LD value object and a RDF blank node or IRI to an JSON-LD node object.
This section is non-normative.
RDF literals are transformed to
        value objects whereas IRIs and
        blank node identifiers are
        transformed to node objects.
        Literals with datatype rdf:JSON
          are transformed into a value object using the internal representation
          based on the lexical-to-value mapping defined in
          JSON datatype in [JSON-LD11],
          and @type of @json.
        If the useNativeTypes flag is set to true,
        RDF literals with a
        datatype IRI
        that equals xsd:integer or xsd:double are converted
        to a JSON numbers and RDF literals
        with a datatype IRI
        that equals xsd:boolean are converted to true or
        false based on their
        lexical form
        as described in
        § 8.6 Data Round Tripping.
This algorithm takes two required inputs: a value to be converted
        to a map and a flag useNativeTypes.
@id whose value is set to
          value.nulluseNativeTypes is true
              xsd:string, set
                  converted value to the
                  lexical form
                  of value.xsd:boolean, set
                  converted value to true if the
                  lexical form
                  of value matches true, or false
                  if it matches false. If it matches neither,
                  set type to xsd:boolean.xsd:integer or
                  xsd:double and its
                  lexical form
                  is a valid xsd:integer or xsd:double
                  according [XMLSCHEMA11-2], set converted value
                  to the result of converting the
                  lexical form
                  to a JSON number.json-ld-1.1,
              and value is a JSON literal,
              set the @value entry to the result of
              turning the lexical value of value
              into the JSON-LD internal representation, and set type to @json.@language to result and set its value to the
              language tag of value.xsd:string which is ignored.@value to result whose value
              is set to converted value.null, add a entry @type
              to result whose value is set to type.When deserializing JSON-LD to RDF
      JSON-native numbers are automatically
      type-coerced to xsd:integer or xsd:double
      depending on whether the number has a non-zero fractional part
      or not (the result of a modulo‑1 operation), the boolean values
      true and false are coerced to xsd:boolean,
      and strings are coerced to xsd:string.
      The JSON, numeric, or boolean values themselves are converted to
      canonical lexical form, i.e., a deterministic string
      representation as defined in [XMLSCHEMA11-2].
The canonical lexical form of an integer, i.e., a
      number with no non-zero fractional part
      and an exponent less than 21,
      or a number coerced to xsd:integer,
      is a finite-length sequence of decimal
      digits (0-9) with an optional leading minus sign; leading
      zeros are prohibited. In JavaScript, implementers can use the following
      snippet of code to convert an integer to
      canonical lexical form:
(value).toFixed(0).toString()
The canonical lexical form of a double, i.e., a
      number
      which cannot be represented as an integer,
      or a number
      coerced to xsd:double, consists of a mantissa followed by the
      character E, followed by an exponent. The mantissa is a
      decimal number and the exponent is an integer. Leading zeros and a
      preceding plus sign (+) are prohibited in the exponent.
      If the exponent is zero, it is indicated by E0. For the
      mantissa, the preceding optional plus sign is prohibited and the
      decimal point is required. Leading and trailing zeros are prohibited
      subject to the following: number representations must be normalized
      such that there is a single digit which is non-zero to the left of
      the decimal point and at least a single digit to the right of the
      decimal point unless the value being represented is zero. The
      canonical representation for zero is 0.0E0.
      xsd:double's value space is defined by the IEEE
      double-precision 64-bit floating point type [IEEE-754-2008] whereas
      the value space of JSON numbers is not
      specified; when deserializing JSON-LD to RDF the mantissa is rounded to
      15 digits after the decimal point. In JavaScript, implementers
      can use the following snippet of code to convert a double to
      canonical lexical form:
(value).toExponential(15).replace(/(\d)0*e\+?/,'$1E')
The canonical lexical form of the boolean
      values true and false are the strings
      true and false.
The canonical lexical form of a JSON literal value is non-normative, as a normative recommendation for JSON canonicalization is not yet defined. Implementations SHOULD use the following guidelines when creating the lexical representation of a JSON literal:
U+0000 through U+001F
        using lowercase hexadecimal Unicode notation (\uhhhh) unless in the set
        of predefined JSON control characters U+0008, U+0009,
        U+000A, U+000C or U+000D
        which SHOULD be serialized as \b, \t, \n, \f and \r respectively.
        All other Unicode characters SHOULD be serialized "as is", other than
        U+005C (\) and U+0022 (")
        which SHOULD be serialized as \\ and \" respectively.The JSON Canonicalization Scheme [JCS] is an emerging standard for JSON canonicalization not yet ready to be referenced. When a JSON canonicalization standard becomes available, this specification will likely be updated to require such a canonical representation. Users are cautioned from depending on the JSON literal lexical representation as an RDF literal, as the specifics of serialization may change in a future revison of this document.
When JSON-native numbers are deserialized
      to RDF, lossless data round-tripping cannot be guaranteed, as rounding
      errors might occur. When
      serializing RDF as JSON-LD,
      similar rounding errors might occur. Furthermore, the datatype or the lexical
      representation might be lost. An xsd:double with a value
      of 2.0 will, e.g., result in an xsd:integer
      with a value of 2 in canonical lexical form
      when converted from RDF to JSON-LD and back to RDF. It is important
      to highlight that in practice it might be impossible to losslessly
      convert an xsd:integer to a number because
      its value space is not limited. While the JSON specification [RFC8259]
      does not limit the value space of numbers
      either, concrete implementations typically do have a limited value
      space.
To ensure lossless round-tripping the
      Serialize RDF as JSON-LD Algorithm
      specifies a useNativeTypes flag which controls whether
      RDF literals
      with a datatype IRI
      equal to xsd:integer, xsd:double, or
      xsd:boolean are converted to their JSON-native
      counterparts. If the useNativeTypes flag is set to
      false, all literals remain in their original string
      representation.
Some JSON serializers, such as PHP's native implementation in some versions,
      backslash-escape the forward slash character. For example, the value
      http://example.com/ would be serialized as http:\/\/example.com\/.
      This is problematic as other JSON parsers might not understand those escaping characters.
      There is no need to backslash-escape forward slashes in JSON-LD. To aid
      interoperability between JSON-LD processors, forward slashes MUST NOT be
      backslash-escaped.
This API provides a clean mechanism that enables developers to convert JSON-LD data into a variety of output formats that are often easier to work with.
The JSON-LD API uses Promises to represent the result of the various asynchronous operations. Promises are defined in [ECMASCRIPT]. General use within specifications can be found in [promises-guide].
JsonLdProcessor InterfaceThe JsonLdProcessor interface is the high-level programming structure
      that developers use to access the JSON-LD transformation methods.
It is important to highlight that implementations do not modify the input parameters.
      If an error is detected, the Promise is
      rejected passing a JsonLdError with the corresponding error
      code
      and processing is stopped.
If the documentLoader
      option is specified, it is used to dereference remote documents and contexts.
      The documentUrl
      in the returned RemoteDocument
      is used as base IRI and the
      contextUrl
      is used instead of looking at the HTTP Link Header directly. For the sake of simplicity, none of the algorithms
      in this document mention this directly.
[Exposed=Window]
interface JsonLdProcessor {
  constructor();
  static Promise<JsonLdDictionary> compact(
    JsonLdInput input,
    optional JsonLdContext context = {},
    optional JsonLdOptions options = {});
  static Promise<sequence<JsonLdDictionary>> expand(
    JsonLdInput input,
    optional JsonLdOptions options = {});
  static Promise<JsonLdDictionary> flatten(
    JsonLdInput input,
    optional JsonLdContext context = {},
    optional JsonLdOptions options = {});
  static Promise<sequence<JsonLdDictionary>> fromRdf(
    RdfDataset input,
    optional JsonLdOptions options = {});
  static Promise<RdfDataset> toRdf(
    JsonLdInput input,
    optional JsonLdOptions options = {});
};
    compact()Compacts the given input using the context according to the steps in the Compaction algorithm:
Promise promise and return it.
            The following steps are then executed asynchronously.expand() method
            using input
            and options,
            with ordered set to false,
            and extractAllScripts defaulting to false.
          @context entry,
            set context to that entry's value,
            otherwise to context.base option from options, if set;
            otherwise, if the compactToRelative option is true,
            to the IRI of the currently being processed document, if available;
            otherwise to null.null as property,
            expanded input as element,
            and if passed, the compactArrays
            and ordered
            flags in options.expand()Expands the given input according to the steps in the Expansion algorithm:
Promise promise and return it.
            The following steps are then executed asynchronously.LoadDocumentCallback, passing input
            for url,
            the extractAllScripts option for extractAllScripts.
          document
            from remote document is a string, transform into the internal representation.
            If document cannot be transformed to the internal representation,
            reject promise passing a loading document failed error.documentUrl
            from remote document, if available;
            otherwise to null.
            If set, the base option from options overrides the base IRI.expandContext option has been passed,
            update the active context using the Context Processing algorithm,
            passing the expandContext as local context.
            If expandContext is a map having an @context entry,
            pass that entry's value instead.contextUrl,
            update the active context using the Context Processing algorithm,
            passing the contextUrl as local context.document
            from remote document, or input
            if there is no remote document as element,
            and if passed, the frameExpansion
            and ordered
            flags in options.flatten()Flattens the given input and compacts it using the passed context according to the steps in the Flattening algorithm:
Promise promise and return it.
            The following steps are then executed asynchronously.expand() method
            using input
            and options
            with ordered set to false,
            and extractAllScripts defaulting to true.@context entry,
            set context to that entry's value,
            otherwise to context.base option
            from options, if set;
            otherwise, if the compactToRelative option is true,
            to the IRI of the currently being processed document, if available;
            otherwise to null.compactArrays
            and ordered
            flags in options.null is passed,
            the result will not be compacted but kept in expanded form.fromRdf()Transforms the given input into a JSON-LD document in expanded form according to the steps in the Serialize RDF as JSON-LD Algorithm:
This interface does not define a means of creating an RdfDataset
          from an arbitrary input, other than the toRdf() method.
Promise promise and return it.
            The following steps are then executed asynchronously.toRdf()Transforms the given input into an RdfDataset
          according to the steps in the Deserialize JSON-LD to RDF Algorithm:
Promise promise and return it.
            The following steps are then executed asynchronously.expand() method
            using input
            and options
            with ordered set to false,
            and extractAllScripts defaulting to true.RdfDataset dataset.produceGeneralizedRdf flag in options.
            produceGeneralizedRdf option may be also be removed.dictionary JsonLdDictionary {};
    The JsonLdDictionary is the definition of a map
      used to contain arbitrary map entries
      which are the result of parsing a JSON Object.
    
typedef (JsonLdDictionary or sequence<JsonLdDictionary> or USVString) JsonLdInput;
    The JsonLdInput type is used to refer to an input value
      that that may be a map,
      an array of maps ,
      or a string representing an IRI
      which can be dereferenced to retrieve a valid JSON document.
typedef (JsonLdDictionary or USVString or sequence<(JsonLdDictionary or USVString)>) JsonLdContext;
    The JsonLdContext type is used to refer to a value
      that may be a map,
      a string representing an IRI,
      or an array of maps and strings.
The RdfDataset interface describes operations on an RDF dataset
      used by the fromRdf()
      and toRdf() methods
      in the JsonLdProcessor interface.
      The interface may be used for constructing a new RDF dataset,
      which has a default graph accessible via the defaultGraph attribute.
[Exposed=Window]
interface RdfDataset {
  constructor();
  readonly attribute RdfGraph defaultGraph;
  void add(USVString graphName, RdfGraph graph);
  iterable<USVString?, RdfGraph>;
};
    add()Adds an RdfGraph and its associated graph name to the RdfDataset.
          Used by the Deserialize JSON-LD to RDF Algorithm.
RdfGraph to add to the RdfDataset.defaultGraphnull
        (for the default graph),
        an IRI,
        or blank node identifier
        and graph an RdfGraph instance.The RdfGraph interface describes operations on an RDF graph used by the fromRdf()
      and toRdf() methods
      in the JsonLdProcessor interface.
      The interface may be used for constructing a new RDF graph,
      which is composed of zero or more RdfTriple instances.
[Exposed=Window]
interface RdfGraph {
  constructor();
  void add(RdfTriple triple);
  iterable<RdfTriple>;
};
    add()Adds an RdfTriple to the RdfGraph.
          Used by the Deserialize JSON-LD to RDF Algorithm.
RdfTriple to add to the RdfGraph.iterableRdfTriple instances associated with the graph.
        Note that a given RdfTriple instance may appear in more than one graph
        within a particular RdfDataset instance.The RdfTriple interface describes an triple.
[Exposed=Window]
interface RdfTriple {
  constructor();
  readonly attribute USVString subject;
  readonly attribute USVString predicate;
  readonly attribute (USVString or RdfLiteral) object;
};
    subjectpredicateobjectThe RdfLiteral interface describes an RDF Literal.
[Exposed=Window]
interface RdfLiteral {
  constructor();
  readonly attribute USVString value;
  readonly attribute USVString datatype;
  readonly attribute USVString? language;
};
    valuedatatyperdf:langString,
        language MUST be specified.languagedatatype MUST be rdf:langString.The JsonLdOptions type is used to pass various options to the
      JsonLdProcessor methods.
dictionary JsonLdOptions {
  USVString?             base;
  boolean                compactArrays = true;
  boolean                compactToRelative = true;
  LoadDocumentCallback   documentLoader = null;
  (JsonLdDictionary? or USVString) expandContext = null;
  boolean                extractAllScripts = false;
  boolean                frameExpansion = false;
  boolean                ordered = false;
  USVString              processingMode = null;
  boolean                produceGeneralizedRdf = true;
  boolean                useNativeTypes = false;
  boolean                useRdfType = false;
};
    basecompactArraystrue, the JSON-LD processor replaces arrays
        with just one element with that element during compaction.
        If set to false,
        all arrays will remain arrays even if they have just one element.
      compactToRelativebase option
        or document location when compacting.documentLoaderLoadDocumentCallback.
        If specified, it is used to retrieve remote documents and contexts;
        otherwise, if not specified, the processor's built-in loader is used.expandContextextractAllScriptstrue,
        when extracting JSON-LD script elements from HTML,
        unless a specific fragment identifier is targeted,
        extracts all encountered JSON-LD script elements using an array form, if necessary.frameExpansionorderedtrue,
        certain algorithm processing steps where indicated are ordered lexicographically.
        If false, order is not considered in processing.processingModejson-ld-1.0 or json-ld-1.1,
        the implementation must produce exactly the same results as the
        algorithms defined in this specification.
        If set to another value,
        the JSON-LD processor is allowed to extend or modify the algorithms defined in this specification
        to enable application-specific optimizations.
        The definition of such optimizations is beyond the scope of this specification
        and thus not defined.
        Consequently, different implementations may implement different optimizations.
        Developers must not define modes beginning with json-ld
        as they are reserved for future versions of this specification.produceGeneralizedRdftrue, the JSON-LD processor may emit
        blank nodes for triple predicates,
        otherwise they will be omitted.
        Generalized RDF Datasets
          are defined in [RDF11-CONCEPTS].
        produceGeneralizedRdf option may be also be removed.useNativeTypes@type.useRdfTyperdf:type properties to be kept as IRIs in the output, rather than use @type.Users of an API implementation can utilize a callback to control how remote documents and contexts are retrieved. This section details the parameters of that callback and the data structure used to return the retrieved context.
The LoadDocumentCallback defines a callback that custom document loaders
        have to implement to be used to retrieve remote documents and contexts.
        The callback returns a Promise resolving to a RemoteDocument.
        On failure, the Promise is rejected with an appropriate error code.
callback LoadDocumentCallback = Promise<RemoteDocument> (
  USVString url,
  optional LoadDocumentOptions? options
);
      The following algorithm describes the default callback and places requirements on implementations of the callback.
Promise promise and return it.
          The following steps are then executed asynchronously.application/ld+json
          followed by application/json.
          If requestProfile is set,
            it MUST be added as a profile on application/ld+json.
Processors MAY include other media types using a +json suffix as defined in [RFC6839].
303 "See Other" redirects
          as discussed in [cooluris]).application/json
          nor any media type with a +json suffix as defined in [RFC6839],
          and the response has an HTTP Link Header [RFC8288] using the alternate link relation
          with type application/ld+json,
          set url to the associated href relative to the previous url
          and restart the algorithm from step 2.application/json
          or any media type with a +json suffix as defined in [RFC6839]
          except application/ld+json,
          and the response has an HTTP Link Header [RFC8288] using the http://www.w3.org/ns/json-ld#context link relation,
          set contextUrl to the associated href.
          If multiple HTTP Link Headers using the http://www.w3.org/ns/json-ld#context link relation are found,
            the promise is rejected with a JsonLdError whose code is set to multiple context link headers
            and processing is terminated.
Processors MAY transform document to the internal representation.
The HTTP Link Header is ignored for documents served as application/ld+json
            or text/html.
application/json,
          application/ld+json,
          nor any other media type using a
          +json suffix as defined in [RFC6839].
          Reject the promise passing a loading document failed error.RemoteDocument remote document using document,
          the returned Content-Type (without parameters) as contentType,
          any returned profile parameter,
          and any contextUrl.A custom LoadDocumentCallback set via the
        documentLoader option might be used
        to maintain a local cache of well-known context documents or to implement
        application-specific URL protocols.
The LoadDocumentOptions type is used to pass various options
        to the LoadDocumentCallback.
dictionary LoadDocumentOptions {
  boolean  extractAllScripts = false;
  USVString profile = null;
  (USVString or sequence<USVString>) requestProfile = null;
};
      extractAllScriptstrue,
          when extracting JSON-LD script elements from HTML,
          unless a specific fragment identifier is targeted,
          extracts all encountered JSON-LD script elements using an array form, if necessary.profilecontentType is text/html,
          this option determines the profile to use for selecting a JSON-LD script elements.requestProfileprofile parameter.
          (See IANA Considerations in [JSON-LD11]).The RemoteDocument type is used by a LoadDocumentCallback
        to return information about a remote document or context.
dictionary RemoteDocument {
  USVString contextUrl = null;
  USVString documentUrl;
  any       document;
  USVString contentType;
  USVString profile = null;
};
      contextUrlhttp://www.w3.org/ns/json-ld#context link relation
          in the response.
          If the response's Content-Type is application/ld+json,
          the HTTP Link Header is ignored.
          If multiple HTTP Link Headers using the http://www.w3.org/ns/json-ld#context link relation are found,
          the Promise of the LoadDocumentCallback is rejected
          with a JsonLdError whose code is set to multiple context link headers.documentUrldocumentcontentTypeprofileprofile parameter
          retrieved as part of the original contentType.This section describes optional features available
      with a documentLoader supporting HTML script extraction.
Implementations of a documentLoader MAY support extracting JSON-LD from
      script elements contained within an HTML [HTML] document.
      This section describes the normative behavior of such processors.
      Such a processor supports HTML script extraction.
This sections describe an extension to the algorithm specified
        in LoadDocumentCallback to support extracting JSON-LD from HTML.
Step 2 is updated to add the following: A processor supporting HTML script extraction MUST include text/html at any preference level,
        unless requestProfile is http://www.w3.org/ns/json-ld#context.
After step 5, add the following processing step:
        Otherwise, if the retrieved resource's Content-Type is text/html:
If no such element is found,
            or the located element is not a JSON-LD script element,
            the promise is rejected with a JsonLdError whose code is set to loading document failed
            and processing is terminated.
profile
          option is specified,
          set source to the result of transforming the
          textContent
          of the first script element in document
          having an type attribute
          of application/ld+json along with the value of the
          profile option, if found.extractAllScripts option is not present, or false,
          set source to the textContent
          of the first JSON-LD script element in document.
          If no such element is found,
            or the located element is not a JSON-LD script element,
            the promise is rejected with a JsonLdError whose code is set to loading document failed
            and processing is terminated.
JsonLdError whose code set from the result, if an error is detected
          and processing is terminated.
        extractAllScripts option is not present, or false,
              the promise is rejected with a JsonLdError whose code is set to loading document failed
              and processing is terminated.extractAllScripts option is true.
              Set document to a new empty array.
              For each JSON-LD script element in input:
              JsonLdError whose code set from the result, if an error is detected
                  and processing is terminated.The algorithm extracts the text content a
        JSON-LD script element into a map or array of maps.
        A JSON-LD script element is a script element
        within an HTML [HTML] document with the type attribute set to
        application/ld+json.
The algorithm takes a single required input variable: source, the textContent of an HTML script element.
invalid script element has been detected, and processing is aborted.This section describes the datatype definitions used within the JSON-LD API for error handling.
The JsonLdError type is used to report processing errors.
dictionary JsonLdError {
  JsonLdErrorCode code;
  USVString?      message = null;
};
      codemessageThe JsonLdErrorCode represents the collection of valid JSON-LD error codes.
enum JsonLdErrorCode {
    "colliding keywords",
    "conflicting indexes",
    "cyclic IRI mapping",
    "invalid @id value",
    "invalid @index value",
    "invalid @nest value",
    "invalid @prefix value",
    "invalid @propagate value",
    "invalid @reverse value",
    "invalid @import value",
    "invalid @version value",
    "invalid base IRI",
    "invalid container mapping",
    "invalid context entry",
    "invalid context nullification",
    "invalid default language",
    "invalid @included value",
    "invalid IRI mapping",
    "invalid keyword alias",
    "invalid language map value",
    "invalid language mapping",
    "invalid language-tagged string",
    "invalid language-tagged value",
    "invalid local context",
    "invalid remote context",
    "invalid reverse property",
    "invalid reverse property map",
    "invalid reverse property value",
    "invalid scoped context",
    "invalid script element",
    "invalid set or list object",
    "invalid term definition",
    "invalid type mapping",
    "invalid type value",
    "invalid typed value",
    "invalid value object",
    "invalid value object value",
    "invalid vocab mapping",
    "IRI confused with prefix",
    "keyword redefinition",
    "loading document failed",
    "loading remote context failed",
    "multiple context link headers",
    "processing mode conflict",
    "protected term redefinition",
    "context overflow"
};
      colliding keywordsconflicting indexescontext overflow@context URLs exceeded.cyclic IRI mappinginvalid @id value@id entry was encountered whose value was not a string.invalid @import value@import has been found.invalid @included valueinvalid @index value@index entry was encountered whose value was not a string.invalid @nest value@nest has been found.invalid @prefix value@prefix has been found.invalid @propagate value@propagate has been found.invalid @reverse value@reverse entry has been detected,
          i.e., the value was not a map.invalid @version value@version entry was used in a context
          with an out of range value.invalid base IRInull.invalid container mapping@container entry was encountered
          whose value was not one of the following strings:
          @list,
          @set,
          or @index.invalid context entryinvalid context nullificationinvalid default languagenull and thus invalid.invalid IRI mappinginvalid keyword aliasinvalid language map valueinvalid language mapping@language entry in a term definition
          was encountered whose value was neither a string
          nor null and thus invalid.invalid language-tagged stringinvalid language-tagged valuetrue, or false
          with an associated language tag was detected.invalid local contextinvalid remote contextinvalid reverse propertyinvalid reverse property map@context
          are allowed in reverse property maps.invalid reverse property valueinvalid scoped contextinvalid script elementinvalid set or list objectinvalid term definitioninvalid type mapping@type entry in a term definition
          was encountered whose value could not be expanded to an absolute IRI.invalid type value@type entry has been detected,
          i.e., the value was neither a string nor an array of strings.invalid typed valueinvalid value objectinvalid value object value@value entry of a value object
          has been detected,
          i.e., it is neither a scalar nor null.invalid vocab mappingnull.IRI confused with prefixkeyword redefinitionloading document failedloading remote context failedmultiple context link headershttp://www.w3.org/ns/json-ld#context link relation
          have been detected.processing mode conflictprotected term redefinitionSee, Security Considerations in [JSON-LD11].
See, Privacy Considerations in [JSON-LD11].
See, Internationalization Considerations in [JSON-LD11].
This section is non-normative.
[Exposed=Window] interfaceJsonLdProcessor{constructor(); static Promise<JsonLdDictionary>compact(JsonLdInputinput, optionalJsonLdContextcontext = {}, optionalJsonLdOptionsoptions = {}); static Promise<sequence<JsonLdDictionary>>expand(JsonLdInputinput, optionalJsonLdOptionsoptions = {}); static Promise<JsonLdDictionary>flatten(JsonLdInputinput, optionalJsonLdContextcontext = {}, optionalJsonLdOptionsoptions = {}); static Promise<sequence<JsonLdDictionary>>fromRdf(RdfDatasetinput, optionalJsonLdOptionsoptions = {}); static Promise<RdfDataset>toRdf(JsonLdInputinput, optionalJsonLdOptionsoptions = {}); }; dictionaryJsonLdDictionary{}; typedef (JsonLdDictionaryor sequence<JsonLdDictionary> or USVString)JsonLdInput; typedef (JsonLdDictionaryor USVString or sequence<(JsonLdDictionaryor USVString)>)JsonLdContext; [Exposed=Window] interfaceRdfDataset{constructor(); readonly attributeRdfGraphdefaultGraph; voidadd(USVString graphName,RdfGraphgraph); iterable<USVString?,RdfGraph>; }; [Exposed=Window] interfaceRdfGraph{constructor(); voidadd(RdfTripletriple); iterable<RdfTriple>; }; [Exposed=Window] interfaceRdfTriple{constructor(); readonly attribute USVStringsubject; readonly attribute USVStringpredicate; readonly attribute (USVString orRdfLiteral)object; }; [Exposed=Window] interfaceRdfLiteral{constructor(); readonly attribute USVStringvalue; readonly attribute USVStringdatatype; readonly attribute USVString?language; }; dictionaryJsonLdOptions{ USVString?base; booleancompactArrays= true; booleancompactToRelative= true;LoadDocumentCallbackdocumentLoader= null; (JsonLdDictionary? or USVString)expandContext= null; booleanextractAllScripts= false; booleanframeExpansion= false; booleanordered= false; USVStringprocessingMode= null; booleanproduceGeneralizedRdf= true; booleanuseNativeTypes= false; booleanuseRdfType= false; }; callbackLoadDocumentCallback= Promise<RemoteDocument> ( USVString url, optionalLoadDocumentOptions? options ); dictionaryLoadDocumentOptions{ booleanextractAllScripts= false; USVStringprofile= null; (USVString or sequence<USVString>)requestProfile= null; }; dictionaryRemoteDocument{ USVStringcontextUrl= null; USVStringdocumentUrl; anydocument; USVStringcontentType; USVStringprofile= null; }; dictionaryJsonLdError{JsonLdErrorCodecode; USVString?message= null; }; enumJsonLdErrorCode{ "colliding keywords", "conflicting indexes", "cyclic IRI mapping", "invalid @id value", "invalid @index value", "invalid @nest value", "invalid @prefix value", "invalid @propagate value", "invalid @reverse value", "invalid @import value", "invalid @version value", "invalid base IRI", "invalid container mapping", "invalid context entry", "invalid context nullification", "invalid default language", "invalid @included value", "invalid IRI mapping", "invalid keyword alias", "invalid language map value", "invalid language mapping", "invalid language-tagged string", "invalid language-tagged value", "invalid local context", "invalid remote context", "invalid reverse property", "invalid reverse property map", "invalid reverse property value", "invalid scoped context", "invalid script element", "invalid set or list object", "invalid term definition", "invalid type mapping", "invalid type value", "invalid typed value", "invalid value object", "invalid value object value", "invalid vocab mapping", "IRI confused with prefix", "keyword redefinition", "loading document failed", "loading remote context failed", "multiple context link headers", "processing mode conflict", "protected term redefinition", "context overflow" };
This section is non-normative.
The following is a list of issues open at the time of publication.
More compact @prefix.
Expansion concept "key's term definition" is unclear with compact IRI keys.
This section is non-normative.
frameExpansion flag, to enable content associated with JSON-LD
      frames, which may not otherwise be valid JSON-LD documents.@context entry, which defines a context used for values of
      a property identified with such a term. This context is used
      in both the Expansion Algorithm and
      Compaction Algorithm.@nest entry, which identifies a term expanding to
      @nest which is used for containing properties using the same
      @nest mapping. When expanding, the values of a entry
      expanding to @nest are treated as if they were contained
      within the enclosing node object directly.@container values within an expanded term definition may now
      include @id and @type, corresponding to id maps and type maps.@none value, but
      JSON-LD 1.0 only allowed string values. This has been updated
      to allow (and ignore) @none values.@container in an expanded term definition
      can also be an array containing any appropriate container
      keyword along with @set (other than @list).
      This allows a way to ensure that such entry values will always
      be expressed in array form.compactToRelative option to allow IRI compaction (§ 6.3 IRI Compaction)
      to document relative IRIs to be disabled.@prefix entry with the value true. The 1.0 algorithm has
      been updated to only consider terms that map to a value that ends with a URI
      gen-delim character.@container to include @graph,
      along with @id, @index and @set.
      In the Expansion Algorithm, this is
      used to create a named graph from either a node object, or
      objects which are values of entries in an id map or index map.
      the Compaction Algorithm allows
      specific forms of graph objects to be compacted back to a set of node
      objects, or maps of node objects.@none keyword, or an alias, for
      values of maps for which there is no natural index. The Expansion Algorithm removes this indexing
      transparently.Additionally, see § D. Changes since JSON-LD Community Group Final Report.
This section is non-normative.
ordered
       option, defaulting to false This is used in algorithms to
       control interation of map entry keys. Previously, the
       algorithms always required such an order. The instructions for
       evaluating test results have been updated accordingly.@type, or an alais of @type, may now have their @container set to @set
      to ensure that @type entries are always represented as an array. This
      also allows a term to be defined for @type, where the value MUST be a map
      with @container set to @set.:), but
      prefix is not a term, to only return value
      if it has the form of an absolute IRI, otherwise fall through to
      the rest of the algorithm.produceGeneralizedRdf option may be also be removed.text/html as input,
      extracting either a specifically targeted script element,
      the first found JSON-LD script element,
      or all JSON-LD script elements.contentType field to RemoteDocument.context overflow error."@type": "@none" in a term definition to prevent value compaction.RemoteDocument processing into the LoadDocumentCallback
      including variations on HTML processing.@propagate
      entry in a local context.@import entry used to reference a remote context
      within a context, allowing JSON-LD 1.1 features to be added to contexts originally
      authored for JSON-LD 1.0.colliding keywords error is not issued for @type;
      instead, previous values of @type are prepended to any new values, when expanding.@vocab in
      a context. When this is set, vocabulary-relative IRIs, such as the
      entries of node objects, are expanded or compacted relative
      to the base IRI and the vocabulary mapping using string concatenation.LoadDocumentCallback, if the retrieved content is not any JSON media type
      and there is a link header with rel=alternate and type=application/ld+json, redirect
      to that content.This section is non-normative.
The editor would like to specially thank the following individuals for making significant contributions to the authoring and editing of this specification:
Additionally, the following people were members of the Working Group at the time of publication:
A large amount of thanks goes out to the JSON-LD Community Group participants who worked through many of the technical issues on the mailing list and the weekly telecons: Chris Webber, David Wood, Drummond Reed, Eleanor Joslin, Fabien Gandon, Herm Fisher, Jamie Pitts, Kim Hamilton Duffy, Niklas Lindström, Paolo Ciccarese, Paul Frazze, Paul Warren, Reto Gmür, Rob Trainer, Ted Thibodeau Jr., and Victor Charpenay.