5.8.5 Statement¶
-
enum SerdField¶
Index of a node in a statement.
-
enumerator SERD_SUBJECT¶
Subject.
-
enumerator SERD_PREDICATE¶
Predicate (“key”)
-
enumerator SERD_OBJECT¶
Object (“value”)
-
enumerator SERD_GRAPH¶
Graph (“context”)
-
enumerator SERD_SUBJECT¶
-
typedef struct SerdStatementImpl SerdStatement¶
A subject, predicate, and object, with optional graph context.
-
SerdStatement *serd_statement_new(SerdAllocator *allocator, const SerdNode *s, const SerdNode *p, const SerdNode *o, const SerdNode *g, const SerdCaret *caret)¶
Create a new statement.
Note that, to minimise model overhead, statements do not own their nodes, so they must have a longer lifetime than the statement for it to be valid. For statements in models, this is the lifetime of the model. For user-created statements, the simplest way to handle this is to use
SerdNodes
.- Parameters
allocator – Allocator to use for statement memory.
s – The subject
p – The predicate (“key”)
o – The object (“value”)
g – The graph (“context”)
caret – Optional caret at the origin of this statement
- Returns
A new statement that must be freed with
serd_statement_free()
-
SerdStatement *serd_statement_copy(SerdAllocator *allocator, const SerdStatement *statement)¶
Return a copy of
statement
-
void serd_statement_free(SerdAllocator *allocator, SerdStatement *statement)¶
Free
statement
-
const SerdNode *serd_statement_node(const SerdStatement *statement, SerdField field)¶
Return the given node of the statement.
-
const SerdNode *serd_statement_subject(const SerdStatement *statement)¶
Return the subject of the statement.
-
const SerdNode *serd_statement_predicate(const SerdStatement *statement)¶
Return the predicate of the statement.
-
const SerdNode *serd_statement_object(const SerdStatement *statement)¶
Return the object of the statement.
-
const SerdNode *serd_statement_graph(const SerdStatement *statement)¶
Return the graph of the statement.
-
const SerdCaret *serd_statement_caret(const SerdStatement *statement)¶
Return the source location where the statement originated, or NULL.
-
bool serd_statement_equals(const SerdStatement *a, const SerdStatement *b)¶
Return true iff
a
is equal tob
, ignoring statement caret metadata.Only returns true if nodes are equivalent, does not perform wildcard matching.
-
bool serd_statement_matches(const SerdStatement *statement, const SerdNode *subject, const SerdNode *predicate, const SerdNode *object, const SerdNode *graph)¶
Return true iff the statement matches the given pattern.
Nodes match if they are equivalent, or if one of them is NULL. The statement matches if every node matches.