X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fversion.cc;h=e779a76971e15a8d2c0449f133e12e25a9883340;hb=9973d386ac8476cd09cc4d9cf7bd2234a42740c7;hp=9f41c97ae6ac10e7224cb576d81027dc21615fd7;hpb=999006a8904a0f08293f1df7bda81bff914b091a;p=awesomized%2Flibmemcached diff --git a/libmemcached/version.cc b/libmemcached/version.cc index 9f41c97a..e779a769 100644 --- a/libmemcached/version.cc +++ b/libmemcached/version.cc @@ -41,7 +41,7 @@ const char * memcached_lib_version(void) return LIBMEMCACHED_VERSION_STRING; } -static inline memcached_return_t memcached_version_textual(memcached_st *ptr) +static inline memcached_return_t memcached_version_textual(Memcached *memc) { libmemcached_io_vector_st vector[]= { @@ -50,9 +50,9 @@ static inline memcached_return_t memcached_version_textual(memcached_st *ptr) uint32_t success= 0; bool errors_happened= false; - for (uint32_t x= 0; x < memcached_server_count(ptr); x++) + for (uint32_t x= 0; x < memcached_server_count(memc); x++) { - memcached_server_write_instance_st instance= memcached_server_instance_fetch(ptr, x); + memcached_instance_st* instance= memcached_instance_fetch(memc, x); // Optimization, we only fetch version once. if (instance->major_version != UINT8_MAX) @@ -73,13 +73,13 @@ static inline memcached_return_t memcached_version_textual(memcached_st *ptr) if (success) { // Collect the returned items - memcached_server_write_instance_st instance; - while ((instance= memcached_io_get_readable_server(ptr))) + memcached_instance_st* instance; + memcached_return_t readable_error; + while ((instance= memcached_io_get_readable_server(memc, readable_error))) { memcached_return_t rrc= memcached_response(instance, NULL); if (memcached_failed(rrc)) { - memcached_io_reset(instance); errors_happened= true; } } @@ -88,7 +88,7 @@ static inline memcached_return_t memcached_version_textual(memcached_st *ptr) return errors_happened ? MEMCACHED_SOME_ERRORS : MEMCACHED_SUCCESS; } -static inline memcached_return_t memcached_version_binary(memcached_st *ptr) +static inline memcached_return_t memcached_version_binary(Memcached *memc) { protocol_binary_request_version request= {}; @@ -102,9 +102,9 @@ static inline memcached_return_t memcached_version_binary(memcached_st *ptr) uint32_t success= 0; bool errors_happened= false; - for (uint32_t x= 0; x < memcached_server_count(ptr); x++) + for (uint32_t x= 0; x < memcached_server_count(memc); x++) { - memcached_server_write_instance_st instance= memcached_server_instance_fetch(ptr, x); + memcached_instance_st* instance= memcached_instance_fetch(memc, x); initialize_binary_request(instance, request.message.header); @@ -116,7 +116,6 @@ static inline memcached_return_t memcached_version_binary(memcached_st *ptr) memcached_return_t rrc= memcached_vdo(instance, vector, 1, true); if (memcached_failed(rrc)) { - memcached_io_reset(instance); errors_happened= true; continue; } @@ -127,14 +126,14 @@ static inline memcached_return_t memcached_version_binary(memcached_st *ptr) if (success) { // Collect the returned items - memcached_server_write_instance_st instance; - while ((instance= memcached_io_get_readable_server(ptr))) + memcached_instance_st* instance; + memcached_return_t readable_error; + while ((instance= memcached_io_get_readable_server(memc, readable_error))) { char buffer[32]; memcached_return_t rrc= memcached_response(instance, buffer, sizeof(buffer), NULL); if (memcached_failed(rrc)) { - memcached_io_reset(instance); errors_happened= true; } } @@ -143,23 +142,86 @@ static inline memcached_return_t memcached_version_binary(memcached_st *ptr) return errors_happened ? MEMCACHED_SOME_ERRORS : MEMCACHED_SUCCESS; } -memcached_return_t memcached_version(memcached_st *ptr) +static inline void version_ascii_instance(memcached_instance_st* instance) { - memcached_return_t rc; - if (memcached_failed(rc= initialize_query(ptr, true))) + if (instance->major_version != UINT8_MAX) { - return rc; + libmemcached_io_vector_st vector[]= + { + { memcached_literal_param("version\r\n") }, + }; + + (void)memcached_vdo(instance, vector, 1, false); + } +} + +static inline void version_binary_instance(memcached_instance_st* instance) +{ + if (instance->major_version != UINT8_MAX) + { + protocol_binary_request_version request= {}; + + request.message.header.request.opcode= PROTOCOL_BINARY_CMD_VERSION; + request.message.header.request.datatype= PROTOCOL_BINARY_RAW_BYTES; + + libmemcached_io_vector_st vector[]= + { + { request.bytes, sizeof(request.bytes) } + }; + + initialize_binary_request(instance, request.message.header); + + (void)memcached_vdo(instance, vector, 1, false); } +} - if (memcached_is_udp(ptr)) +void memcached_version_instance(memcached_instance_st* instance) +{ + if (instance) { - return MEMCACHED_NOT_SUPPORTED; + if (memcached_has_root(instance)) + { + if (memcached_is_fetching_version(instance->root)) + { + if (memcached_is_udp(instance->root) == false) + { + + if (memcached_is_binary(instance->root)) + { + version_binary_instance(instance); + return; + } + + version_ascii_instance(instance); + } + } + } } +} - if (memcached_is_binary(ptr)) +memcached_return_t memcached_version(memcached_st *shell) +{ + Memcached* memc= memcached2Memcached(shell); + if (memc) { - return memcached_version_binary(ptr); + memcached_return_t rc; + if (memcached_failed(rc= initialize_query(memc, true))) + { + return rc; + } + + if (memcached_is_udp(memc)) + { + return MEMCACHED_NOT_SUPPORTED; + } + + if (memcached_is_binary(memc)) + { + return memcached_version_binary(memc); + } + + return memcached_version_textual(memc); } - return memcached_version_textual(ptr); + return MEMCACHED_INVALID_ARGUMENTS; }