X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fmemory.h;h=06cc9985b27b8ea240b6b10507a22974fa87ff06;hb=4018da61ccc84a5345b19b61a1cfd5a30df896ea;hp=65d06b8c77a2b8940485db8d43d7258513372933;hpb=a6c3e3a3d04f379b1480c8c88a8eae17e54b1449;p=m6w6%2Flibmemcached diff --git a/libmemcached/memory.h b/libmemcached/memory.h index 65d06b8c..06cc9985 100644 --- a/libmemcached/memory.h +++ b/libmemcached/memory.h @@ -36,6 +36,18 @@ #pragma once +#include + +#include + +#ifdef __cplusplus +#include +#include +#else +#include +#include +#endif + static inline void libmemcached_free(const memcached_st *self, void *mem) { if (self) @@ -44,7 +56,11 @@ static inline void libmemcached_free(const memcached_st *self, void *mem) } else if (mem) { +#ifdef __cplusplus + std::free(mem); +#else free(mem); +#endif } } @@ -55,18 +71,29 @@ static inline void *libmemcached_malloc(const memcached_st *self, const size_t s return self->allocators.malloc(self, size, self->allocators.context); } +#ifdef __cplusplus + return std::malloc(size); +#else return malloc(size); +#endif } +#define libmemcached_xmalloc(__memcachd_st, __type) ((__type *)libmemcached_malloc((__memcachd_st), sizeof(__type))) -static inline void *libmemcached_realloc(const memcached_st *self, void *mem, const size_t size) +static inline void *libmemcached_realloc(const memcached_st *self, void *mem, size_t nmemb, const size_t size) { if (self) { - return self->allocators.realloc(self, mem, size, self->allocators.context); + return self->allocators.realloc(self, mem, nmemb * size, self->allocators.context); } - return realloc(mem, size); +#ifdef __cplusplus + return std::realloc(mem, size); +#else + return realloc(mem, size); +#endif } +#define libmemcached_xrealloc(__memcachd_st, __mem, __nelem, __type) ((__type *)libmemcached_realloc((__memcachd_st), (__mem), (__nelem), sizeof(__type))) +#define libmemcached_xvalloc(__memcachd_st, __nelem, __type) ((__type *)libmemcached_realloc((__memcachd_st), NULL, (__nelem), sizeof(__type))) static inline void *libmemcached_calloc(const memcached_st *self, size_t nelem, size_t size) { @@ -75,5 +102,10 @@ static inline void *libmemcached_calloc(const memcached_st *self, size_t nelem, return self->allocators.calloc(self, nelem, size, self->allocators.context); } - return calloc(nelem, size); +#ifdef __cplusplus + return std::calloc(nelem, size); +#else + return calloc(nelem, size); +#endif } +#define libmemcached_xcalloc(__memcachd_st, __nelem, __type) ((__type *)libmemcached_calloc((__memcachd_st), (__nelem), sizeof(__type)))