From cfdea96ce4c01e0aa0bae41e084110d03135f06a Mon Sep 17 00:00:00 2001 From: David Robillard Date: Fri, 28 Jan 2011 23:35:43 +0000 Subject: Fix crashes when passed NULL nodes. git-svn-id: http://svn.drobilla.net/serd/trunk@88 490d8e77-9747-427b-9fa3-0b8f29cee8a0 --- src/serdi.c | 2 +- src/writer.c | 8 +++++--- 2 files changed, 6 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/serdi.c b/src/serdi.c index 7a275e36..e85c9f70 100644 --- a/src/serdi.c +++ b/src/serdi.c @@ -204,7 +204,7 @@ main(int argc, char** argv) input += 5; } } - in_fd = fopen((const char*)input, "r"); + in_fd = fopen((const char*)input, "r"); if (!in_fd) { fprintf(stderr, "failed to open file %s\n", input); return 1; diff --git a/src/writer.c b/src/writer.c index 9ba02489..dd1d3f7a 100644 --- a/src/writer.c +++ b/src/writer.c @@ -207,10 +207,10 @@ write_node(SerdWriter writer, writer->sink("\"", 1, writer->stream); write_text(writer, WRITE_STRING, node->buf, node->n_bytes - 1, '"'); writer->sink("\"", 1, writer->stream); - if (lang->buf) { + if (lang && lang->buf) { writer->sink("@", 1, writer->stream); writer->sink(lang->buf, lang->n_bytes - 1, writer->stream); - } else if (datatype->buf) { + } else if (datatype && datatype->buf) { writer->sink("^^", 2, writer->stream); write_node(writer, datatype, NULL, NULL); } @@ -316,7 +316,9 @@ serd_writer_write_statement(SerdWriter writer, write_node(writer, object, object_datatype, object_lang); } - const WriteContext new_context = { *graph, *subject, *predicate }; + const WriteContext new_context = { graph ? *graph : SERD_NODE_NULL, + *subject, + *predicate }; writer->context = new_context; return true; } -- cgit v1.2.1