From ba67dcd8288e73beb4aa571541b73a6b1ea143af Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 12 May 2018 18:03:13 +0200 Subject: Set datatypes on integer, decimal, and base64 nodes --- serd/serd.h | 24 ++++++++++++++++++++---- 1 file changed, 20 insertions(+), 4 deletions(-) (limited to 'serd') diff --git a/serd/serd.h b/serd/serd.h index 41b03fbd..1d12df94 100644 --- a/serd/serd.h +++ b/serd/serd.h @@ -583,18 +583,27 @@ serd_node_new_relative_uri(const char* str, represent a double and float, respectively. @param d The value for the new node. + @param frac_digits The maximum number of digits after the decimal place. + + @param datatype Datatype of node, may be NULL in which case the node has + type xsd:decimal. */ SERD_API SerdNode* -serd_node_new_decimal(double d, unsigned frac_digits); +serd_node_new_decimal(double d, unsigned frac_digits, const SerdNode* datatype); /** Create a new node by serialising `i` into an xsd:integer string. + + @param i Integer value to serialise. + + @param datatype Datatype of node, may be NULL in which case the node has + type xsd:integer. */ SERD_API SerdNode* -serd_node_new_integer(int64_t i); +serd_node_new_integer(int64_t i, const SerdNode* datatype); /** Create a node by serialising `buf` into an xsd:base64Binary string. @@ -602,12 +611,19 @@ serd_node_new_integer(int64_t i); binary data, which can be decoded using serd_base64_decode(). @param buf Raw binary input data. + @param size Size of `buf`. + @param wrap_lines Wrap lines at 76 characters to conform to RFC 2045. + + @param datatype Datatype of node, may be NULL in which case the node has + type xsd:base64Binary. */ SERD_API -SerdNode* -serd_node_new_blob(const void* buf, size_t size, bool wrap_lines); +SerdNode* serd_node_new_blob(const void* buf, + size_t size, + bool wrap_lines, + const SerdNode* datatype); /** Return the type of a node (SERD_URI, SERD_BLANK, or SERD_LITERAL). -- cgit v1.2.1