Merge in all of build.
[m6w6/libmemcached] / libmemcached / string.h
index 4b44e6eddc60aea02d52583266b34da220c15fe1..ca3dad14faa64e2601c652b1f98b624a26df69b6 100644 (file)
@@ -27,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
@@ -79,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<size_t>((sizeof(X) - 1)))
+#define memcached_string_make(X) (static_cast<size_t>((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__ */