summaryrefslogtreecommitdiffstats
path: root/sord
diff options
context:
space:
mode:
Diffstat (limited to 'sord')
-rw-r--r--sord/sord.h350
1 files changed, 350 insertions, 0 deletions
diff --git a/sord/sord.h b/sord/sord.h
new file mode 100644
index 0000000..88af9bd
--- /dev/null
+++ b/sord/sord.h
@@ -0,0 +1,350 @@
+/* Sord, a lightweight RDF model library.
+ * Copyright 2010-2011 David Robillard <d@drobilla.net>
+ *
+ * Sord is free software: you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Sord 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 Lesser General Public
+ * License for details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef SORD_SORD_H
+#define SORD_SORD_H
+
+#include <stdbool.h>
+#include <stdint.h>
+#include <stdio.h>
+
+/** @cond */
+#if defined _WIN32 || defined __CYGWIN__
+ #define SORD_LIB_IMPORT __declspec(dllimport)
+ #define SORD_LIB_EXPORT __declspec(dllexport)
+#else
+ #define SORD_LIB_IMPORT __attribute__ ((visibility("default")))
+ #define SORD_LIB_EXPORT __attribute__ ((visibility("default")))
+#endif
+
+#ifdef SORD_SHARED // Building a shared library
+ #ifdef SORD_INTERNAL // Building SORD (not using it)
+ #define SORD_API SORD_LIB_EXPORT
+ #else
+ #define SORD_API SORD_LIB_IMPORT
+ #endif
+#else // Building a static library
+ #define SORD_API
+#endif
+/** @endcond */
+
+/** @defgroup sord Public Sord API
+ * Sord is an RDF tuple store implemented in C.
+ * Sord stores RDF (subject object predicate) triples, where triples may
+ * have an added "context" field, i.e. (subject object predicate context).
+ * @{
+ */
+
+typedef struct _Sord* Sord; ///< Tuple store
+typedef struct _SordIter* SordIter; ///< Store iterator
+typedef struct _SordNode* SordNode; ///< Node
+
+typedef void* SordID; ///< Integer ID of a Node (0 reserved for NULL)
+typedef int SordCount; ///< Count of nodes or triples
+
+
+/** Tuple of IDs (statement), or a tuple pattern.
+ * Nodes are ordered (S P O G). The ID of the default graph is 0.
+ */
+typedef SordID SordTuple[4];
+
+/** Type of a node */
+typedef enum {
+ SORD_URI = 1, ///< URI
+ SORD_BLANK = 2, ///< Blank node identifier
+ SORD_LITERAL = 3 ///< Literal (string with optional lang and/or type)
+} SordNodeType;
+
+/** @name Initialisation and Cleanup */
+//@{
+
+/** Create a new store for the given @a path */
+SORD_API
+Sord
+sord_new();
+
+/** Set a store option.
+ * Options are RDF properties (with the store as the subject), with the
+ * restriction that each has at most one value.
+ * If @a value is NULL, the option is unset (i.e. the property is removed).
+ *
+ * Known options (with acceptable types):
+ * - http://drobilla.net/ns/sord#index-spo :: xsd:boolean
+ * - http://drobilla.net/ns/sord#index-sop :: xsd:boolean
+ * - http://drobilla.net/ns/sord#index-ops :: xsd:boolean
+ * - http://drobilla.net/ns/sord#index-osp :: xsd:boolean
+ * - http://drobilla.net/ns/sord#index-pso :: xsd:boolean
+ * - http://drobilla.net/ns/sord#index-pos :: xsd:boolean
+ *
+ * @param sord Store
+ * @param key URI of this option (predicate)
+ * @param value String of option value (object)
+ * @param type Type of @a value
+ * @param datatype Data type of @a value (if @a type is SORD_LITERAL), or NULL
+ * @param lang Language of @a value (if @a type is SORD_LITERAL), or NULL
+ */
+SORD_API
+void
+sord_set_option(Sord sord, const char* key, const char* value,
+ SordNodeType type, const char* datatype, const char* lang);
+
+/** Open store on disk. */
+SORD_API
+bool
+sord_open(Sord sord);
+
+/** Close store on disk. */
+SORD_API
+void
+sord_close(Sord sord);
+
+/** Close and free @a sord, leaving disk data intact. */
+SORD_API
+void
+sord_free(Sord sord);
+
+//@}
+
+/** @name Node Loading
+ * Searching for node IDs by value and loading nodes from disk by ID.
+ */
+
+//@{
+
+/** Set the free function for node opaque user data. */
+SORD_API
+void
+sord_node_set_user_data_free_function(Sord sord, void (*f)(void*));
+
+/** Dereference an ID, loading node data into memory.
+ * The returned node is allocated memory owned by @a sord,
+ * it can only be freed by the caller via sord_clear_cache.
+ */
+SORD_API
+SordNode
+sord_node_load(Sord sord, SordID id);
+
+/** Set @a s, @a p, and @a o to the nodes in @a tup.
+ * The actual node values will be loaded from the database into memory
+ * as necessary, and remain in memory until @ref sord_clear_cache is called.
+ */
+SORD_API
+void
+sord_tuple_load(Sord sord,
+ SordTuple tup,
+ SordNode* s,
+ SordNode* p,
+ SordNode* o);
+
+/** Clear in-memory node cache (possibly removing unused nodes on disk). */
+SORD_API
+void
+sord_clear_cache(Sord write);
+
+/** Find a URI, creating a new one if necessary iff @a create is true.
+ * Use sord_get_uri_counted instead if the length of @a str is known.
+ */
+SORD_API
+SordID
+sord_get_uri(Sord sord, bool create, const char* str);
+
+/** Find a URI, creating a new one if necessary iff @a create is true. */
+SORD_API
+SordID
+sord_get_uri_counted(Sord sord, bool create, const char* str, int str_len);
+
+/** Find a blank, creating a new one if necessary iff @a create is true
+ * Use sord_get_blank_counted instead if the length of @a str is known.
+ */
+SORD_API
+SordID
+sord_get_blank(Sord sord, bool create, const char* str);
+
+/** Find a blank, creating a new one if necessary iff @a create is true. */
+SORD_API
+SordID
+sord_get_blank_counted(Sord sord, bool create, const char* str, int str_len);
+
+/** Find a literal, creating a new one if necessary iff @a create is true.
+ * Use sord_get_literal_counted instead if the length of @a str is known.
+ */
+SORD_API
+SordID
+sord_get_literal(Sord sord, bool create, SordID type,
+ const char* str, const char* lang);
+
+/** Find a literal, creating a new one if necessary iff @a create is true. */
+SORD_API
+SordID
+sord_get_literal_counted(Sord sord, bool create, SordID type,
+ const char* str, int str_len,
+ const char* lang, uint8_t lang_len);
+
+//@}
+
+/** @name Node Values
+ * Investigating loaded (in-memory) node values.
+ */
+//@{
+
+/** Return the type of a node (SORD_URI, SORD_BLANK, or SORD_LITERAL). */
+SORD_API
+SordNodeType
+sord_node_get_type(SordNode node);
+
+/** Return the string value of a node. */
+SORD_API
+const char*
+sord_node_get_string(SordNode node);
+
+/** Set an opaque user pointer on a node.
+ * Sord does not interpret the user pointer in any way, but it will be
+ * preserved on the node until the cache is cleared.
+ */
+SORD_API
+void
+sord_node_set_user_data(SordNode node, void* user_data);
+
+/** Get the opaque user pointer on a node. */
+SORD_API
+void*
+sord_node_get_user_data(SordNode node);
+
+/** Get the language of a literal node. */
+SORD_API
+const char*
+sord_literal_get_lang(SordNode node);
+
+/** Get the datatype URI of a literal node. */
+SORD_API
+SordNode
+sord_literal_get_datatype(SordNode node);
+
+//@}
+
+/** @name Read Operations */
+//@{
+
+/** Return the number of nodes stored in @a sord.
+ * Nodes are included in this count iff they are a part of a tuple in @a sord.
+ */
+SORD_API
+int
+sord_num_nodes(Sord read);
+
+/** Return the number of tuples stored in @a sord. */
+SORD_API
+int
+sord_num_tuples(Sord read);
+
+/** Return an iterator to the start of the store. */
+SORD_API
+SordIter
+sord_begin(Sord read);
+
+/** Return an iterator that will iterate over each graph URI. */
+SORD_API
+SordIter
+sord_graphs_begin(Sord read);
+
+/** Search for a triple pattern.
+ * @return an iterator to the first match, or NULL if no matches found
+ */
+SORD_API
+SordIter
+sord_find(Sord sord, const SordTuple pat);
+
+//@}
+
+
+/** @name Write Operations */
+//@{
+
+/** Add a tuple to the store. */
+SORD_API
+void
+sord_add(Sord sord, const SordTuple tup);
+
+/** Remove a tuple from the store.
+ * This function invalidates all iterators to @a sord (use sord_remove_iter
+ * if this is undesirable)
+ */
+SORD_API
+void
+sord_remove(Sord sord, const SordTuple tup);
+
+/** Remove a tuple from the store by iterator.
+ * @a iter will be incremented to point at the next value.
+ */
+SORD_API
+void
+sord_remove_iter(Sord sord, SordIter iter);
+
+/** Remove a graph from the store. */
+SORD_API
+void
+sord_remove_graph(Sord sord, SordID graph);
+
+//@}
+
+/** @name Iteration */
+//@{
+
+/** Set @a id to the tuple pointed to by @a iter. */
+SORD_API
+void
+sord_iter_get(SordIter iter, SordTuple tup);
+
+/** Return the store pointed to by @a iter. */
+SORD_API
+Sord
+sord_iter_get_sord(SordIter iter);
+
+/** Increment @a iter to point to the next statement. */
+SORD_API
+bool
+sord_iter_increment(SordIter iter);
+
+/** Return true iff @a iter is at the end of its range. */
+SORD_API
+bool
+sord_iter_is_end(SordIter iter);
+
+/** Free @a iter. */
+SORD_API
+void
+sord_iter_free(SordIter iter);
+
+//@}
+
+/** @name Utilities */
+//@{
+
+/** Match two tuples (using ID comparison only).
+ * This function is a straightforward and fast equivalence match with wildcard
+ * support (ID 0 is a wildcard). It never performs any database access.
+ * @return true iff @a x and @a y match.
+ */
+SORD_API
+bool
+sord_tuple_match(const SordTuple x, const SordTuple y);
+
+//@}
+
+/** @} */
+
+#endif // SORD_SORD_H