diff options
author | David Robillard <d@drobilla.net> | 2019-03-17 13:04:36 +0100 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2020-06-21 18:12:04 +0200 |
commit | a0d356d595f3c4a016828df830161fbb17e967a9 (patch) | |
tree | c3df527d06baab0ed2776b0251c5a458aa22a7a3 /src | |
parent | 68a4f7cfbae546831e375e2097bd7efa57a1d565 (diff) | |
download | serd-a0d356d595f3c4a016828df830161fbb17e967a9.tar.gz serd-a0d356d595f3c4a016828df830161fbb17e967a9.tar.bz2 serd-a0d356d595f3c4a016828df830161fbb17e967a9.zip |
Avoid writing invalid prefixed name prefixes
Diffstat (limited to 'src')
-rw-r--r-- | src/writer.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/writer.c b/src/writer.c index 4b6b5579..fad22ee2 100644 --- a/src/writer.c +++ b/src/writer.c @@ -478,7 +478,7 @@ write_literal(SerdWriter* writer, return true; } -// Return true iff `buf` is a valid prefixed name suffix +// Return true iff `buf` is a valid prefixed name prefix or suffix static inline bool is_name(const char* buf, const size_t len) { @@ -515,6 +515,7 @@ write_uri_node(SerdWriter* const writer, return sink("()", 2, writer) == 2; } else if (has_scheme && (writer->style & SERD_STYLE_CURIED) && serd_env_qualify_in_place(writer->env, node, &prefix, &suffix) && + is_name(serd_node_get_string(prefix), serd_node_get_length(prefix)) && is_name(suffix.buf, suffix.len)) { write_uri_from_node(writer, prefix); sink(":", 1, writer); |