View Source RDF.Serialization.Format behaviour (RDF.ex v2.0.0)
A behaviour for RDF serialization formats.
A serialization format can be implemented like this
defmodule SomeFormat do
  use RDF.Serialization.Format
  import RDF.Sigils
  @id         ~I<http://example.com/some_format>
  @name       :some_format
  @extension  "ext"
  @media_type "application/some-format"
endWhen @id, @name, @extension and @media_type module attributes are
defined the resp. behaviour functions are generated automatically and return
these values.
Then you'll have to do the main work by implementing a
RDF.Serialization.Encoder and a RDF.Serialization.Decoder for the format.
By default, it is assumed that these are defined in Encoder and Decoder
modules under the RDF.Serialization.Format module of the format, i.e. in the
example above in SomeFormat.Encoder and SomeFormat.Decoder. If you want
them in another module, you'll have to override the encoder/0 and/or
decoder/0 functions in your RDF.Serialization.Format module.
Summary
Callbacks
The RDF.Serialization.Decoder module for the serialization format.
The RDF.Serialization.Encoder module for the serialization format.
The usual file extension for the serialization format.
An IRI of the serialization format.
The MIME type of the serialization format.
The name atom of the serialization format.
Callbacks
@callback decoder() :: module()
The RDF.Serialization.Decoder module for the serialization format.
@callback encoder() :: module()
The RDF.Serialization.Encoder module for the serialization format.
@callback extension() :: String.t()
The usual file extension for the serialization format.
@callback id() :: RDF.IRI.t()
An IRI of the serialization format.
@callback media_type() :: String.t()
The MIME type of the serialization format.
@callback name() :: atom()
The name atom of the serialization format.