Reader¶
-
SerdReader *
serd_reader_new
(SerdWorld *world, SerdSyntax syntax, SerdReaderFlags flags, SerdEnv *env, const SerdSink *sink, size_t stack_size)¶ Create a new RDF reader.
-
void
serd_reader_add_blank_prefix
(SerdReader *reader, const char *prefix)¶ Set a prefix to be added to all blank node identifiers.
This is useful when multiple files are to be parsed into the same output (a model or a file). Since Serd preserves blank node IDs, this could cause conflicts where two non-equivalent blank nodes are merged, resulting in corrupt data. By setting a unique blank node prefix for each parsed file, this can be avoided, while preserving blank node names.
-
SerdStatus
serd_reader_start
(SerdReader *reader, SerdByteSource *byte_source)¶ Prepare to read from a byte source.
-
SerdStatus
serd_reader_read_chunk
(SerdReader *reader)¶ Read a single “chunk” of data during an incremental read.
This function will read a single top level description, and return. This may be a directive, statement, or several statements; essentially it reads until a ‘.’ is encountered. This is particularly useful for reading directly from a pipe or socket.
-
SerdStatus
serd_reader_read_document
(SerdReader *reader)¶ Read a complete document from the source.
This function will continue pulling from the source until a complete document has been read. Note that this may block when used with streams, for incremental reading use
serd_reader_read_chunk()
.
-
SerdStatus
serd_reader_finish
(SerdReader *reader)¶ Finish reading from the source.
This should be called before starting to read from another source.
-
void
serd_reader_free
(SerdReader *reader)¶ Free
reader
.The reader will be finished via
serd_reader_finish()
if necessary.