couchbase-memcached 1.2.8
Sign up to get free protection for your applications and to get access to all the features.
- data.tar.gz.sig +2 -0
- data/BENCHMARKS +134 -0
- data/CHANGELOG +127 -0
- data/LICENSE +184 -0
- data/Manifest +535 -0
- data/README +118 -0
- data/Rakefile +83 -0
- data/TODO +4 -0
- data/couchbase-memcached.gemspec +33 -0
- data/ext/extconf-make.rb +25 -0
- data/ext/extconf.rb +91 -0
- data/ext/libmemcached-0.50/AUTHORS +11 -0
- data/ext/libmemcached-0.50/COPYING +33 -0
- data/ext/libmemcached-0.50/ChangeLog +392 -0
- data/ext/libmemcached-0.50/Makefile.am +114 -0
- data/ext/libmemcached-0.50/Makefile.in +4232 -0
- data/ext/libmemcached-0.50/NEWS +1 -0
- data/ext/libmemcached-0.50/README +43 -0
- data/ext/libmemcached-0.50/README.FIRST +31 -0
- data/ext/libmemcached-0.50/README.win32 +25 -0
- data/ext/libmemcached-0.50/THANKS +14 -0
- data/ext/libmemcached-0.50/TODO +11 -0
- data/ext/libmemcached-0.50/aclocal.m4 +1077 -0
- data/ext/libmemcached-0.50/clients/client_options.h +45 -0
- data/ext/libmemcached-0.50/clients/execute.cc +131 -0
- data/ext/libmemcached-0.50/clients/execute.h +30 -0
- data/ext/libmemcached-0.50/clients/generator.cc +96 -0
- data/ext/libmemcached-0.50/clients/generator.h +36 -0
- data/ext/libmemcached-0.50/clients/include.am +116 -0
- data/ext/libmemcached-0.50/clients/memaslap.c +908 -0
- data/ext/libmemcached-0.50/clients/memcapable.cc +2094 -0
- data/ext/libmemcached-0.50/clients/memcat.cc +242 -0
- data/ext/libmemcached-0.50/clients/memcp.cc +317 -0
- data/ext/libmemcached-0.50/clients/memdump.cc +183 -0
- data/ext/libmemcached-0.50/clients/memerror.cc +102 -0
- data/ext/libmemcached-0.50/clients/memflush.cc +154 -0
- data/ext/libmemcached-0.50/clients/memparse.cc +68 -0
- data/ext/libmemcached-0.50/clients/memrm.cc +177 -0
- data/ext/libmemcached-0.50/clients/memslap.cc +495 -0
- data/ext/libmemcached-0.50/clients/memstat.cc +349 -0
- data/ext/libmemcached-0.50/clients/ms_atomic.h +69 -0
- data/ext/libmemcached-0.50/clients/ms_conn.c +3413 -0
- data/ext/libmemcached-0.50/clients/ms_conn.h +241 -0
- data/ext/libmemcached-0.50/clients/ms_memslap.h +132 -0
- data/ext/libmemcached-0.50/clients/ms_setting.c +1068 -0
- data/ext/libmemcached-0.50/clients/ms_setting.h +181 -0
- data/ext/libmemcached-0.50/clients/ms_sigsegv.c +126 -0
- data/ext/libmemcached-0.50/clients/ms_sigsegv.h +34 -0
- data/ext/libmemcached-0.50/clients/ms_stats.c +307 -0
- data/ext/libmemcached-0.50/clients/ms_stats.h +69 -0
- data/ext/libmemcached-0.50/clients/ms_task.c +1114 -0
- data/ext/libmemcached-0.50/clients/ms_task.h +94 -0
- data/ext/libmemcached-0.50/clients/ms_thread.c +351 -0
- data/ext/libmemcached-0.50/clients/ms_thread.h +78 -0
- data/ext/libmemcached-0.50/clients/utilities.cc +231 -0
- data/ext/libmemcached-0.50/clients/utilities.h +64 -0
- data/ext/libmemcached-0.50/config.h.in +647 -0
- data/ext/libmemcached-0.50/config/autorun.sh +126 -0
- data/ext/libmemcached-0.50/config/compile +143 -0
- data/ext/libmemcached-0.50/config/config.guess +1517 -0
- data/ext/libmemcached-0.50/config/config.rpath +666 -0
- data/ext/libmemcached-0.50/config/config.sub +1760 -0
- data/ext/libmemcached-0.50/config/depcomp +630 -0
- data/ext/libmemcached-0.50/config/install-sh +520 -0
- data/ext/libmemcached-0.50/config/ltmain.sh +9642 -0
- data/ext/libmemcached-0.50/config/missing +376 -0
- data/ext/libmemcached-0.50/config/pandora-plugin +752 -0
- data/ext/libmemcached-0.50/config/uncrustify.cfg +1112 -0
- data/ext/libmemcached-0.50/configure +27103 -0
- data/ext/libmemcached-0.50/configure.ac +186 -0
- data/ext/libmemcached-0.50/docs/conf.py.in +354 -0
- data/ext/libmemcached-0.50/docs/include.am +240 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_clone.3 +88 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_crc32.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_create.3 +88 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_fnv1_32.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_fnv1_64.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_fnv1a_32.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_fnv1a_64.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_free.3 +88 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_functions.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_hsieh.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_is_allocated.3 +88 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_jenkins.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_md5.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_murmur.3 +105 -0
- data/ext/libmemcached-0.50/docs/man/hashkit_value.3 +66 -0
- data/ext/libmemcached-0.50/docs/man/libhashkit.3 +57 -0
- data/ext/libmemcached-0.50/docs/man/libmemcached.3 +208 -0
- data/ext/libmemcached-0.50/docs/man/libmemcached_check_configuration.3 +293 -0
- data/ext/libmemcached-0.50/docs/man/libmemcached_configuration.3 +293 -0
- data/ext/libmemcached-0.50/docs/man/libmemcached_examples.3 +144 -0
- data/ext/libmemcached-0.50/docs/man/libmemcachedutil.3 +68 -0
- data/ext/libmemcached-0.50/docs/man/memaslap.1 +1222 -0
- data/ext/libmemcached-0.50/docs/man/memcached.3 +293 -0
- data/ext/libmemcached-0.50/docs/man/memcached_add.3 +132 -0
- data/ext/libmemcached-0.50/docs/man/memcached_add_by_key.3 +132 -0
- data/ext/libmemcached-0.50/docs/man/memcached_analyze.3 +77 -0
- data/ext/libmemcached-0.50/docs/man/memcached_append.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_append_by_key.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_behavior_get.3 +333 -0
- data/ext/libmemcached-0.50/docs/man/memcached_behavior_set.3 +333 -0
- data/ext/libmemcached-0.50/docs/man/memcached_callback_get.3 +159 -0
- data/ext/libmemcached-0.50/docs/man/memcached_callback_set.3 +159 -0
- data/ext/libmemcached-0.50/docs/man/memcached_cas.3 +91 -0
- data/ext/libmemcached-0.50/docs/man/memcached_cas_by_key.3 +91 -0
- data/ext/libmemcached-0.50/docs/man/memcached_clone.3 +99 -0
- data/ext/libmemcached-0.50/docs/man/memcached_create.3 +99 -0
- data/ext/libmemcached-0.50/docs/man/memcached_decrement.3 +124 -0
- data/ext/libmemcached-0.50/docs/man/memcached_decrement_with_initial.3 +124 -0
- data/ext/libmemcached-0.50/docs/man/memcached_delete.3 +83 -0
- data/ext/libmemcached-0.50/docs/man/memcached_delete_by_key.3 +83 -0
- data/ext/libmemcached-0.50/docs/man/memcached_destroy_sasl_auth_data.3 +95 -0
- data/ext/libmemcached-0.50/docs/man/memcached_dump.3 +77 -0
- data/ext/libmemcached-0.50/docs/man/memcached_fetch.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_fetch_execute.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_fetch_result.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_flush_buffers.3 +72 -0
- data/ext/libmemcached-0.50/docs/man/memcached_free.3 +99 -0
- data/ext/libmemcached-0.50/docs/man/memcached_generate_hash.3 +85 -0
- data/ext/libmemcached-0.50/docs/man/memcached_generate_hash_value.3 +85 -0
- data/ext/libmemcached-0.50/docs/man/memcached_get.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_get_by_key.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_get_memory_allocators.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_get_sasl_callbacks.3 +95 -0
- data/ext/libmemcached-0.50/docs/man/memcached_get_user_data.3 +79 -0
- data/ext/libmemcached-0.50/docs/man/memcached_increment.3 +124 -0
- data/ext/libmemcached-0.50/docs/man/memcached_increment_with_initial.3 +124 -0
- data/ext/libmemcached-0.50/docs/man/memcached_lib_version.3 +76 -0
- data/ext/libmemcached-0.50/docs/man/memcached_mget.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_mget_by_key.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_mget_execute.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_mget_execute_by_key.3 +174 -0
- data/ext/libmemcached-0.50/docs/man/memcached_pool_behavior_get.3 +139 -0
- data/ext/libmemcached-0.50/docs/man/memcached_pool_behavior_set.3 +139 -0
- data/ext/libmemcached-0.50/docs/man/memcached_pool_create.3 +139 -0
- data/ext/libmemcached-0.50/docs/man/memcached_pool_destroy.3 +139 -0
- data/ext/libmemcached-0.50/docs/man/memcached_pool_pop.3 +139 -0
- data/ext/libmemcached-0.50/docs/man/memcached_pool_push.3 +139 -0
- data/ext/libmemcached-0.50/docs/man/memcached_pool_st.3 +139 -0
- data/ext/libmemcached-0.50/docs/man/memcached_prepend.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_prepend_by_key.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_quit.3 +74 -0
- data/ext/libmemcached-0.50/docs/man/memcached_replace.3 +132 -0
- data/ext/libmemcached-0.50/docs/man/memcached_replace_by_key.3 +132 -0
- data/ext/libmemcached-0.50/docs/man/memcached_sasl_set_auth_data.3 +95 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_add.3 +141 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_count.3 +141 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_cursor.3 +141 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_list.3 +141 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_list_append.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_list_count.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_list_free.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_server_push.3 +141 -0
- data/ext/libmemcached-0.50/docs/man/memcached_servers_parse.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_set.3 +132 -0
- data/ext/libmemcached-0.50/docs/man/memcached_set_by_key.3 +132 -0
- data/ext/libmemcached-0.50/docs/man/memcached_set_memory_allocators.3 +111 -0
- data/ext/libmemcached-0.50/docs/man/memcached_set_sasl_callbacks.3 +95 -0
- data/ext/libmemcached-0.50/docs/man/memcached_set_user_data.3 +79 -0
- data/ext/libmemcached-0.50/docs/man/memcached_stat.3 +116 -0
- data/ext/libmemcached-0.50/docs/man/memcached_stat_execute.3 +116 -0
- data/ext/libmemcached-0.50/docs/man/memcached_stat_get_keys.3 +116 -0
- data/ext/libmemcached-0.50/docs/man/memcached_stat_get_value.3 +116 -0
- data/ext/libmemcached-0.50/docs/man/memcached_stat_servername.3 +116 -0
- data/ext/libmemcached-0.50/docs/man/memcached_strerror.3 +69 -0
- data/ext/libmemcached-0.50/docs/man/memcached_verbosity.3 +66 -0
- data/ext/libmemcached-0.50/docs/man/memcached_version.3 +76 -0
- data/ext/libmemcached-0.50/docs/man/memcapable.1 +92 -0
- data/ext/libmemcached-0.50/docs/man/memcat.1 +71 -0
- data/ext/libmemcached-0.50/docs/man/memcp.1 +77 -0
- data/ext/libmemcached-0.50/docs/man/memdump.1 +66 -0
- data/ext/libmemcached-0.50/docs/man/memerror.1 +65 -0
- data/ext/libmemcached-0.50/docs/man/memflush.1 +73 -0
- data/ext/libmemcached-0.50/docs/man/memrm.1 +72 -0
- data/ext/libmemcached-0.50/docs/man/memslap.1 +59 -0
- data/ext/libmemcached-0.50/docs/man/memstat.1 +70 -0
- data/ext/libmemcached-0.50/example/include.am +24 -0
- data/ext/libmemcached-0.50/example/interface_v0.c +594 -0
- data/ext/libmemcached-0.50/example/interface_v1.c +411 -0
- data/ext/libmemcached-0.50/example/memcached_light.c +474 -0
- data/ext/libmemcached-0.50/example/memcached_light.h +7 -0
- data/ext/libmemcached-0.50/example/storage.c +172 -0
- data/ext/libmemcached-0.50/example/storage.h +27 -0
- data/ext/libmemcached-0.50/example/storage_innodb.c +535 -0
- data/ext/libmemcached-0.50/libhashkit/algorithm.cc +69 -0
- data/ext/libmemcached-0.50/libhashkit/algorithm.h +96 -0
- data/ext/libmemcached-0.50/libhashkit/behavior.cc +9 -0
- data/ext/libmemcached-0.50/libhashkit/behavior.h +26 -0
- data/ext/libmemcached-0.50/libhashkit/common.h +33 -0
- data/ext/libmemcached-0.50/libhashkit/configure.h.in +19 -0
- data/ext/libmemcached-0.50/libhashkit/crc32.cc +86 -0
- data/ext/libmemcached-0.50/libhashkit/digest.cc +62 -0
- data/ext/libmemcached-0.50/libhashkit/digest.h +30 -0
- data/ext/libmemcached-0.50/libhashkit/fnv.cc +75 -0
- data/ext/libmemcached-0.50/libhashkit/function.cc +156 -0
- data/ext/libmemcached-0.50/libhashkit/function.h +44 -0
- data/ext/libmemcached-0.50/libhashkit/hashkit.cc +100 -0
- data/ext/libmemcached-0.50/libhashkit/hashkit.h +95 -0
- data/ext/libmemcached-0.50/libhashkit/hashkit.hpp +97 -0
- data/ext/libmemcached-0.50/libhashkit/hsieh.cc +70 -0
- data/ext/libmemcached-0.50/libhashkit/include.am +69 -0
- data/ext/libmemcached-0.50/libhashkit/jenkins.cc +214 -0
- data/ext/libmemcached-0.50/libhashkit/ketama.cc +164 -0
- data/ext/libmemcached-0.50/libhashkit/md5.cc +367 -0
- data/ext/libmemcached-0.50/libhashkit/murmur.cc +77 -0
- data/ext/libmemcached-0.50/libhashkit/one_at_a_time.cc +34 -0
- data/ext/libmemcached-0.50/libhashkit/str_algorithm.cc +58 -0
- data/ext/libmemcached-0.50/libhashkit/str_algorithm.h +48 -0
- data/ext/libmemcached-0.50/libhashkit/strerror.cc +25 -0
- data/ext/libmemcached-0.50/libhashkit/strerror.h +23 -0
- data/ext/libmemcached-0.50/libhashkit/types.h +90 -0
- data/ext/libmemcached-0.50/libhashkit/visibility.h +48 -0
- data/ext/libmemcached-0.50/libmemcached/allocators.cc +119 -0
- data/ext/libmemcached-0.50/libmemcached/allocators.h +87 -0
- data/ext/libmemcached-0.50/libmemcached/analyze.cc +110 -0
- data/ext/libmemcached-0.50/libmemcached/analyze.h +66 -0
- data/ext/libmemcached-0.50/libmemcached/array.c +128 -0
- data/ext/libmemcached-0.50/libmemcached/array.h +75 -0
- data/ext/libmemcached-0.50/libmemcached/auto.cc +383 -0
- data/ext/libmemcached-0.50/libmemcached/auto.h +111 -0
- data/ext/libmemcached-0.50/libmemcached/basic_string.h +55 -0
- data/ext/libmemcached-0.50/libmemcached/behavior.cc +590 -0
- data/ext/libmemcached-0.50/libmemcached/behavior.h +86 -0
- data/ext/libmemcached-0.50/libmemcached/byteorder.cc +90 -0
- data/ext/libmemcached-0.50/libmemcached/byteorder.h +52 -0
- data/ext/libmemcached-0.50/libmemcached/callback.cc +160 -0
- data/ext/libmemcached-0.50/libmemcached/callback.h +61 -0
- data/ext/libmemcached-0.50/libmemcached/common.h +182 -0
- data/ext/libmemcached-0.50/libmemcached/configure.h.in +52 -0
- data/ext/libmemcached-0.50/libmemcached/connect.cc +626 -0
- data/ext/libmemcached-0.50/libmemcached/constants.h +167 -0
- data/ext/libmemcached-0.50/libmemcached/delete.cc +266 -0
- data/ext/libmemcached-0.50/libmemcached/delete.h +57 -0
- data/ext/libmemcached-0.50/libmemcached/do.cc +100 -0
- data/ext/libmemcached-0.50/libmemcached/do.hpp +49 -0
- data/ext/libmemcached-0.50/libmemcached/dump.cc +107 -0
- data/ext/libmemcached-0.50/libmemcached/dump.h +51 -0
- data/ext/libmemcached-0.50/libmemcached/error.cc +419 -0
- data/ext/libmemcached-0.50/libmemcached/error.h +61 -0
- data/ext/libmemcached-0.50/libmemcached/error.hpp +87 -0
- data/ext/libmemcached-0.50/libmemcached/exception.hpp +63 -0
- data/ext/libmemcached-0.50/libmemcached/fetch.cc +267 -0
- data/ext/libmemcached-0.50/libmemcached/fetch.h +53 -0
- data/ext/libmemcached-0.50/libmemcached/flush.cc +149 -0
- data/ext/libmemcached-0.50/libmemcached/flush.h +49 -0
- data/ext/libmemcached-0.50/libmemcached/flush_buffers.cc +66 -0
- data/ext/libmemcached-0.50/libmemcached/flush_buffers.h +49 -0
- data/ext/libmemcached-0.50/libmemcached/get.cc +842 -0
- data/ext/libmemcached-0.50/libmemcached/get.h +135 -0
- data/ext/libmemcached-0.50/libmemcached/hash.cc +178 -0
- data/ext/libmemcached-0.50/libmemcached/hash.h +68 -0
- data/ext/libmemcached-0.50/libmemcached/hosts.cc +516 -0
- data/ext/libmemcached-0.50/libmemcached/include.am +183 -0
- data/ext/libmemcached-0.50/libmemcached/initialize_query.cc +70 -0
- data/ext/libmemcached-0.50/libmemcached/initialize_query.h +51 -0
- data/ext/libmemcached-0.50/libmemcached/internal.h +46 -0
- data/ext/libmemcached-0.50/libmemcached/io.cc +920 -0
- data/ext/libmemcached-0.50/libmemcached/io.h +119 -0
- data/ext/libmemcached-0.50/libmemcached/is.h +48 -0
- data/ext/libmemcached-0.50/libmemcached/key.cc +23 -0
- data/ext/libmemcached-0.50/libmemcached/libmemcached_probes.d +30 -0
- data/ext/libmemcached-0.50/libmemcached/libmemcached_probes.h +118 -0
- data/ext/libmemcached-0.50/libmemcached/memcached.cc +437 -0
- data/ext/libmemcached-0.50/libmemcached/memcached.h +214 -0
- data/ext/libmemcached-0.50/libmemcached/memcached.hpp +799 -0
- data/ext/libmemcached-0.50/libmemcached/memcached/README.txt +7 -0
- data/ext/libmemcached-0.50/libmemcached/memcached/protocol_binary.h +726 -0
- data/ext/libmemcached-0.50/libmemcached/memcached/vbucket.h +26 -0
- data/ext/libmemcached-0.50/libmemcached/memcached_util.h +44 -0
- data/ext/libmemcached-0.50/libmemcached/memory.h +79 -0
- data/ext/libmemcached-0.50/libmemcached/options.cc +178 -0
- data/ext/libmemcached-0.50/libmemcached/options.h +49 -0
- data/ext/libmemcached-0.50/libmemcached/options.hpp +56 -0
- data/ext/libmemcached-0.50/libmemcached/options/context.h +151 -0
- data/ext/libmemcached-0.50/libmemcached/options/include.am +19 -0
- data/ext/libmemcached-0.50/libmemcached/options/parser.am +0 -0
- data/ext/libmemcached-0.50/libmemcached/options/parser.cc +2324 -0
- data/ext/libmemcached-0.50/libmemcached/options/parser.h +122 -0
- data/ext/libmemcached-0.50/libmemcached/options/scanner.cc +3203 -0
- data/ext/libmemcached-0.50/libmemcached/options/scanner.h +479 -0
- data/ext/libmemcached-0.50/libmemcached/options/server.h +60 -0
- data/ext/libmemcached-0.50/libmemcached/options/symbol.h +57 -0
- data/ext/libmemcached-0.50/libmemcached/parse.cc +110 -0
- data/ext/libmemcached-0.50/libmemcached/parse.h +23 -0
- data/ext/libmemcached-0.50/libmemcached/platform.h +56 -0
- data/ext/libmemcached-0.50/libmemcached/prefix_key.cc +65 -0
- data/ext/libmemcached-0.50/libmemcached/prefix_key.h +49 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/ascii_handler.c +963 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/ascii_handler.h +40 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/binary_handler.c +1121 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/binary_handler.h +47 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/cache.c +149 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/cache.h +116 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/callback.h +418 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/common.h +163 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/include.am +26 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/pedantic.c +202 -0
- data/ext/libmemcached-0.50/libmemcached/protocol/protocol_handler.c +365 -0
- data/ext/libmemcached-0.50/libmemcached/protocol_handler.h +215 -0
- data/ext/libmemcached-0.50/libmemcached/purge.cc +90 -0
- data/ext/libmemcached-0.50/libmemcached/quit.cc +139 -0
- data/ext/libmemcached-0.50/libmemcached/quit.h +55 -0
- data/ext/libmemcached-0.50/libmemcached/response.cc +619 -0
- data/ext/libmemcached-0.50/libmemcached/response.h +57 -0
- data/ext/libmemcached-0.50/libmemcached/result.cc +173 -0
- data/ext/libmemcached-0.50/libmemcached/result.h +100 -0
- data/ext/libmemcached-0.50/libmemcached/return.h +98 -0
- data/ext/libmemcached-0.50/libmemcached/sasl.c +408 -0
- data/ext/libmemcached-0.50/libmemcached/sasl.h +86 -0
- data/ext/libmemcached-0.50/libmemcached/server.cc +351 -0
- data/ext/libmemcached-0.50/libmemcached/server.h +169 -0
- data/ext/libmemcached-0.50/libmemcached/server_list.cc +88 -0
- data/ext/libmemcached-0.50/libmemcached/server_list.h +77 -0
- data/ext/libmemcached-0.50/libmemcached/stats.cc +623 -0
- data/ext/libmemcached-0.50/libmemcached/stats.h +96 -0
- data/ext/libmemcached-0.50/libmemcached/storage.cc +567 -0
- data/ext/libmemcached-0.50/libmemcached/storage.h +133 -0
- data/ext/libmemcached-0.50/libmemcached/strerror.cc +189 -0
- data/ext/libmemcached-0.50/libmemcached/strerror.h +50 -0
- data/ext/libmemcached-0.50/libmemcached/string.cc +253 -0
- data/ext/libmemcached-0.50/libmemcached/string.h +121 -0
- data/ext/libmemcached-0.50/libmemcached/touch.cc +106 -0
- data/ext/libmemcached-0.50/libmemcached/touch.h +59 -0
- data/ext/libmemcached-0.50/libmemcached/types.h +117 -0
- data/ext/libmemcached-0.50/libmemcached/util.h +40 -0
- data/ext/libmemcached-0.50/libmemcached/util/flush.cc +61 -0
- data/ext/libmemcached-0.50/libmemcached/util/flush.h +50 -0
- data/ext/libmemcached-0.50/libmemcached/util/include.am +34 -0
- data/ext/libmemcached-0.50/libmemcached/util/ping.cc +62 -0
- data/ext/libmemcached-0.50/libmemcached/util/ping.h +49 -0
- data/ext/libmemcached-0.50/libmemcached/util/pool.cc +392 -0
- data/ext/libmemcached-0.50/libmemcached/util/pool.h +78 -0
- data/ext/libmemcached-0.50/libmemcached/util/version.cc +87 -0
- data/ext/libmemcached-0.50/libmemcached/util/version.h +53 -0
- data/ext/libmemcached-0.50/libmemcached/verbosity.cc +97 -0
- data/ext/libmemcached-0.50/libmemcached/verbosity.h +50 -0
- data/ext/libmemcached-0.50/libmemcached/version.cc +214 -0
- data/ext/libmemcached-0.50/libmemcached/version.h +52 -0
- data/ext/libmemcached-0.50/libmemcached/virtual_bucket.c +118 -0
- data/ext/libmemcached-0.50/libmemcached/virtual_bucket.h +59 -0
- data/ext/libmemcached-0.50/libmemcached/visibility.h +51 -0
- data/ext/libmemcached-0.50/libmemcached/watchpoint.h +110 -0
- data/ext/libmemcached-0.50/libtest/callbacks.h +21 -0
- data/ext/libmemcached-0.50/libtest/collection.h +19 -0
- data/ext/libmemcached-0.50/libtest/common.h +50 -0
- data/ext/libmemcached-0.50/libtest/core.h +11 -0
- data/ext/libmemcached-0.50/libtest/error.h +18 -0
- data/ext/libmemcached-0.50/libtest/failed.h +52 -0
- data/ext/libmemcached-0.50/libtest/framework.cc +57 -0
- data/ext/libmemcached-0.50/libtest/framework.h +137 -0
- data/ext/libmemcached-0.50/libtest/get.h +22 -0
- data/ext/libmemcached-0.50/libtest/include.am +52 -0
- data/ext/libmemcached-0.50/libtest/runner.h +19 -0
- data/ext/libmemcached-0.50/libtest/server.c +355 -0
- data/ext/libmemcached-0.50/libtest/server.h +43 -0
- data/ext/libmemcached-0.50/libtest/stats.h +30 -0
- data/ext/libmemcached-0.50/libtest/strerror.h +14 -0
- data/ext/libmemcached-0.50/libtest/test.cc +319 -0
- data/ext/libmemcached-0.50/libtest/test.h +162 -0
- data/ext/libmemcached-0.50/libtest/test.hpp +46 -0
- data/ext/libmemcached-0.50/libtest/visibility.h +69 -0
- data/ext/libmemcached-0.50/m4/ac_cxx_header_stdcxx_98.m4 +83 -0
- data/ext/libmemcached-0.50/m4/acx_pthread.m4 +271 -0
- data/ext/libmemcached-0.50/m4/byteorder.m4 +19 -0
- data/ext/libmemcached-0.50/m4/deprecated.m4 +17 -0
- data/ext/libmemcached-0.50/m4/eagain.m4 +28 -0
- data/ext/libmemcached-0.50/m4/enable_utillib.m4 +16 -0
- data/ext/libmemcached-0.50/m4/gettext.m4 +379 -0
- data/ext/libmemcached-0.50/m4/hsieh.m4 +18 -0
- data/ext/libmemcached-0.50/m4/iconv.m4 +214 -0
- data/ext/libmemcached-0.50/m4/lib-ld.m4 +110 -0
- data/ext/libmemcached-0.50/m4/lib-link.m4 +767 -0
- data/ext/libmemcached-0.50/m4/lib-prefix.m4 +221 -0
- data/ext/libmemcached-0.50/m4/libtool.m4 +7851 -0
- data/ext/libmemcached-0.50/m4/ltoptions.m4 +369 -0
- data/ext/libmemcached-0.50/m4/ltsugar.m4 +123 -0
- data/ext/libmemcached-0.50/m4/ltversion.m4 +23 -0
- data/ext/libmemcached-0.50/m4/lt~obsolete.m4 +98 -0
- data/ext/libmemcached-0.50/m4/memaslap.m4 +9 -0
- data/ext/libmemcached-0.50/m4/memcached.m4 +31 -0
- data/ext/libmemcached-0.50/m4/murmur.m4 +18 -0
- data/ext/libmemcached-0.50/m4/pandora_64bit.m4 +60 -0
- data/ext/libmemcached-0.50/m4/pandora_bison.m4 +33 -0
- data/ext/libmemcached-0.50/m4/pandora_canonical.m4 +418 -0
- data/ext/libmemcached-0.50/m4/pandora_check_compiler_version.m4 +37 -0
- data/ext/libmemcached-0.50/m4/pandora_check_cxx_standard.m4 +23 -0
- data/ext/libmemcached-0.50/m4/pandora_cinttypes.m4 +39 -0
- data/ext/libmemcached-0.50/m4/pandora_clock_gettime.m4 +15 -0
- data/ext/libmemcached-0.50/m4/pandora_compile_stdcxx_0x.m4 +103 -0
- data/ext/libmemcached-0.50/m4/pandora_cstdint.m4 +38 -0
- data/ext/libmemcached-0.50/m4/pandora_cxx_demangle.m4 +27 -0
- data/ext/libmemcached-0.50/m4/pandora_enable_dtrace.m4 +60 -0
- data/ext/libmemcached-0.50/m4/pandora_ensure_gcc_version.m4 +62 -0
- data/ext/libmemcached-0.50/m4/pandora_extensions.m4 +16 -0
- data/ext/libmemcached-0.50/m4/pandora_fdatasync.m4 +25 -0
- data/ext/libmemcached-0.50/m4/pandora_flex.m4 +33 -0
- data/ext/libmemcached-0.50/m4/pandora_have_better_malloc.m4 +66 -0
- data/ext/libmemcached-0.50/m4/pandora_have_boost.m4 +93 -0
- data/ext/libmemcached-0.50/m4/pandora_have_gcc_atomics.m4 +37 -0
- data/ext/libmemcached-0.50/m4/pandora_have_innodb.m4 +41 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libaio.m4 +56 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libavahi.m4 +41 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libbdb.m4 +40 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libboost_date_time.m4 +46 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libboost_filesystem.m4 +47 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libboost_iostreams.m4 +49 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libboost_options.m4 +47 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libboost_regex.m4 +54 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libboost_test.m4 +45 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libboost_thread.m4 +54 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libcassandra.m4 +44 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libcurl.m4 +62 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libdl.m4 +51 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libdrizzle.m4 +61 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libevent.m4 +66 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libgearman.m4 +41 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libgtest.m4 +47 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libhaildb.m4 +43 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libhashkit.m4 +42 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libinnodb.m4 +64 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libldap.m4 +73 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libmemcached.m4 +106 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libmysqlclient.m4 +146 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libndbclient.m4 +80 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libpcre.m4 +73 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libpq.m4 +46 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libpqxx.m4 +44 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libsqlite3.m4 +42 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libtokyocabinet.m4 +54 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libuuid.m4 +55 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libvbucket.m4 +40 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libxml2.m4 +52 -0
- data/ext/libmemcached-0.50/m4/pandora_have_libz.m4 +51 -0
- data/ext/libmemcached-0.50/m4/pandora_have_protobuf.m4 +82 -0
- data/ext/libmemcached-0.50/m4/pandora_have_sasl.m4 +133 -0
- data/ext/libmemcached-0.50/m4/pandora_have_thrift.m4 +45 -0
- data/ext/libmemcached-0.50/m4/pandora_header_assert.m4 +23 -0
- data/ext/libmemcached-0.50/m4/pandora_header_stdcxx_98.m4 +83 -0
- data/ext/libmemcached-0.50/m4/pandora_intltool.m4 +225 -0
- data/ext/libmemcached-0.50/m4/pandora_libtool.m4 +25 -0
- data/ext/libmemcached-0.50/m4/pandora_optimize.m4 +75 -0
- data/ext/libmemcached-0.50/m4/pandora_platform.m4 +117 -0
- data/ext/libmemcached-0.50/m4/pandora_plugins.m4 +62 -0
- data/ext/libmemcached-0.50/m4/pandora_print_callstack.m4 +61 -0
- data/ext/libmemcached-0.50/m4/pandora_pthread.m4 +258 -0
- data/ext/libmemcached-0.50/m4/pandora_python3_devel.m4 +236 -0
- data/ext/libmemcached-0.50/m4/pandora_run_cpplint.m4 +8 -0
- data/ext/libmemcached-0.50/m4/pandora_sasl.m4 +133 -0
- data/ext/libmemcached-0.50/m4/pandora_shared_ptr.m4 +59 -0
- data/ext/libmemcached-0.50/m4/pandora_stack_direction.m4 +39 -0
- data/ext/libmemcached-0.50/m4/pandora_stl_hash.m4 +94 -0
- data/ext/libmemcached-0.50/m4/pandora_swig.m4 +39 -0
- data/ext/libmemcached-0.50/m4/pandora_use_pipe.m4 +36 -0
- data/ext/libmemcached-0.50/m4/pandora_vc_build.m4 +168 -0
- data/ext/libmemcached-0.50/m4/pandora_version.m4 +11 -0
- data/ext/libmemcached-0.50/m4/pandora_visibility.m4 +75 -0
- data/ext/libmemcached-0.50/m4/pandora_warnings.m4 +447 -0
- data/ext/libmemcached-0.50/m4/pandora_with_gettext.m4 +44 -0
- data/ext/libmemcached-0.50/m4/pandora_with_lua.m4 +55 -0
- data/ext/libmemcached-0.50/m4/pandora_with_memcached.m4 +41 -0
- data/ext/libmemcached-0.50/m4/pandora_with_perl.m4 +81 -0
- data/ext/libmemcached-0.50/m4/pandora_with_php.m4 +56 -0
- data/ext/libmemcached-0.50/m4/pandora_with_python.m4 +37 -0
- data/ext/libmemcached-0.50/m4/pandora_with_python3.m4 +44 -0
- data/ext/libmemcached-0.50/m4/pandora_with_r.m4 +33 -0
- data/ext/libmemcached-0.50/m4/pandora_with_ruby.m4 +79 -0
- data/ext/libmemcached-0.50/m4/pandora_with_valgrind.m4 +17 -0
- data/ext/libmemcached-0.50/m4/pkg.m4 +157 -0
- data/ext/libmemcached-0.50/m4/po.m4 +449 -0
- data/ext/libmemcached-0.50/m4/progtest.m4 +92 -0
- data/ext/libmemcached-0.50/m4/protocol_binary.m4 +36 -0
- data/ext/libmemcached-0.50/m4/setsockopt.m4 +73 -0
- data/ext/libmemcached-0.50/m4/socket_send_flags.m4 +66 -0
- data/ext/libmemcached-0.50/poll/include.am +8 -0
- data/ext/libmemcached-0.50/poll/poll.c +77 -0
- data/ext/libmemcached-0.50/poll/poll.h +45 -0
- data/ext/libmemcached-0.50/support/include.am +11 -0
- data/ext/libmemcached-0.50/support/libmemcached-fc.spec.in +105 -0
- data/ext/libmemcached-0.50/support/libmemcached.pc.in +10 -0
- data/ext/libmemcached-0.50/support/libmemcached.spec.in +281 -0
- data/ext/libmemcached-0.50/support/set_benchmark.sh +5 -0
- data/ext/libmemcached-0.50/tests/atomsmasher.cc +295 -0
- data/ext/libmemcached-0.50/tests/basic.cc +134 -0
- data/ext/libmemcached-0.50/tests/basic.h +66 -0
- data/ext/libmemcached-0.50/tests/cpp_example.cc +195 -0
- data/ext/libmemcached-0.50/tests/deprecated.cc +72 -0
- data/ext/libmemcached-0.50/tests/deprecated.h +49 -0
- data/ext/libmemcached-0.50/tests/error_conditions.cc +63 -0
- data/ext/libmemcached-0.50/tests/error_conditions.h +48 -0
- data/ext/libmemcached-0.50/tests/hash_plus.cc +225 -0
- data/ext/libmemcached-0.50/tests/hash_results.h +127 -0
- data/ext/libmemcached-0.50/tests/hashkit_functions.cc +619 -0
- data/ext/libmemcached-0.50/tests/include.am +342 -0
- data/ext/libmemcached-0.50/tests/ketama_test_cases.h +121 -0
- data/ext/libmemcached-0.50/tests/ketama_test_cases_spy.h +118 -0
- data/ext/libmemcached-0.50/tests/libmemcached_world.h +205 -0
- data/ext/libmemcached-0.50/tests/mem_functions.cc +6648 -0
- data/ext/libmemcached-0.50/tests/mem_udp.cc +510 -0
- data/ext/libmemcached-0.50/tests/output_plus.res +5 -0
- data/ext/libmemcached-0.50/tests/parser.cc +599 -0
- data/ext/libmemcached-0.50/tests/parser.h +109 -0
- data/ext/libmemcached-0.50/tests/plus.cpp +240 -0
- data/ext/libmemcached-0.50/tests/pool.cc +78 -0
- data/ext/libmemcached-0.50/tests/pool.h +49 -0
- data/ext/libmemcached-0.50/tests/print.cc +58 -0
- data/ext/libmemcached-0.50/tests/print.h +51 -0
- data/ext/libmemcached-0.50/tests/replication.cc +333 -0
- data/ext/libmemcached-0.50/tests/replication.h +64 -0
- data/ext/libmemcached-0.50/tests/start.cc +29 -0
- data/ext/libmemcached-0.50/tests/string.cc +174 -0
- data/ext/libmemcached-0.50/tests/string.h +67 -0
- data/ext/libmemcached-0.50/tests/virtual_buckets.cc +143 -0
- data/ext/libmemcached-0.50/tests/virtual_buckets.h +51 -0
- data/ext/libmemcached-0.50/win32/include.am +11 -0
- data/ext/libmemcached-0.50/win32/wrappers.h +55 -0
- data/ext/rlibmemcached.i +263 -0
- data/ext/rlibmemcached_wrap.c +16732 -0
- data/lib/memcached.rb +32 -0
- data/lib/memcached/auth.rb +16 -0
- data/lib/memcached/behaviors.rb +77 -0
- data/lib/memcached/exceptions.rb +84 -0
- data/lib/memcached/experimental.rb +48 -0
- data/lib/memcached/memcached.rb +660 -0
- data/lib/memcached/rails.rb +133 -0
- data/test/profile/benchmark.rb +245 -0
- data/test/profile/c_profiler.rb +14 -0
- data/test/profile/exercise.rb +185 -0
- data/test/profile/rb_profiler.rb +21 -0
- data/test/profile/valgrind.rb +10 -0
- data/test/setup.rb +30 -0
- data/test/teardown.rb +0 -0
- data/test/test_helper.rb +19 -0
- data/test/unit/binding_test.rb +8 -0
- data/test/unit/memcached_experimental_test.rb +274 -0
- data/test/unit/memcached_test.rb +1293 -0
- data/test/unit/rails_test.rb +122 -0
- metadata +650 -0
- metadata.gz.sig +0 -0
@@ -0,0 +1,70 @@
|
|
1
|
+
/* By Paul Hsieh (C) 2004, 2005. Covered under the Paul Hsieh
|
2
|
+
* derivative license.
|
3
|
+
* See: http://www.azillionmonkeys.com/qed/weblicense.html for license
|
4
|
+
* details.
|
5
|
+
* http://www.azillionmonkeys.com/qed/hash.html
|
6
|
+
*/
|
7
|
+
|
8
|
+
#include <libhashkit/common.h>
|
9
|
+
|
10
|
+
#undef get16bits
|
11
|
+
#if (defined(__GNUC__) && defined(__i386__))
|
12
|
+
#define get16bits(d) (*((const uint16_t *) (d)))
|
13
|
+
#endif
|
14
|
+
|
15
|
+
#if !defined (get16bits)
|
16
|
+
#define get16bits(d) ((((uint32_t)(((const uint8_t *)(d))[1])) << 8)\
|
17
|
+
+(uint32_t)(((const uint8_t *)(d))[0]) )
|
18
|
+
#endif
|
19
|
+
|
20
|
+
uint32_t hashkit_hsieh(const char *key, size_t key_length, void *context __attribute__((unused)))
|
21
|
+
{
|
22
|
+
uint32_t hash = 0, tmp;
|
23
|
+
int rem;
|
24
|
+
|
25
|
+
if (key_length <= 0 || key == NULL)
|
26
|
+
return 0;
|
27
|
+
|
28
|
+
rem = key_length & 3;
|
29
|
+
key_length >>= 2;
|
30
|
+
|
31
|
+
/* Main loop */
|
32
|
+
for (;key_length > 0; key_length--)
|
33
|
+
{
|
34
|
+
hash += get16bits (key);
|
35
|
+
tmp = (get16bits (key+2) << 11) ^ hash;
|
36
|
+
hash = (hash << 16) ^ tmp;
|
37
|
+
key += 2*sizeof (uint16_t);
|
38
|
+
hash += hash >> 11;
|
39
|
+
}
|
40
|
+
|
41
|
+
/* Handle end cases */
|
42
|
+
switch (rem)
|
43
|
+
{
|
44
|
+
case 3: hash += get16bits (key);
|
45
|
+
hash ^= hash << 16;
|
46
|
+
hash ^= (uint32_t)key[sizeof (uint16_t)] << 18;
|
47
|
+
hash += hash >> 11;
|
48
|
+
break;
|
49
|
+
case 2: hash += get16bits (key);
|
50
|
+
hash ^= hash << 11;
|
51
|
+
hash += hash >> 17;
|
52
|
+
break;
|
53
|
+
case 1: hash += (unsigned char)(*key);
|
54
|
+
hash ^= hash << 10;
|
55
|
+
hash += hash >> 1;
|
56
|
+
default:
|
57
|
+
break;
|
58
|
+
}
|
59
|
+
|
60
|
+
/* Force "avalanching" of final 127 bits */
|
61
|
+
hash ^= hash << 3;
|
62
|
+
hash += hash >> 5;
|
63
|
+
hash ^= hash << 4;
|
64
|
+
hash += hash >> 17;
|
65
|
+
hash ^= hash << 25;
|
66
|
+
hash += hash >> 6;
|
67
|
+
|
68
|
+
return hash;
|
69
|
+
}
|
70
|
+
|
@@ -0,0 +1,69 @@
|
|
1
|
+
# vim:ft=automake
|
2
|
+
# included from Top Level Makefile.am
|
3
|
+
# All paths should be given relative to the root
|
4
|
+
#
|
5
|
+
# HashKit
|
6
|
+
# Copyright (C) 2009 Brian Aker
|
7
|
+
# All rights reserved.
|
8
|
+
#
|
9
|
+
# Use and distribution licensed under the BSD license. See
|
10
|
+
# the COPYING file in the parent directory for full text.
|
11
|
+
|
12
|
+
lib_LTLIBRARIES+= libhashkit/libhashkit.la
|
13
|
+
|
14
|
+
EXTRA_DIST+= \
|
15
|
+
libhashkit/configure.h.in
|
16
|
+
|
17
|
+
|
18
|
+
nobase_include_HEADERS+= \
|
19
|
+
libhashkit/algorithm.h \
|
20
|
+
libhashkit/behavior.h \
|
21
|
+
libhashkit/configure.h \
|
22
|
+
libhashkit/digest.h \
|
23
|
+
libhashkit/function.h \
|
24
|
+
libhashkit/hashkit.h \
|
25
|
+
libhashkit/hashkit.hpp \
|
26
|
+
libhashkit/strerror.h \
|
27
|
+
libhashkit/str_algorithm.h \
|
28
|
+
libhashkit/types.h \
|
29
|
+
libhashkit/visibility.h
|
30
|
+
|
31
|
+
noinst_HEADERS+= \
|
32
|
+
libhashkit/common.h
|
33
|
+
|
34
|
+
libhashkit_libhashkit_la_SOURCES= \
|
35
|
+
libhashkit/algorithm.cc \
|
36
|
+
libhashkit/behavior.cc \
|
37
|
+
libhashkit/crc32.cc \
|
38
|
+
libhashkit/digest.cc \
|
39
|
+
libhashkit/fnv.cc \
|
40
|
+
libhashkit/function.cc \
|
41
|
+
libhashkit/hashkit.cc \
|
42
|
+
libhashkit/jenkins.cc \
|
43
|
+
libhashkit/ketama.cc \
|
44
|
+
libhashkit/md5.cc \
|
45
|
+
libhashkit/one_at_a_time.cc \
|
46
|
+
libhashkit/str_algorithm.cc \
|
47
|
+
libhashkit/strerror.cc
|
48
|
+
|
49
|
+
if INCLUDE_HSIEH_SRC
|
50
|
+
libhashkit_libhashkit_la_SOURCES+= libhashkit/hsieh.cc
|
51
|
+
endif
|
52
|
+
|
53
|
+
if INCLUDE_MURMUR_SRC
|
54
|
+
libhashkit_libhashkit_la_SOURCES+= libhashkit/murmur.cc
|
55
|
+
endif
|
56
|
+
|
57
|
+
libhashkit_libhashkit_la_CXXFLAGS= \
|
58
|
+
${AM_CXXFLAGS} \
|
59
|
+
-DBUILDING_HASHKIT
|
60
|
+
|
61
|
+
libhashkit_libhashkit_la_LDFLAGS= \
|
62
|
+
$(LIBM) \
|
63
|
+
-version-info $(HASHKIT_LIBRARY_VERSION)
|
64
|
+
|
65
|
+
noinst_LTLIBRARIES+= libhashkit/libhashkitinc.la
|
66
|
+
|
67
|
+
libhashkit_libhashkitinc_la_SOURCES= ${libhashkit_libhashkit_la_SOURCES}
|
68
|
+
libhashkit_libhashkitinc_la_CFLAGS= ${libhashkit_libhashkit_la_CFLAGS}
|
69
|
+
libhashkit_libhashkitinc_la_LDFLAGS= $(LIBM)
|
@@ -0,0 +1,214 @@
|
|
1
|
+
/*
|
2
|
+
*
|
3
|
+
* By Bob Jenkins, 2006. bob_jenkins@burtleburtle.net. You may use this
|
4
|
+
* code any way you wish, private, educational, or commercial. It's free.
|
5
|
+
* Use for hash table lookup, or anything where one collision in 2^^32 is
|
6
|
+
* acceptable. Do NOT use for cryptographic purposes.
|
7
|
+
* http://burtleburtle.net/bob/hash/index.html
|
8
|
+
*
|
9
|
+
* Modified by Brian Pontz for libmemcached
|
10
|
+
* TODO:
|
11
|
+
* Add big endian support
|
12
|
+
*/
|
13
|
+
|
14
|
+
#include <libhashkit/common.h>
|
15
|
+
|
16
|
+
#define hashsize(n) ((uint32_t)1<<(n))
|
17
|
+
#define hashmask(n) (hashsize(n)-1)
|
18
|
+
#define rot(x,k) (((x)<<(k)) | ((x)>>(32-(k))))
|
19
|
+
|
20
|
+
#define mix(a,b,c) \
|
21
|
+
{ \
|
22
|
+
a -= c; a ^= rot(c, 4); c += b; \
|
23
|
+
b -= a; b ^= rot(a, 6); a += c; \
|
24
|
+
c -= b; c ^= rot(b, 8); b += a; \
|
25
|
+
a -= c; a ^= rot(c,16); c += b; \
|
26
|
+
b -= a; b ^= rot(a,19); a += c; \
|
27
|
+
c -= b; c ^= rot(b, 4); b += a; \
|
28
|
+
}
|
29
|
+
|
30
|
+
#define final(a,b,c) \
|
31
|
+
{ \
|
32
|
+
c ^= b; c -= rot(b,14); \
|
33
|
+
a ^= c; a -= rot(c,11); \
|
34
|
+
b ^= a; b -= rot(a,25); \
|
35
|
+
c ^= b; c -= rot(b,16); \
|
36
|
+
a ^= c; a -= rot(c,4); \
|
37
|
+
b ^= a; b -= rot(a,14); \
|
38
|
+
c ^= b; c -= rot(b,24); \
|
39
|
+
}
|
40
|
+
|
41
|
+
#define JENKINS_INITVAL 13
|
42
|
+
|
43
|
+
/*
|
44
|
+
jenkins_hash() -- hash a variable-length key into a 32-bit value
|
45
|
+
k : the key (the unaligned variable-length array of bytes)
|
46
|
+
length : the length of the key, counting by bytes
|
47
|
+
initval : can be any 4-byte value
|
48
|
+
Returns a 32-bit value. Every bit of the key affects every bit of
|
49
|
+
the return value. Two keys differing by one or two bits will have
|
50
|
+
totally different hash values.
|
51
|
+
|
52
|
+
The best hash table sizes are powers of 2. There is no need to do
|
53
|
+
mod a prime (mod is sooo slow!). If you need less than 32 bits,
|
54
|
+
use a bitmask. For example, if you need only 10 bits, do
|
55
|
+
h = (h & hashmask(10));
|
56
|
+
In which case, the hash table should have hashsize(10) elements.
|
57
|
+
*/
|
58
|
+
|
59
|
+
uint32_t hashkit_jenkins(const char *key, size_t length, void *context)
|
60
|
+
{
|
61
|
+
uint32_t a,b,c; /* internal state */
|
62
|
+
union { const void *ptr; size_t i; } u; /* needed for Mac Powerbook G4 */
|
63
|
+
(void)context;
|
64
|
+
|
65
|
+
/* Set up the internal state */
|
66
|
+
a = b = c = 0xdeadbeef + ((uint32_t)length) + JENKINS_INITVAL;
|
67
|
+
|
68
|
+
u.ptr = key;
|
69
|
+
#ifndef WORDS_BIGENDIAN
|
70
|
+
if ((u.i & 0x3) == 0)
|
71
|
+
{
|
72
|
+
const uint32_t *k = (const uint32_t *)key; /* read 32-bit chunks */
|
73
|
+
|
74
|
+
/*------ all but last block: aligned reads and affect 32 bits of (a,b,c) */
|
75
|
+
while (length > 12)
|
76
|
+
{
|
77
|
+
a += k[0];
|
78
|
+
b += k[1];
|
79
|
+
c += k[2];
|
80
|
+
mix(a,b,c);
|
81
|
+
length -= 12;
|
82
|
+
k += 3;
|
83
|
+
}
|
84
|
+
|
85
|
+
/*----------------------------- handle the last (probably partial) block */
|
86
|
+
/*
|
87
|
+
* "k[2]&0xffffff" actually reads beyond the end of the string, but
|
88
|
+
* then masks off the part it's not allowed to read. Because the
|
89
|
+
* string is aligned, the masked-off tail is in the same word as the
|
90
|
+
* rest of the string. Every machine with memory protection I've seen
|
91
|
+
* does it on word boundaries, so is OK with this. But VALGRIND will
|
92
|
+
* still catch it and complain. The masking trick does make the hash
|
93
|
+
* noticably faster for short strings (like English words).
|
94
|
+
*/
|
95
|
+
switch(length)
|
96
|
+
{
|
97
|
+
case 12: c+=k[2]; b+=k[1]; a+=k[0]; break;
|
98
|
+
case 11: c+=k[2]&0xffffff; b+=k[1]; a+=k[0]; break;
|
99
|
+
case 10: c+=k[2]&0xffff; b+=k[1]; a+=k[0]; break;
|
100
|
+
case 9 : c+=k[2]&0xff; b+=k[1]; a+=k[0]; break;
|
101
|
+
case 8 : b+=k[1]; a+=k[0]; break;
|
102
|
+
case 7 : b+=k[1]&0xffffff; a+=k[0]; break;
|
103
|
+
case 6 : b+=k[1]&0xffff; a+=k[0]; break;
|
104
|
+
case 5 : b+=k[1]&0xff; a+=k[0]; break;
|
105
|
+
case 4 : a+=k[0]; break;
|
106
|
+
case 3 : a+=k[0]&0xffffff; break;
|
107
|
+
case 2 : a+=k[0]&0xffff; break;
|
108
|
+
case 1 : a+=k[0]&0xff; break;
|
109
|
+
case 0 : return c; /* zero length strings require no mixing */
|
110
|
+
default: return c;
|
111
|
+
}
|
112
|
+
|
113
|
+
}
|
114
|
+
else if ((u.i & 0x1) == 0)
|
115
|
+
{
|
116
|
+
const uint16_t *k = (const uint16_t *)key; /* read 16-bit chunks */
|
117
|
+
const uint8_t *k8;
|
118
|
+
|
119
|
+
/*--------------- all but last block: aligned reads and different mixing */
|
120
|
+
while (length > 12)
|
121
|
+
{
|
122
|
+
a += k[0] + (((uint32_t)k[1])<<16);
|
123
|
+
b += k[2] + (((uint32_t)k[3])<<16);
|
124
|
+
c += k[4] + (((uint32_t)k[5])<<16);
|
125
|
+
mix(a,b,c);
|
126
|
+
length -= 12;
|
127
|
+
k += 6;
|
128
|
+
}
|
129
|
+
|
130
|
+
/*----------------------------- handle the last (probably partial) block */
|
131
|
+
k8 = (const uint8_t *)k;
|
132
|
+
switch(length)
|
133
|
+
{
|
134
|
+
case 12: c+=k[4]+(((uint32_t)k[5])<<16);
|
135
|
+
b+=k[2]+(((uint32_t)k[3])<<16);
|
136
|
+
a+=k[0]+(((uint32_t)k[1])<<16);
|
137
|
+
break;
|
138
|
+
case 11: c+=((uint32_t)k8[10])<<16; /* fall through */
|
139
|
+
case 10: c+=k[4];
|
140
|
+
b+=k[2]+(((uint32_t)k[3])<<16);
|
141
|
+
a+=k[0]+(((uint32_t)k[1])<<16);
|
142
|
+
break;
|
143
|
+
case 9 : c+=k8[8]; /* fall through */
|
144
|
+
case 8 : b+=k[2]+(((uint32_t)k[3])<<16);
|
145
|
+
a+=k[0]+(((uint32_t)k[1])<<16);
|
146
|
+
break;
|
147
|
+
case 7 : b+=((uint32_t)k8[6])<<16; /* fall through */
|
148
|
+
case 6 : b+=k[2];
|
149
|
+
a+=k[0]+(((uint32_t)k[1])<<16);
|
150
|
+
break;
|
151
|
+
case 5 : b+=k8[4]; /* fall through */
|
152
|
+
case 4 : a+=k[0]+(((uint32_t)k[1])<<16);
|
153
|
+
break;
|
154
|
+
case 3 : a+=((uint32_t)k8[2])<<16; /* fall through */
|
155
|
+
case 2 : a+=k[0];
|
156
|
+
break;
|
157
|
+
case 1 : a+=k8[0];
|
158
|
+
break;
|
159
|
+
case 0 : return c; /* zero length requires no mixing */
|
160
|
+
default: return c;
|
161
|
+
}
|
162
|
+
|
163
|
+
}
|
164
|
+
else
|
165
|
+
{ /* need to read the key one byte at a time */
|
166
|
+
#endif /* little endian */
|
167
|
+
const uint8_t *k = (const uint8_t *)key;
|
168
|
+
|
169
|
+
/*--------------- all but the last block: affect some 32 bits of (a,b,c) */
|
170
|
+
while (length > 12)
|
171
|
+
{
|
172
|
+
a += k[0];
|
173
|
+
a += ((uint32_t)k[1])<<8;
|
174
|
+
a += ((uint32_t)k[2])<<16;
|
175
|
+
a += ((uint32_t)k[3])<<24;
|
176
|
+
b += k[4];
|
177
|
+
b += ((uint32_t)k[5])<<8;
|
178
|
+
b += ((uint32_t)k[6])<<16;
|
179
|
+
b += ((uint32_t)k[7])<<24;
|
180
|
+
c += k[8];
|
181
|
+
c += ((uint32_t)k[9])<<8;
|
182
|
+
c += ((uint32_t)k[10])<<16;
|
183
|
+
c += ((uint32_t)k[11])<<24;
|
184
|
+
mix(a,b,c);
|
185
|
+
length -= 12;
|
186
|
+
k += 12;
|
187
|
+
}
|
188
|
+
|
189
|
+
/*-------------------------------- last block: affect all 32 bits of (c) */
|
190
|
+
switch(length) /* all the case statements fall through */
|
191
|
+
{
|
192
|
+
case 12: c+=((uint32_t)k[11])<<24;
|
193
|
+
case 11: c+=((uint32_t)k[10])<<16;
|
194
|
+
case 10: c+=((uint32_t)k[9])<<8;
|
195
|
+
case 9 : c+=k[8];
|
196
|
+
case 8 : b+=((uint32_t)k[7])<<24;
|
197
|
+
case 7 : b+=((uint32_t)k[6])<<16;
|
198
|
+
case 6 : b+=((uint32_t)k[5])<<8;
|
199
|
+
case 5 : b+=k[4];
|
200
|
+
case 4 : a+=((uint32_t)k[3])<<24;
|
201
|
+
case 3 : a+=((uint32_t)k[2])<<16;
|
202
|
+
case 2 : a+=((uint32_t)k[1])<<8;
|
203
|
+
case 1 : a+=k[0];
|
204
|
+
break;
|
205
|
+
case 0 : return c;
|
206
|
+
default : return c;
|
207
|
+
}
|
208
|
+
#ifndef WORDS_BIGENDIAN
|
209
|
+
}
|
210
|
+
#endif
|
211
|
+
|
212
|
+
final(a,b,c);
|
213
|
+
return c;
|
214
|
+
}
|
@@ -0,0 +1,164 @@
|
|
1
|
+
/* HashKit
|
2
|
+
* Copyright (C) 2006-2009 Brian Aker
|
3
|
+
* All rights reserved.
|
4
|
+
*
|
5
|
+
* Use and distribution licensed under the BSD license. See
|
6
|
+
* the COPYING file in the parent directory for full text.
|
7
|
+
*/
|
8
|
+
|
9
|
+
#include <libhashkit/common.h>
|
10
|
+
#include <math.h>
|
11
|
+
|
12
|
+
#if 0
|
13
|
+
static uint32_t ketama_server_hash(const char *key, unsigned int key_length, int alignment)
|
14
|
+
{
|
15
|
+
unsigned char results[16];
|
16
|
+
|
17
|
+
md5_signature((unsigned char*)key, key_length, results);
|
18
|
+
return ((uint32_t) (results[3 + alignment * 4] & 0xFF) << 24)
|
19
|
+
| ((uint32_t) (results[2 + alignment * 4] & 0xFF) << 16)
|
20
|
+
| ((uint32_t) (results[1 + alignment * 4] & 0xFF) << 8)
|
21
|
+
| (results[0 + alignment * 4] & 0xFF);
|
22
|
+
}
|
23
|
+
|
24
|
+
static int continuum_points_cmp(const void *t1, const void *t2)
|
25
|
+
{
|
26
|
+
hashkit_continuum_point_st *ct1= (hashkit_continuum_point_st *)t1;
|
27
|
+
hashkit_continuum_point_st *ct2= (hashkit_continuum_point_st *)t2;
|
28
|
+
|
29
|
+
if (ct1->value == ct2->value)
|
30
|
+
return 0;
|
31
|
+
else if (ct1->value > ct2->value)
|
32
|
+
return 1;
|
33
|
+
else
|
34
|
+
return -1;
|
35
|
+
}
|
36
|
+
|
37
|
+
int update_continuum(hashkit_st *hashkit)
|
38
|
+
{
|
39
|
+
uint32_t count;
|
40
|
+
uint32_t continuum_index= 0;
|
41
|
+
uint32_t value;
|
42
|
+
uint32_t points_index;
|
43
|
+
uint32_t points_count= 0;
|
44
|
+
uint32_t points_per_server;
|
45
|
+
uint32_t points_per_hash;
|
46
|
+
uint64_t total_weight= 0;
|
47
|
+
uint32_t live_servers;
|
48
|
+
uint8_t *context;
|
49
|
+
|
50
|
+
if (hashkit->active_fn != NULL || hashkit->weight_fn != NULL)
|
51
|
+
{
|
52
|
+
live_servers= 0;
|
53
|
+
|
54
|
+
for (count= 0, context= hashkit->list; count < hashkit->list_size;
|
55
|
+
count++, context+= hashkit->context_size)
|
56
|
+
{
|
57
|
+
if (hashkit->active_fn != NULL)
|
58
|
+
{
|
59
|
+
if (hashkit->active_fn(context))
|
60
|
+
live_servers++;
|
61
|
+
else
|
62
|
+
continue;
|
63
|
+
}
|
64
|
+
|
65
|
+
if (hashkit->weight_fn != NULL)
|
66
|
+
total_weight+= hashkit->weight_fn(context);
|
67
|
+
}
|
68
|
+
}
|
69
|
+
|
70
|
+
if (hashkit->active_fn == NULL)
|
71
|
+
live_servers= (uint32_t)hashkit->list_size;
|
72
|
+
|
73
|
+
if (live_servers == 0)
|
74
|
+
return 0;
|
75
|
+
|
76
|
+
if (hashkit->weight_fn == NULL)
|
77
|
+
{
|
78
|
+
points_per_server= HASHKIT_POINTS_PER_NODE;
|
79
|
+
points_per_hash= 1;
|
80
|
+
}
|
81
|
+
else
|
82
|
+
{
|
83
|
+
points_per_server= HASHKIT_POINTS_PER_NODE_WEIGHTED;
|
84
|
+
points_per_hash= 4;
|
85
|
+
}
|
86
|
+
|
87
|
+
if (live_servers > hashkit->continuum_count)
|
88
|
+
{
|
89
|
+
hashkit_continuum_point_st *new_continuum;
|
90
|
+
|
91
|
+
new_continuum= realloc(hashkit->continuum,
|
92
|
+
sizeof(hashkit_continuum_point_st) *
|
93
|
+
(live_servers + HASHKIT_CONTINUUM_ADDITION) *
|
94
|
+
points_per_server);
|
95
|
+
|
96
|
+
if (new_continuum == NULL)
|
97
|
+
return ENOMEM;
|
98
|
+
|
99
|
+
hashkit->continuum= new_continuum;
|
100
|
+
hashkit->continuum_count= live_servers + HASHKIT_CONTINUUM_ADDITION;
|
101
|
+
}
|
102
|
+
|
103
|
+
for (count= 0, context= hashkit->list; count < hashkit->list_size;
|
104
|
+
count++, context+= hashkit->context_size)
|
105
|
+
{
|
106
|
+
if (hashkit->active_fn != NULL && hashkit->active_fn(context) == false)
|
107
|
+
continue;
|
108
|
+
|
109
|
+
if (hashkit->weight_fn != NULL)
|
110
|
+
{
|
111
|
+
float pct = (float)hashkit->weight_fn(context) / (float)total_weight;
|
112
|
+
points_per_server= (uint32_t) ((floorf((float) (pct * HASHKIT_POINTS_PER_NODE_WEIGHTED / 4 * (float)live_servers + 0.0000000001))) * 4);
|
113
|
+
}
|
114
|
+
|
115
|
+
for (points_index= 0;
|
116
|
+
points_index < points_per_server / points_per_hash;
|
117
|
+
points_index++)
|
118
|
+
{
|
119
|
+
char sort_host[HASHKIT_CONTINUUM_KEY_SIZE]= "";
|
120
|
+
size_t sort_host_length;
|
121
|
+
|
122
|
+
if (hashkit->continuum_key_fn == NULL)
|
123
|
+
{
|
124
|
+
sort_host_length= (size_t) snprintf(sort_host, HASHKIT_CONTINUUM_KEY_SIZE, "%u",
|
125
|
+
points_index);
|
126
|
+
}
|
127
|
+
else
|
128
|
+
{
|
129
|
+
sort_host_length= hashkit->continuum_key_fn(sort_host, HASHKIT_CONTINUUM_KEY_SIZE,
|
130
|
+
points_index, context);
|
131
|
+
}
|
132
|
+
|
133
|
+
if (hashkit->weight_fn == NULL)
|
134
|
+
{
|
135
|
+
if (hashkit->continuum_hash_fn == NULL)
|
136
|
+
value= hashkit_default(sort_host, sort_host_length);
|
137
|
+
else
|
138
|
+
value= hashkit->continuum_hash_fn(sort_host, sort_host_length);
|
139
|
+
|
140
|
+
hashkit->continuum[continuum_index].index= count;
|
141
|
+
hashkit->continuum[continuum_index++].value= value;
|
142
|
+
}
|
143
|
+
else
|
144
|
+
{
|
145
|
+
unsigned int i;
|
146
|
+
for (i = 0; i < points_per_hash; i++)
|
147
|
+
{
|
148
|
+
value= ketama_server_hash(sort_host, (uint32_t) sort_host_length, (int) i);
|
149
|
+
hashkit->continuum[continuum_index].index= count;
|
150
|
+
hashkit->continuum[continuum_index++].value= value;
|
151
|
+
}
|
152
|
+
}
|
153
|
+
}
|
154
|
+
|
155
|
+
points_count+= points_per_server;
|
156
|
+
}
|
157
|
+
|
158
|
+
hashkit->continuum_points_count= points_count;
|
159
|
+
qsort(hashkit->continuum, hashkit->continuum_points_count, sizeof(hashkit_continuum_point_st),
|
160
|
+
continuum_points_cmp);
|
161
|
+
|
162
|
+
return 0;
|
163
|
+
}
|
164
|
+
#endif
|