aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2022-10-02 09:08:22 -0400
committerDavid Robillard <d@drobilla.net>2023-12-02 16:27:02 -0500
commit8978501e5cf06f366eb14f6ef5f5f7f2f8e34986 (patch)
tree203504ff9b58fc1ba5b71ed1d066104f6a08ffb9 /include
parentc2e59da8865a8c5719b8ddaf5f68204729a8ebab (diff)
downloadserd-8978501e5cf06f366eb14f6ef5f5f7f2f8e34986.tar.gz
serd-8978501e5cf06f366eb14f6ef5f5f7f2f8e34986.tar.bz2
serd-8978501e5cf06f366eb14f6ef5f5f7f2f8e34986.zip
Simplify reader interface
Diffstat (limited to 'include')
-rw-r--r--include/serd/reader.h80
1 files changed, 35 insertions, 45 deletions
diff --git a/include/serd/reader.h b/include/serd/reader.h
index 779505cf..61b553db 100644
--- a/include/serd/reader.h
+++ b/include/serd/reader.h
@@ -13,8 +13,8 @@
#include "serd/syntax.h"
#include <stdbool.h>
+#include <stddef.h>
#include <stdint.h>
-#include <stdio.h>
SERD_BEGIN_DECLS
@@ -76,38 +76,30 @@ SERD_API void
serd_reader_set_default_graph(SerdReader* SERD_NONNULL reader,
const SerdNode* SERD_NULLABLE graph);
-/// Read a file at a given `uri`
+/// Prepare to read from the file at a local file `uri`
SERD_API SerdStatus
-serd_reader_read_file(SerdReader* SERD_NONNULL reader,
- const char* SERD_NONNULL uri);
+serd_reader_start_file(SerdReader* SERD_NONNULL reader,
+ const char* SERD_NONNULL uri,
+ bool bulk);
/**
- Start an incremental read from a file handle.
-
- Iff `bulk` is true, `file` will be read a page at a time. This is more
- efficient, but uses a page of memory and means that an entire page of input
- must be ready before any callbacks will fire. To react as soon as input
- arrives, set `bulk` to false.
-*/
-SERD_API SerdStatus
-serd_reader_start_stream(SerdReader* SERD_NONNULL reader,
- FILE* SERD_NONNULL file,
- const char* SERD_NULLABLE name,
- bool bulk);
-
-/**
- Start an incremental read from a user-specified source.
+ Prepare to read from a stream.
The `read_func` is guaranteed to only be called for `page_size` elements
with size 1 (i.e. `page_size` bytes).
*/
SERD_API SerdStatus
-serd_reader_start_source_stream(SerdReader* SERD_NONNULL reader,
- SerdReadFunc SERD_NONNULL read_func,
- SerdStreamErrorFunc SERD_NONNULL error_func,
- void* SERD_NONNULL stream,
- const char* SERD_NULLABLE name,
- size_t page_size);
+serd_reader_start_stream(SerdReader* SERD_NONNULL reader,
+ SerdReadFunc SERD_NONNULL read_func,
+ SerdStreamErrorFunc SERD_NONNULL error_func,
+ void* SERD_NONNULL stream,
+ const char* SERD_NULLABLE name,
+ size_t page_size);
+
+/// Prepare to read from a string
+SERD_API SerdStatus
+serd_reader_start_string(SerdReader* SERD_NONNULL reader,
+ const char* SERD_NONNULL utf8);
/**
Read a single "chunk" of data during an incremental read.
@@ -120,29 +112,23 @@ serd_reader_start_source_stream(SerdReader* SERD_NONNULL reader,
SERD_API SerdStatus
serd_reader_read_chunk(SerdReader* SERD_NONNULL reader);
-/// Finish an incremental read from a file handle
-SERD_API SerdStatus
-serd_reader_end_stream(SerdReader* SERD_NONNULL reader);
+/**
+ Read a complete document from the source.
-/// Read `file`
+ 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().
+*/
SERD_API SerdStatus
-serd_reader_read_file_handle(SerdReader* SERD_NONNULL reader,
- FILE* SERD_NONNULL file,
- const char* SERD_NULLABLE name);
+serd_reader_read_document(SerdReader* SERD_NONNULL reader);
-/// Read a user-specified byte source
-SERD_API SerdStatus
-serd_reader_read_source(SerdReader* SERD_NONNULL reader,
- SerdReadFunc SERD_NONNULL source,
- SerdStreamErrorFunc SERD_NONNULL error,
- void* SERD_NONNULL stream,
- const char* SERD_NULLABLE name,
- size_t page_size);
-
-/// Read `utf8`
+/**
+ Finish reading from the source.
+
+ This should be called before starting to read from another source.
+*/
SERD_API SerdStatus
-serd_reader_read_string(SerdReader* SERD_NONNULL reader,
- const char* SERD_NONNULL utf8);
+serd_reader_finish(SerdReader* SERD_NONNULL reader);
/**
Skip over bytes in the input until a specific byte is encountered.
@@ -156,7 +142,11 @@ serd_reader_read_string(SerdReader* SERD_NONNULL reader,
SERD_API SerdStatus
serd_reader_skip_until_byte(SerdReader* SERD_NONNULL reader, uint8_t byte);
-/// Free `reader`
+/**
+ Free `reader`.
+
+ The reader will be finished via `serd_reader_finish()` if necessary.
+*/
SERD_API void
serd_reader_free(SerdReader* SERD_NULLABLE reader);