/* vim:expandtab:shiftwidth=2:tabstop=2:smarttab: * * Libmemcached library * * Copyright (C) 2012-2013 Data Differential, http://datadifferential.com/ * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * * * The names of its contributors may not be used to endorse or * promote products derived from this software without specific prior * written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ #pragma once #ifndef WIN32 # ifdef HAVE_NETDB_H # include # endif #endif #ifdef NI_MAXHOST # define MEMCACHED_NI_MAXHOST NI_MAXHOST #else # define MEMCACHED_NI_MAXHOST 1025 #endif #ifdef NI_MAXSERV # define MEMCACHED_NI_MAXSERV NI_MAXSERV #else # define MEMCACHED_NI_MAXSERV 32 #endif #include "libmemcached/string.hpp" // @todo Complete class transformation struct memcached_instance_st { in_port_t port() const { return port_; } void port(in_port_t arg) { port_= arg; } void mark_server_as_clean() { server_failure_counter= 0; server_timeout_counter= 0; next_retry= 0; } void disable() { } void enable() { } bool valid() const; bool is_shutting_down() const; void start_close_socket(); void close_socket(); void reset_socket(); uint32_t response_count() const { return cursor_active_; } struct { bool is_allocated; bool is_initialized; bool is_shutting_down; bool is_dead; bool ready; } options; short _events; short _revents; short events(void) { return _events; } short revents(void) { return _revents; } const char* hostname() { return _hostname; } void hostname(const memcached_string_t& hostname_) { if (hostname_.size) { memcpy(_hostname, hostname_.c_str, hostname_.size); _hostname[hostname_.size]= 0; } else { memcpy(_hostname, memcached_literal_param("localhost")); _hostname[memcached_literal_param_size("localhost")]= 0; } } void events(short); void revents(short); uint32_t cursor_active_; in_port_t port_; memcached_socket_t fd; uint32_t io_bytes_sent; /* # bytes sent since last read */ uint32_t request_id; uint32_t server_failure_counter; uint64_t server_failure_counter_query_id; uint32_t server_timeout_counter; uint32_t server_timeout_counter_query_id; uint32_t weight; uint32_t version; enum memcached_server_state_t state; struct { uint32_t read; uint32_t write; uint32_t timeouts; size_t _bytes_read; } io_wait_count; uint8_t major_version; // Default definition of UINT8_MAX means that it has not been set. uint8_t micro_version; // ditto, and note that this is the third, not second version bit uint8_t minor_version; // ditto memcached_connection_t type; char *read_ptr; size_t read_buffer_length; size_t read_data_length; size_t write_buffer_offset; struct addrinfo *address_info; struct addrinfo *address_info_next; time_t next_retry; struct memcached_st *root; uint64_t limit_maxbytes; struct memcached_error_t *error_messages; char read_buffer[MEMCACHED_MAX_BUFFER]; char write_buffer[MEMCACHED_MAX_BUFFER]; char _hostname[MEMCACHED_NI_MAXHOST]; void clear_addrinfo() { if (address_info) { freeaddrinfo(address_info); address_info= NULL; address_info_next= NULL; } } }; memcached_instance_st* __instance_create_with(memcached_st *memc, memcached_instance_st* self, const memcached_string_t& _hostname, const in_port_t port, uint32_t weight, const memcached_connection_t type); memcached_return_t memcached_instance_push(memcached_st *ptr, const memcached_instance_st*, uint32_t); void __instance_free(memcached_instance_st *);