diff options
author | David Robillard <d@drobilla.net> | 2023-09-10 15:06:42 -0400 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2023-12-02 18:49:08 -0500 |
commit | 248a874d7425749d29cf900a1c3783c624ea8d8c (patch) | |
tree | aed59f5a484a815cd254506866e98a947858904d /include/serd/caret.h | |
parent | 0bd10132c6707353dba80bd89cf0102ee7ca4e34 (diff) | |
download | serd-248a874d7425749d29cf900a1c3783c624ea8d8c.tar.gz serd-248a874d7425749d29cf900a1c3783c624ea8d8c.tar.bz2 serd-248a874d7425749d29cf900a1c3783c624ea8d8c.zip |
Add support for custom allocators
This makes it explicit in the API where memory is allocated, and allows the
user to provide a custom allocator to avoid the use of the default system
allocator for whatever reason.
Diffstat (limited to 'include/serd/caret.h')
-rw-r--r-- | include/serd/caret.h | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/include/serd/caret.h b/include/serd/caret.h index 429a6fcd..54df0932 100644 --- a/include/serd/caret.h +++ b/include/serd/caret.h @@ -5,6 +5,7 @@ #define SERD_CARET_H #include "serd/attributes.h" +#include "serd/memory.h" #include "serd/node.h" #include "zix/attributes.h" @@ -29,23 +30,27 @@ typedef struct SerdCaretImpl SerdCaret; valid. That is, serd_caret_document() will return exactly the pointer `document`, not a copy. + @param allocator Allocator to use for caret memory. @param document The document or the caret refers to (usually a file URI) @param line The line number in the document (1-based) @param column The column number in the document (1-based) @return A new caret that must be freed with serd_caret_free() */ SERD_API SerdCaret* ZIX_ALLOCATED -serd_caret_new(const SerdNode* ZIX_NONNULL document, +serd_caret_new(SerdAllocator* ZIX_NULLABLE allocator, + const SerdNode* ZIX_NONNULL document, unsigned line, unsigned column); /// Return a copy of `caret` SERD_API SerdCaret* ZIX_ALLOCATED -serd_caret_copy(const SerdCaret* ZIX_NULLABLE caret); +serd_caret_copy(SerdAllocator* ZIX_NULLABLE allocator, + const SerdCaret* ZIX_NULLABLE caret); /// Free `caret` SERD_API void -serd_caret_free(SerdCaret* ZIX_NULLABLE caret); +serd_caret_free(SerdAllocator* ZIX_NULLABLE allocator, + SerdCaret* ZIX_NULLABLE caret); /// Return true iff `lhs` is equal to `rhs` SERD_PURE_API bool |