aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2022-05-08 15:27:32 -0400
committerDavid Robillard <d@drobilla.net>2022-06-10 10:36:59 -0400
commitf6437f606bd85dbc6d7581146955f85902230ca0 (patch)
tree29526f43272a8c13455379f4f34b0580af0aa729
parent272d7081257dc6d50c06b1b62e8c4baa5bf3b4b2 (diff)
downloadserd-f6437f606bd85dbc6d7581146955f85902230ca0.tar.gz
serd-f6437f606bd85dbc6d7581146955f85902230ca0.tar.bz2
serd-f6437f606bd85dbc6d7581146955f85902230ca0.zip
Fix memory consumption when reading documents
-rw-r--r--NEWS6
-rw-r--r--doc/serdi.14
-rw-r--r--src/n3.c14
-rw-r--r--src/serd_config.h4
-rw-r--r--wscript2
5 files changed, 24 insertions, 6 deletions
diff --git a/NEWS b/NEWS
index cb1dbb93..34ecc18d 100644
--- a/NEWS
+++ b/NEWS
@@ -1,3 +1,9 @@
+serd (0.30.13) unstable;
+
+ * Fix memory consumption when reading documents
+
+ -- David Robillard <d@drobilla.net> Fri, 10 Jun 2022 13:00:11 +0000
+
serd (0.30.12) stable;
* Fix warnings and build issues with clang 13 and VS 2019
diff --git a/doc/serdi.1 b/doc/serdi.1
index a459136d..1d69add2 100644
--- a/doc/serdi.1
+++ b/doc/serdi.1
@@ -1,6 +1,6 @@
-.Dd May 26, 2022
+.Dd Jun 10, 2022
.Dt SERDI 1
-.Os Serd 0.30.12
+.Os Serd 0.30.13
.Sh NAME
.Nm serdi
.Nd read and write RDF syntax
diff --git a/src/n3.c b/src/n3.c
index 33828258..60d975c2 100644
--- a/src/n3.c
+++ b/src/n3.c
@@ -1572,7 +1572,7 @@ read_wrappedGraph(SerdReader* const reader, ReadContext* const ctx)
reader, SERD_ERR_BAD_SYNTAX, "missing predicate object list\n");
}
- pop_node(reader, ctx->subject);
+ ctx->subject = pop_node(reader, ctx->subject);
read_ws_star(reader);
if (peek_byte(reader) == '.') {
eat_byte_safe(reader, '.');
@@ -1606,6 +1606,10 @@ tokcmp(SerdReader* const reader,
SerdStatus
read_n3_statement(SerdReader* const reader)
{
+#ifndef NDEBUG
+ const size_t orig_stack_size = reader->stack.size;
+#endif
+
SerdStatementFlags flags = 0;
ReadContext ctx = {0, 0, 0, 0, 0, 0, &flags};
bool ate_dot = false;
@@ -1646,6 +1650,7 @@ read_n3_statement(SerdReader* const reader)
} else if (!tokcmp(reader, ctx.subject, "prefix", 6)) {
st = read_prefixID(reader, true, false);
} else if (!tokcmp(reader, ctx.subject, "graph", 5)) {
+ ctx.subject = pop_node(reader, ctx.subject);
read_ws_star(reader);
TRY(st, read_labelOrSubject(reader, &ctx.graph));
read_ws_star(reader);
@@ -1678,8 +1683,15 @@ read_n3_statement(SerdReader* const reader)
st = (eat_byte_check(reader, '.') == '.') ? SERD_SUCCESS
: SERD_ERR_BAD_SYNTAX;
}
+
+ ctx.subject = pop_node(reader, ctx.subject);
break;
}
+
+#ifndef NDEBUG
+ assert(reader->stack.size == orig_stack_size);
+#endif
+
return st;
}
diff --git a/src/serd_config.h b/src/serd_config.h
index 17c56929..1af3f423 100644
--- a/src/serd_config.h
+++ b/src/serd_config.h
@@ -1,5 +1,5 @@
/*
- Copyright 2021 David Robillard <d@drobilla.net>
+ Copyright 2021-2022 David Robillard <d@drobilla.net>
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted, provided that the above
@@ -29,7 +29,7 @@
#define SERD_CONFIG_H
// Define version unconditionally so a warning will catch a mismatch
-#define SERD_VERSION "0.30.12"
+#define SERD_VERSION "0.30.13"
#if !defined(SERD_NO_DEFAULT_CONFIG)
diff --git a/wscript b/wscript
index 5965892e..8f717d32 100644
--- a/wscript
+++ b/wscript
@@ -11,7 +11,7 @@ from waflib.extras import autowaf
# major increment <=> incompatible changes
# minor increment <=> compatible changes (additions)
# micro increment <=> no interface changes
-SERD_VERSION = '0.30.12'
+SERD_VERSION = '0.30.13'
SERD_MAJOR_VERSION = '0'
# Mandatory waf variables