X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fserver.h;h=109f9d50b42e5e0e774384820b334a605805224e;hb=56bb95c23210147d45b792e4e494e995d9de76dc;hp=f7531883981fd5f9449d293d6997522616cd62a6;hpb=14fbb41f4a761f96a047c36f9eaae33e6b57d21f;p=awesomized%2Flibmemcached diff --git a/libmemcached/server.h b/libmemcached/server.h index f7531883..109f9d50 100644 --- a/libmemcached/server.h +++ b/libmemcached/server.h @@ -9,17 +9,15 @@ * */ -#ifndef __MEMCACHED_SERVER_H__ -#define __MEMCACHED_SERVER_H__ +#ifndef __LIBMEMCACHED_SERVER_H__ +#define __LIBMEMCACHED_SERVER_H__ -#ifdef __cplusplus -extern "C" { -#endif struct memcached_server_st { struct { - bool is_allocated:1; - bool sockaddr_inited:1; + bool is_allocated MEMCACHED_BITFIELD; + bool is_initialized MEMCACHED_BITFIELD; + bool sockaddr_inited MEMCACHED_BITFIELD; } options; uint32_t number_of_hosts; uint32_t cursor_active; @@ -29,6 +27,9 @@ struct memcached_server_st { uint32_t io_bytes_sent; /* # bytes sent since last read */ uint32_t server_failure_counter; uint32_t weight; + struct { // Place any "state" sort variables in here. + bool is_corked; + } state; uint8_t major_version; uint8_t micro_version; uint8_t minor_version; @@ -40,33 +41,17 @@ struct memcached_server_st { size_t write_buffer_offset; struct addrinfo *address_info; time_t next_retry; - memcached_st *root; + const memcached_st *root; uint64_t limit_maxbytes; char read_buffer[MEMCACHED_MAX_BUFFER]; char write_buffer[MEMCACHED_MAX_BUFFER]; - char hostname[MEMCACHED_MAX_HOST_LENGTH]; + char hostname[NI_MAXHOST]; }; -// Local Only Inline -static inline uint32_t memcached_servers_count(memcached_server_st *servers) -{ - return servers->number_of_hosts; -} - -// Local Only Inline -static inline uint32_t memcached_servers_set_count(memcached_server_st *servers, uint32_t count) -{ - return servers->number_of_hosts= count; -} - - -#define memcached_server_count(A) (A)->number_of_hosts -#define memcached_server_name(A,B) (B).hostname -#define memcached_server_port(A,B) (B).port -#define memcached_server_list(A) (A)->hosts -#define memcached_server_list_set(A,B) (A)->hosts=(B) -#define memcached_server_response_count(A) (A)->cursor_active +#ifdef __cplusplus +extern "C" { +#endif LIBMEMCACHED_API memcached_return_t memcached_server_cursor(memcached_st *ptr, @@ -89,11 +74,9 @@ void memcached_server_error_reset(memcached_server_st *ptr); /* These should not currently be used by end users */ /* TODO: Is the above comment valid? If so, how can we unit test these if they * aren't exported. If not, we should remove the comment */ -LIBMEMCACHED_LOCAL -memcached_server_st *memcached_server_create(memcached_st *memc, memcached_server_st *ptr); LIBMEMCACHED_LOCAL -memcached_server_st *memcached_server_create_with(memcached_st *memc, +memcached_server_st *memcached_server_create_with(const memcached_st *memc, memcached_server_st *host, const char *hostname, in_port_t port, @@ -104,8 +87,8 @@ LIBMEMCACHED_API void memcached_server_free(memcached_server_st *ptr); LIBMEMCACHED_LOCAL -memcached_server_st *memcached_server_clone(memcached_server_st *clone, - memcached_server_st *ptr); +memcached_server_st *memcached_server_clone(memcached_server_st *destination, + const memcached_server_st *source); LIBMEMCACHED_API memcached_return_t memcached_server_remove(memcached_server_st *st_ptr); @@ -113,8 +96,76 @@ memcached_return_t memcached_server_remove(memcached_server_st *st_ptr); LIBMEMCACHED_API memcached_server_st *memcached_server_get_last_disconnect(memcached_st *ptr); -#ifdef __cplusplus + +LIBMEMCACHED_API +memcached_return_t memcached_server_add_udp(memcached_st *ptr, + const char *hostname, + in_port_t port); +LIBMEMCACHED_API +memcached_return_t memcached_server_add_unix_socket(memcached_st *ptr, + const char *filename); +LIBMEMCACHED_API +memcached_return_t memcached_server_add(memcached_st *ptr, + const char *hostname, in_port_t port); + +LIBMEMCACHED_API +memcached_return_t memcached_server_add_udp_with_weight(memcached_st *ptr, + const char *hostname, + in_port_t port, + uint32_t weight); +LIBMEMCACHED_API +memcached_return_t memcached_server_add_unix_socket_with_weight(memcached_st *ptr, + const char *filename, + uint32_t weight); +LIBMEMCACHED_API +memcached_return_t memcached_server_add_with_weight(memcached_st *ptr, const char *hostname, + in_port_t port, + uint32_t weight); +/* Server List Public functions */ + +LIBMEMCACHED_API +void memcached_server_list_free(memcached_server_st *ptr); + + +LIBMEMCACHED_API +memcached_return_t memcached_server_push(memcached_st *ptr, memcached_server_st *list); + +LIBMEMCACHED_API +memcached_server_st *memcached_server_list_append(memcached_server_st *ptr, + const char *hostname, + in_port_t port, + memcached_return_t *error); +LIBMEMCACHED_API +memcached_server_st *memcached_server_list_append_with_weight(memcached_server_st *ptr, + const char *hostname, + in_port_t port, + uint32_t weight, + memcached_return_t *error); +LIBMEMCACHED_API +unsigned int memcached_server_list_count(memcached_server_st *ptr); + +// Local Only Inline +static inline uint32_t memcached_servers_count(memcached_server_st *servers) +{ + return servers->number_of_hosts; +} + +// Local Only Inline +static inline uint32_t memcached_servers_set_count(memcached_server_st *servers, uint32_t count) +{ + return servers->number_of_hosts= count; } + + +#define memcached_server_count(A) (A)->number_of_hosts +#define memcached_server_name(A,B) (B).hostname +#define memcached_server_port(A,B) (B).port +#define memcached_server_list(A) (A)->servers +#define memcached_server_list_set(A,B) (A)->servers=(B) +#define memcached_server_response_count(A) (A)->cursor_active + +#ifdef __cplusplus +} // extern "C" #endif -#endif /* __MEMCACHED_SERVER_H__ */ +#endif /* __LIBMEMCACHED_SERVER_H__ */