aboutsummaryrefslogtreecommitdiffstats
path: root/src/n3.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-02-10 13:32:06 +0100
committerDavid Robillard <d@drobilla.net>2020-06-21 18:12:03 +0200
commit27ee06024c2d54a2340e83e5c90e919f8764ae0f (patch)
tree75810ccb7871446552f41c76c10a0821c3d46d9c /src/n3.c
parent77b496a15d3c263a1bbc7c4cc56583f4014c1d22 (diff)
downloadserd-27ee06024c2d54a2340e83e5c90e919f8764ae0f.tar.gz
serd-27ee06024c2d54a2340e83e5c90e919f8764ae0f.tar.bz2
serd-27ee06024c2d54a2340e83e5c90e919f8764ae0f.zip
Simplify reader interface
Diffstat (limited to 'src/n3.c')
-rw-r--r--src/n3.c28
1 files changed, 16 insertions, 12 deletions
diff --git a/src/n3.c b/src/n3.c
index aa482b2e..19ef8557 100644
--- a/src/n3.c
+++ b/src/n3.c
@@ -1452,22 +1452,22 @@ skip_until(SerdReader* reader, uint8_t byte)
}
}
-bool
+SerdStatus
read_turtleTrigDoc(SerdReader* reader)
{
while (!reader->source.eof) {
if (!read_n3_statement(reader)) {
if (reader->strict) {
- return 0;
+ return SERD_ERR_UNKNOWN;
}
skip_until(reader, '\n');
reader->status = SERD_SUCCESS;
}
}
- return reader->status <= SERD_FAILURE;
+ return reader->status;
}
-bool
+SerdStatus
read_nquadsDoc(SerdReader* reader)
{
while (!reader->source.eof) {
@@ -1479,8 +1479,9 @@ read_nquadsDoc(SerdReader* reader)
if (peek_byte(reader) == EOF) {
break;
} else if (peek_byte(reader) == '@') {
- return r_err(reader, SERD_ERR_BAD_SYNTAX,
- "syntax does not support directives\n");
+ r_err(reader, SERD_ERR_BAD_SYNTAX,
+ "syntax does not support directives\n");
+ return SERD_ERR_BAD_SYNTAX;
}
// subject predicate object
@@ -1489,11 +1490,11 @@ read_nquadsDoc(SerdReader* reader)
!(ctx.predicate = read_IRIREF(reader)) ||
!read_ws_star(reader) ||
!read_object(reader, &ctx, false, &ate_dot)) {
- return false;
+ return SERD_ERR_UNKNOWN;
}
if (!ate_dot) { // graphLabel?
- TRY_RET(read_ws_star(reader));
+ read_ws_star(reader);
switch (peek_byte(reader)) {
case '.':
break;
@@ -1502,20 +1503,23 @@ read_nquadsDoc(SerdReader* reader)
break;
default:
if (!(ctx.graph = read_IRIREF(reader))) {
- return false;
+ return SERD_ERR_UNKNOWN;
}
}
// Terminating '.'
- TRY_RET(read_ws_star(reader));
+ read_ws_star(reader);
eat_byte_check(reader, '.');
}
- TRY_RET(emit_statement(reader, ctx, ctx.object, ctx.datatype, ctx.lang));
+ if (!emit_statement(reader, ctx, ctx.object, ctx.datatype, ctx.lang)) {
+ break;
+ }
+
pop_node(reader, ctx.graph);
pop_node(reader, ctx.lang);
pop_node(reader, ctx.datatype);
pop_node(reader, ctx.object);
}
- return reader->status <= SERD_FAILURE;
+ return reader->status;
}