diff options
| author | Patrick Steinhardt <ps@pks.im> | 2018-03-16 10:14:50 +0000 |
|---|---|---|
| committer | Patrick Steinhardt <ps@pks.im> | 2018-06-07 12:57:39 +0200 |
| commit | 74b7ddbf333ee20a4b2bc7a0e7c3f7c2aa4fc590 (patch) | |
| tree | c982f3373dc2f50a361e55798d524f9530c2483c | |
| parent | 9865cd1696ac4a3f47991a9a1d79b17cef5edc89 (diff) | |
| download | libgit2-74b7ddbf333ee20a4b2bc7a0e7c3f7c2aa4fc590.tar.gz | |
settings: allow swapping out memory allocator
Tie in the newly created infrastructure for swapping out memory
allocators into our settings code. A user can now simply use the new
option "GIT_OPT_SET_ALLOCATOR" with `git_libgit2_opts`, passing in an
already initialized allocator structure as vararg.
| -rw-r--r-- | include/git2/common.h | 7 | ||||
| -rw-r--r-- | include/git2/sys/alloc.h | 24 | ||||
| -rw-r--r-- | src/alloc.c | 9 | ||||
| -rw-r--r-- | src/settings.c | 5 |
4 files changed, 45 insertions, 0 deletions
diff --git a/include/git2/common.h b/include/git2/common.h index f65cfdd01..f095e5990 100644 --- a/include/git2/common.h +++ b/include/git2/common.h @@ -183,6 +183,7 @@ typedef enum { GIT_OPT_GET_WINDOWS_SHAREMODE, GIT_OPT_SET_WINDOWS_SHAREMODE, GIT_OPT_ENABLE_STRICT_HASH_VERIFICATION, + GIT_OPT_SET_ALLOCATOR } git_libgit2_opt_t; /** @@ -345,6 +346,12 @@ typedef enum { * > additional checksum calculation on each object. This defaults * > to enabled. * + * opts(GIT_OPT_SET_ALLOCATOR, git_allocator *allocator) + * + * > Set the memory allocator to a different memory allocator. This + * > allocator will then be used to make all memory allocations for + * > libgit2 operations. + * * @param option Option key * @param ... value to set the option * @return 0 on success, <0 on failure diff --git a/include/git2/sys/alloc.h b/include/git2/sys/alloc.h index a0955ce8b..4bc5323e2 100644 --- a/include/git2/sys/alloc.h +++ b/include/git2/sys/alloc.h @@ -72,6 +72,30 @@ typedef struct { void (*gfree)(void *ptr); } git_allocator; +/** + * Initialize the allocator structure to use the `stdalloc` pointer. + * + * Set up the structure so that all of its members are using the standard + * "stdalloc" allocator functions. The structure can then be used with + * `git_allocator_setup`. + * + * @param allocator The allocator that is to be initialized. + * @return An error code or 0. + */ +int git_stdalloc_init_allocator(git_allocator *allocator); + +/** + * Initialize the allocator structure to use the `crtdbg` pointer. + * + * Set up the structure so that all of its members are using the "crtdbg" + * allocator functions. Note that this allocator is only available on Windows + * platforms and only if libgit2 is being compiled with "-DMSVC_CRTDBG". + * + * @param allocator The allocator that is to be initialized. + * @return An error code or 0. + */ +int git_win32_crtdbg_init_allocator(git_allocator *allocator); + GIT_END_DECL #endif diff --git a/src/alloc.c b/src/alloc.c index 79ed1dd5f..35fdd00c4 100644 --- a/src/alloc.c +++ b/src/alloc.c @@ -29,3 +29,12 @@ int git_allocator_setup(git_allocator *allocator) memcpy(&git__allocator, allocator, sizeof(*allocator)); return 0; } + +#if !defined(GIT_MSVC_CRTDBG) +int git_win32_crtdbg_init_allocator(git_allocator *allocator) +{ + GIT_UNUSED(allocator); + giterr_set(GIT_EINVALID, "crtdbg memory allocator not available"); + return -1; +} +#endif diff --git a/src/settings.c b/src/settings.c index f6bc5b270..14280f8c0 100644 --- a/src/settings.c +++ b/src/settings.c @@ -16,6 +16,7 @@ #endif #include <git2.h> +#include "alloc.h" #include "sysdir.h" #include "cache.h" #include "global.h" @@ -260,6 +261,10 @@ int git_libgit2_opts(int key, ...) git_odb__strict_hash_verification = (va_arg(ap, int) != 0); break; + case GIT_OPT_SET_ALLOCATOR: + error = git_allocator_setup(va_arg(ap, git_allocator *)); + break; + default: giterr_set(GITERR_INVALID, "invalid option key"); error = -1; |
