diff options
author | Edward Thomson <ethomson@edwardthomson.com> | 2019-02-23 18:42:53 +0000 |
---|---|---|
committer | Edward Thomson <ethomson@edwardthomson.com> | 2019-02-23 18:42:53 +0000 |
commit | 459ac856d94d4a59ee47b2807aa8e4b029499582 (patch) | |
tree | 474ddd7cd35c6a832eb6bcf97f410f1f6fb1345e | |
parent | 790aae778df9bf4809e3c1e772d4d948c1cc2aa3 (diff) | |
download | libgit2-ethomson/odb_backend_allocations.tar.gz |
odb: provide a free function for custom backendsethomson/odb_backend_allocations
Custom backends can allocate memory when reading objects and providing
them to libgit2. However, if an error occurs in the custom backend
after the memory has been allocated for the custom object but before
it's returned to libgit2, the custom backend has no way to free that
memory and it must be leaked.
Provide a free function that corresponds to the alloc function so that
custom backends have an opportunity to free memory before they return an
error.
-rw-r--r-- | include/git2/sys/odb_backend.h | 11 | ||||
-rw-r--r-- | src/odb.c | 6 |
2 files changed, 17 insertions, 0 deletions
diff --git a/include/git2/sys/odb_backend.h b/include/git2/sys/odb_backend.h index 15c741577..6614dcf30 100644 --- a/include/git2/sys/odb_backend.h +++ b/include/git2/sys/odb_backend.h @@ -131,6 +131,17 @@ GIT_EXTERN(int) git_odb_init_backend( */ GIT_EXTERN(void *) git_odb_backend_data_alloc(git_odb_backend *backend, size_t len); +/** + * Frees custom allocated ODB data. This should only be called when + * memory allocated using git_odb_backend_data_alloc is not returned + * to libgit2 because the backend encountered an error in the read + * function after allocation and did not return this data to libgit2. + * + * @param backend the ODB backend that is freeing this memory + * @param data the buffer to free + */ +GIT_EXTERN(void) git_odb_backend_data_free(git_odb_backend *backend, void *data); + /* * Users can avoid deprecated functions by defining `GIT_DEPRECATE_HARD`. @@ -1508,6 +1508,12 @@ void *git_odb_backend_malloc(git_odb_backend *backend, size_t len) return git_odb_backend_data_alloc(backend, len); } +void git_odb_backend_data_free(git_odb_backend *backend, void *data) +{ + GIT_UNUSED(backend); + git__free(data); +} + int git_odb_refresh(struct git_odb *db) { size_t i; |