X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;ds=sidebyside;f=libmemcached%2Fstring.h;h=5dd7d8dd7b0cdde0ef595f9ac13603d82713d6d9;hb=3dee67d04099cc5e2986ed94aa612f429f54d6fb;hp=9e064d9ad117808475c6b7f692907101e841e6b2;hpb=a6d18834a85d2a65caae820ee426169af5aff800;p=awesomized%2Flibmemcached diff --git a/libmemcached/string.h b/libmemcached/string.h index 9e064d9a..5dd7d8dd 100644 --- a/libmemcached/string.h +++ b/libmemcached/string.h @@ -9,19 +9,16 @@ * */ -#ifndef __MEMCACHED_STRING_H__ -#define __MEMCACHED_STRING_H__ - -#ifdef __cplusplus -extern "C" { -#endif +#pragma once +#ifndef __LIBMEMCACHED_STRING_H__ +#define __LIBMEMCACHED_STRING_H__ /** Strings are always under our control so we make some assumptions about them. 1) is_initialized is always valid. - 2) A string once intialized will always be, until free where we + 2) A string once intialized will always be, until free where we unset this flag. 3) A string always has a root. */ @@ -37,27 +34,14 @@ struct memcached_string_st { } options; }; -static inline size_t memcached_string_length(const memcached_string_st *self) -{ - return (size_t)(self->end - self->string); -} - -static inline size_t memcached_string_size(const memcached_string_st *self) -{ - return self->current_size; -} - -static inline const char *memcached_string_value(const memcached_string_st *self) -{ - return self->string; -} - -static inline char *memcached_string_value_mutable(const memcached_string_st *self) -{ - return self->string; -} +struct memcached_string_t { + size_t size; + const char *c_str; +}; -#define memcached_string_set_length(A, B) (A)->end= (A)->string + B +#ifdef __cplusplus +extern "C" { +#endif LIBMEMCACHED_LOCAL memcached_string_st *memcached_string_create(const memcached_st *ptr, @@ -81,8 +65,33 @@ memcached_return_t memcached_string_reset(memcached_string_st *string); LIBMEMCACHED_LOCAL void memcached_string_free(memcached_string_st *string); +LIBMEMCACHED_LOCAL +size_t memcached_string_length(const memcached_string_st *self); + +LIBMEMCACHED_LOCAL +size_t memcached_string_size(const memcached_string_st *self); + +LIBMEMCACHED_LOCAL +const char *memcached_string_value(const memcached_string_st *self); + +LIBMEMCACHED_LOCAL +char *memcached_string_value_mutable(const memcached_string_st *self); + +LIBMEMCACHED_LOCAL +void memcached_string_set_length(memcached_string_st *self, size_t length); + +LIBMEMCACHED_LOCAL +memcached_string_t memcached_string_make(const char *str, size_t length); + #ifdef __cplusplus } #endif -#endif /* __MEMCACHED_STRING_H__ */ + +#ifdef __cplusplus +#define memcached_string_with_size(X) (X), (static_cast((sizeof(X) - 1))) +#else +#define memcached_string_with_size(X) (X), ((size_t)((sizeof(X) - 1))) +#endif + +#endif /* __LIBMEMCACHED_STRING_H__ */