/* This file is part of Raul. Copyright (C) 2007 Dave Robillard. * * Raul is free software; you can redistribute it and/or modify it under the * terms of the GNU General Public License as published by the Free Software * Foundation; either version 2 of the License, or (at your option) any later * version. * * Raul is distributed in the hope that it will be useful, but WITHOUT ANY * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef RAUL_ATOM_RAPTOR_H #define RAUL_ATOM_RAPTOR_H #include #include #include #include #include "raul/Atom.h" using std::cerr; using std::endl; #define U(x) ((const unsigned char*)(x)) namespace Raul { /** Support for serializing an Atom to/from RDF (via raptor, a part of librdf). * * (Here to prevent a unnecessary raptor dependency for Atom). * * \ingroup raul */ class AtomRaptor { public: /** Set this atom's value to the object (value) portion of an RDF triple. * * Caller is responsible for calling free(triple->object). */ static void atom_to_triple_object(raptor_statement* triple, const Atom& atom) { std::ostringstream os; triple->object_literal_language = NULL; switch (atom.type()) { case Atom::INT: os << atom.get_int32(); triple->object = (unsigned char*)strdup(os.str().c_str()); triple->object_type = RAPTOR_IDENTIFIER_TYPE_LITERAL; triple->object_literal_datatype = raptor_new_uri( U("http://www.w3.org/2001/XMLSchema#integer")); break; case Atom::FLOAT: os << atom.get_float(); triple->object = (unsigned char*)strdup(os.str().c_str()); triple->object_type = RAPTOR_IDENTIFIER_TYPE_LITERAL; /* Use xsd:decimal so turtle abbreviation works */ triple->object_literal_datatype = raptor_new_uri( U("http://www.w3.org/2001/XMLSchema#decimal")); break; case Atom::STRING: triple->object = strdup(atom.get_string()); triple->object_type = RAPTOR_IDENTIFIER_TYPE_LITERAL; triple->object_literal_datatype = NULL; break; case Atom::BLOB: case Atom::NIL: default: cerr << "WARNING: Unserializable Atom!" << endl; triple->object = NULL; triple->object_type = RAPTOR_IDENTIFIER_TYPE_UNKNOWN; } } #if 0 static Atom node_to_atom(librdf_node* node) { /*switch (type) { case 'i': return Atom(arg->i); case 'f': return Atom(arg->f); case 's': return Atom(&arg->s); //case 'b' // FIXME: How to get a blob from a lo_arg? //return Atom(arg->b); default: return Atom(); }*/ cerr << "FIXME: node_to_atom\n"; return Atom(); } #endif }; } // namespace Raul #endif // RAUL_ATOM_RAPTOR_H