diff options
author | David Robillard <d@drobilla.net> | 2018-05-11 18:11:44 +0200 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2020-10-27 13:13:58 +0100 |
commit | 40c90e819d20d6933504ccb639896be223e10c3c (patch) | |
tree | fc9e0589c2fb4bb72eaf16fa06e7ce8263a6360a /serd | |
parent | 36a418f0d8dfd10007e48d6e8cb796cfa8aa4d88 (diff) | |
download | serd-40c90e819d20d6933504ccb639896be223e10c3c.tar.gz serd-40c90e819d20d6933504ccb639896be223e10c3c.tar.bz2 serd-40c90e819d20d6933504ccb639896be223e10c3c.zip |
Clean up node construction API
Diffstat (limited to 'serd')
-rw-r--r-- | serd/serd.h | 102 |
1 files changed, 52 insertions, 50 deletions
diff --git a/serd/serd.h b/serd/serd.h index 45e7ea56..b10d9ce9 100644 --- a/serd/serd.h +++ b/serd/serd.h @@ -463,18 +463,30 @@ serd_uri_serialise_relative(const SerdURI* uri, */ /** - Create a new node from `str`. + Create a new "simple" node that is just a string. + + This can be used to create blank, CURIE, or URI nodes from an already + measured string or slice of a buffer, which avoids a strlen compared to the + friendly constructors. This may not be used for literals since those must + be measured to set the SERD_HAS_NEWLINE and SERD_HAS_QUOTE flags. +*/ +SERD_API +SerdNode* +serd_node_new_simple_node(SerdType type, const char* str, size_t len); + +/** + Create a new plain literal string node from `str`. */ SERD_API SerdNode* -serd_node_new_string(SerdType type, const char* str); +serd_node_new_string(const char* str); /** - Create a new node from a prefix of `str`. + Create a new plain literal string node from a prefix of `str`. */ SERD_API SerdNode* -serd_node_new_substring(SerdType type, const char* str, size_t len); +serd_node_new_substring(const char* str, size_t len); /** Create a new literal node from `str`. @@ -490,81 +502,72 @@ serd_node_new_literal(const char* str, /** Create a new blank node. - - Note this function measures `str`, which is a common bottleneck. - Use sord_node_from_serd_node() instead if `str` is already measured. */ SERD_API SerdNode* serd_node_new_blank(const char* str); /** - Simple wrapper for serd_node_new_uri() to resolve a URI node. + Create a new CURIE node. */ SERD_API SerdNode* -serd_node_new_uri_from_node(const SerdNode* uri_node, - const SerdURI* base, - SerdURI* out); +serd_node_new_curie(const char* str); /** - Simple wrapper for serd_node_new_uri() to resolve a URI string. + Create a new URI from a string. */ SERD_API SerdNode* -serd_node_new_uri_from_string(const char* str, - const SerdURI* base, - SerdURI* out); +serd_node_new_uri(const char* str); /** - Create a new file URI node from a file system path and optional hostname. + Create a new URI from a string, resolved against a base URI. +*/ +SERD_API +SerdNode* +serd_node_new_resolved_uri(const char* str, const SerdNode* base); - Backslashes in Windows paths will be converted and '%' will always be - percent encoded. If `escape` is true, all other invalid characters will be - percent encoded as well. +/** + Resolve `node` against `base`. - If `path` is relative, `hostname` is ignored. - If `out` is not NULL, it will be set to the parsed URI. + If `node` is not a relative URI, an equivalent new node is returned. */ SERD_API SerdNode* -serd_node_new_file_uri(const char* path, - const char* hostname, - SerdURI* out, - bool escape); +serd_node_resolve(const SerdNode* node, const SerdNode* base); /** - Create a new node by serialising `uri` into a new string. - - @param uri The URI to serialise. + Create a new file URI node from a file system path and optional hostname. - @param base Base URI to resolve `uri` against (or NULL for no resolution). + Backslashes in Windows paths will be converted and '%' will always be + percent encoded. If `escape` is true, all other invalid characters will be + percent encoded as well. - @param out Set to the parsing of the new URI (i.e. points only to - memory owned by the new returned node). + If `path` is relative, `hostname` is ignored. */ SERD_API SerdNode* -serd_node_new_uri(const SerdURI* uri, const SerdURI* base, SerdURI* out); +serd_node_new_file_uri(const char* path, const char* hostname, bool escape); /** - Create a new node by serialising `uri` into a new relative URI. + Create a new URI from a string, relative to a base URI. - @param uri The URI to serialise. + @param str URI string. - @param base Base URI to make `uri` relative to, if possible. + @param base Base URI to make `str` relative to, if possible. - @param root Root URI for resolution (see serd_uri_serialise_relative()). + @param root Optional root URI for resolution. - @param out Set to the parsing of the new URI (i.e. points only to - memory owned by the new returned node). + The URI is made relative iff if it a child of `base` and `root`. The + optional `root` parameter must be a prefix of `base` and can be used keep + up-references ("../") within a certain namespace. */ SERD_API SerdNode* -serd_node_new_relative_uri(const SerdURI* uri, - const SerdURI* base, - const SerdURI* root, - SerdURI* out); +serd_node_new_relative_uri(const char* str, + const SerdNode* base, + const SerdNode* root); /** Create a new node by serialising `d` into an xsd:decimal string. @@ -793,7 +796,7 @@ serd_env_free(SerdEnv* env); */ SERD_API const SerdNode* -serd_env_base_uri(const SerdEnv* env, SerdURI* out); +serd_env_base_uri(const SerdEnv* env); /** Set the current base URI. @@ -990,13 +993,12 @@ serd_reader_free(SerdReader* reader); */ SERD_API SerdWriter* -serd_writer_new(SerdWorld* world, - SerdSyntax syntax, - SerdStyle style, - SerdEnv* env, - const SerdURI* base_uri, - SerdWriteFunc ssink, - void* stream); +serd_writer_new(SerdWorld* world, + SerdSyntax syntax, + SerdStyle style, + SerdEnv* env, + SerdWriteFunc ssink, + void* stream); /** Free `writer`. |