X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fstring.h;h=ca3dad14faa64e2601c652b1f98b624a26df69b6;hb=f285e1b3821f56a8983b5ce9fb1a0070e7bb0a1c;hp=ca2c1220943a60ae93f9c8b77aaddccd31eb2bf5;hpb=5f65f6be53b3e3d92969b1dd414e0c6473bdf1ec;p=awesomized%2Flibmemcached diff --git a/libmemcached/string.h b/libmemcached/string.h index ca2c1220..ca3dad14 100644 --- a/libmemcached/string.h +++ b/libmemcached/string.h @@ -9,6 +9,7 @@ * */ +#pragma once #ifndef __LIBMEMCACHED_STRING_H__ #define __LIBMEMCACHED_STRING_H__ @@ -26,13 +27,18 @@ struct memcached_string_st { char *end; char *string; size_t current_size; - const memcached_st *root; + memcached_st *root; struct { bool is_allocated:1; bool is_initialized:1; } options; }; +struct memcached_string_t { + size_t size; + const char *c_str; +}; + #ifdef __cplusplus extern "C" { #endif @@ -78,5 +84,18 @@ void memcached_string_set_length(memcached_string_st *self, size_t length); } #endif +#ifdef BUILDING_LIBMEMCACHED + +#ifdef __cplusplus +#define memcached_string_with_size(X) (X), (static_cast((sizeof(X) - 1))) +#define memcached_string_make(X) (static_cast((sizeof(X) - 1))), (X) +#else +#define memcached_string_with_size(X) (X), ((size_t)((sizeof(X) - 1))) +#define memcached_string_make(X) (((size_t)((sizeof(X) - 1))), (X) +#endif + +#define memcached_string_make_from_cstr(X) (X), ((X) ? strlen(X) : 0) + +#endif #endif /* __LIBMEMCACHED_STRING_H__ */