NAME
RDF::TrineX::Compatibility::Attean - Compatibility layer between Attean and RDF::Trine
SYNOPSIS
In modules that have new Attean methods, but otherwise uses RDF::Trine, just go:
use RDF::TrineX::Compatibility::Attean;
DESCRIPTION
For now, only certain methods of Attean nodes are supported. They are added to the respective RDF::Trine nodes by this module. They are:
RDF::Trine::Node::Resource::abs
RDF::Trine::Node::Literal::value
RDF::Trine::Node::Literal::language
RDF::Trine::Node::Literal::datatype
RDF::Trine::Model::get_quads
TODO
I'm unsure on how RDF::Trine::Node::Literal::has_datatype
should be treated. Attean implements RDF 1.1, where all literals have a datatype, so to Attean, has_datatype
would always be true, but that would be surprising to Trine users. For now, I have chosen to solve this only at the output level, i.e. the RDF::Trine::Node::Literal::datatype
will return the RDF 1.1 datatypes, but has_datatype
is still false for what was in RDF 1.0 plain literals and language literals.
BUGS
One should be that this module is a hack to make legacy code run while being in transition to Attean. It was initially motivated by making RDF::RDFa::Generator run on both frameworks. It may do surprising things.
Nevertheless, please report any bugs or things you miss from Attean here: https://github.com/kjetilk/p5-rdf-trinex-compatibility-attean/issues.
SEE ALSO
AUTHOR
Kjetil Kjernsmo <kjetilk@cpan.org>.
COPYRIGHT AND LICENCE
This software is copyright (c) 2017 by Kjetil Kjernsmo.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
DISCLAIMER OF WARRANTIES
THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.