- From: David Booth <david@dbooth.org>
- Date: Tue, 11 Jun 2013 00:17:27 -0400
- CC: 'public-rdf-comments' <public-rdf-comments@w3.org>
Below is a specific proposal for resolving the issue that the normative relationship between JSON-LD and RDF is not clear, and the JSON-LD model is not fully aligned with the RDF model. It clarifies that JSON-LD is a concrete syntax for RDF and ensures complete alignment with RDF while avoiding additional early mentions of RDF in the document. For substantive changes: 1. In RDF conversion algorithms in JSON-LD 1.0 Processing Algorithms and API, http://json-ld.org/spec/latest/json-ld-api/#rdf-conversion-algorithms specify that **when JSON-LD is interpreted as RDF,** (i.e., when the JSON-LD model is converted to the RDF model) skolem IRIs MUST be generated using the well-known URI suffix "json-ld-genid" for any JSON-LD blank node that would otherwise be mapped to an RDF blank node in a position where an RDF blank node is not permitted. Conversely, when RDF is serialized as JSON-LD (or when an RDF model is converted to a JSON-LD model), skolem IRIs having the well-known URI suffix "json-ld-genid" SHOULD be serialized as JSON-LD blank nodes. Finally, register the well-known URI suffix "json-ld-genid", in accordance with RFC5785: http://tools.ietf.org/html/rfc5785 BACKGROUND NOTE: The existing well-known URI suffix "genid" is for converting to/from RDF blank nodes (in positions where blank nodes are *permitted* in RDF), whereas "json-ld-genid" will be used for *avoiding* blank nodes (in positions where they are not allowed in RDF). 2. Make any other changes needed to ensure that JSON-LD is a normative concrete syntax for RDF. (Are any other changes needed?) For editorial changes: 3. In section 1 https://dvcs.w3.org/hg/json-ld/raw-file/default/spec/latest/json-ld/index.html#introduction make the following editorial change to clarify and move the mention of RDF slightly later in the document. Delete the sentence: "Developers that require any of the facilities listed above or need to serialize an RDF graph or dataset [RDF11-CONCEPTS] in a JSON-based syntax will find JSON-LD of interest.". Instead, add the following bullet item to the existing bullet list in section 1.1: - "Software developers who want to generate or consume Linked Data, an RDF graph or an RDF Dataset in a JSON syntax." 4. Without adding any earlier mention of RDF than the JSON-LD spec already contains, make other editorial changes as needed to avoid implying that JSON-LD is not necessarily RDF. (However it is fine to say that JSON-LD does not need to be *processed* as RDF.) Some examples: - Change "Converting JSON-LD to RDF" to either "Interpreting JSON-LD as RDF" or "Converting a JSON-LD model to an RDF model". - Change "Convert to RDF Algorithm" to "Interpret as RDF Algorithm" or "Algorithm for Interpreting JSON-LD as RDF". - Change "Convert from RDF Algorithm" to "Serialize from RDF Algorithm" or "Algorithm for Serializing RDF as JSON-LD". - Change "This algorithms converts a JSON-LD document to an RDF dataset" to "This algorithm interprets a JSON-LD document as an RDF dataset". - Change "This algorithm converts an RDF dataset" to "This algorithm serializes an RDF dataset". - Change "turning a JSON-LD document" to "interpreting a JSON-LD document as RDF". There are many other instances in the JSON-LD document, and I would be happy to help find and fix them. Most of them can be found by searching for the verb "convert" and changing it to "interpret" or "serialize". Alternatively you could say "deserialize" instead of "interpret". 5. At the beginning of appendix C insert: "JSON-LD is a _concrete RDF syntax_ as described in [RDF11_CONCEPTS]. Hence, a JSON-LD document is both an RDF document and a JSON document and correspondingly represents both an instance of the RDF data model and an instance of the JSON-LD data model." 6. In appendix C change the following paragraph in accordance with #1 above: [[ Summarized these differences mean that JSON-LD is capable of serializing any RDF graph or dataset and most, but not all, JSON-LD documents can be directly transformed to RDF. It is possible to work around this restriction, when converting JSON-LD to RDF, by converting blank nodes used as graph names or properties to IRIs, minting new "Skolem IRIs" as per Replacing Blank Nodes with IRIs of [RDF11-CONCEPTS]. A complete description of the algorithms to convert from RDF to JSON-LD and from JSON-LD to RDF is included in the JSON-LD Processing Algorithms and API specification [JSON-LD-API]. ]] to: [[ The algorithm for interpreting JSON-LD as RDF is specified in the JSON-LD Processing Algorithms and API specification [JSON-LD-API], which is hereby normatively included by reference. ]] 7. In section C.1 https://dvcs.w3.org/hg/json-ld/raw-file/default/spec/latest/json-ld/index.html#transformation-from-json-ld-to-rdf make the following changes: a. Change the title from "Transformation from JSON-LD to RDF" to "Brief Overview of Interpreting JSON-LD as RDF". b. After "This section is non-normative." add: "The complete, normative algorithm for interpreting JSON-LD as RDF is defined in the JSON-LD Processing Algorithms and API specification [JSON-LD-API] secion 10." Thanks, David
Received on Tuesday, 11 June 2013 04:18:00 UTC