- From: Gregg Kellogg <gregg@greggkellogg.com>
- Date: Sat, 17 Aug 2013 15:05:27 -0700
- To: Jindřich Mynarz <mynarzjindrich@gmail.com>
- Cc: public-rdf-ruby@w3.org
- Message-Id: <FD90FE4C-4C34-43BB-A7B3-740C7F30888B@greggkellogg.com>
On Aug 17, 2013, at 1:07 PM, Jindřich Mynarz <mynarzjindrich@gmail.com> wrote:
> Hi Gregg,
>
> thanks for a quick and in-depth reply. Now it's much clearer to me how to provide external JSON-LD @context.
>
> Could you please also clarify the example in https://github.com/ruby-rdf/json-ld/blob/master/README.md that uses JSON::LD::API.fromRDF(input, context) even though you made it clear that the fromRDF method doesn't accept context as the second param?
Sure, thanks for noticing that. The README needs a little attention.
Gregg
> Best,
>
> Jindrich
>
> --
> Jindrich Mynarz
> http://mynarz.net/#jindrich
>
>
> On Sat, Aug 17, 2013 at 8:14 PM, Gregg Kellogg <gregg@greggkellogg.com> wrote:
> On Aug 17, 2013, at 3:55 AM, Jindřich Mynarz <mynarzjindrich@gmail.com> wrote:
>
>> Hi,
>>
>> I want to use ruby-rdf/json-ld to serialize RDF::Graph into JSON-LD given an external @context. The examples at https://github.com/ruby-rdf/json-ld/ suggest using JSON::LD::API::fromRDF(input, context). I noticed that the input param should be an instance of RDF::Graph, however, it's not clear to me what type should the context param be. Documentation for JSON::LD::API::fromRDF states that the second parameter is [Hash{Symbol => Object}] options, not @context. How should I provide an external @context when serializing RDF::Graph to JSON-LD? As a file path, String, Hash or as an instance of JSON::LD:Context? How could you do the same when using RDF::Graph#dump directly?
>
> The JSON::LD gem closely follows the JSON-LD API specification, but is more of a ruby-like gem then a JavaScript/Promise API as it is synchronous. You can view the online documentation here: http://rubydoc.info/github/ruby-rdf/json-ld/master/frames.
>
> You can either using the fromRDF API method, or the standard RDF.rb readers and writers, which allows the use of dump() method.
>
> The fromRDF class method [1] does not take a context, as it outputs expanded JSON-LD. If you wanted to compact it using a context, you could add a compact call [2], such as the following:
>
> JSON::LD::API.fromRDF(graph) do |expanded|
> JSON::LD::API.compact(expanded, context) do |compacted|
> puts compacted.to_json
> end
> end
>
> From the compact documentation, you can see that the context parameter accepts a String, something responding to #read, Hash, Array or JSON::LD::Context. In the case of a string, it is interpreted as a file path or URL from which to load a context.
>
> From the JSON::LD::Writer.initialize documentation [3], you can see that there is a :context option, which is treated just like the context parameter to compact. Because this is a general Writer interface, as used elsewhere in RDF.rb, this means that it could be added to a dump() call, such as the following
>
> g = RDF::Graph.load("file.ttl")
> puts g.dump(:jsonld, :context => context)
>
> If you use prefix and base definitions instead, it will create a new context and use that for compacting the output; this is common when transcoding between different RDF formats.
>
> Gregg
>
> [1] http://rubydoc.info/github/ruby-rdf/json-ld/master/JSON/LD/API#fromRDF-class_method
> [2] http://rubydoc.info/github/ruby-rdf/json-ld/master/JSON/LD/API#compact-class_method
> [3] http://rubydoc.info/github/ruby-rdf/json-ld/master/JSON/LD/Writer#initialize-instance_method
>
>
>> Best,
>>
>> Jindrich
>>
>> --
>> Jindrich Mynarz
>> http://mynarz.net/#jindrich
>
>
Received on Saturday, 17 August 2013 22:05:57 UTC