Sha256: 7cc8718c4ba03e4d50cac64dcb41de6f862eedefba3df6c4dee2355b3b9186c9

Contents?: true

Size: 1.52 KB

Versions: 27

Compression:

Stored size: 1.52 KB

Contents

/* By Paul Hsieh (C) 2004, 2005.  Covered under the Paul Hsieh
 * derivative license. 
 * See: http://www.azillionmonkeys.com/qed/weblicense.html for license
 * details.
 * http://www.azillionmonkeys.com/qed/hash.html
*/

#include "common.h"

#undef get16bits
#if (defined(__GNUC__) && defined(__i386__))
#define get16bits(d) (*((const uint16_t *) (d)))
#endif

#if !defined (get16bits)
#define get16bits(d) ((((uint32_t)(((const uint8_t *)(d))[1])) << 8)\
                      +(uint32_t)(((const uint8_t *)(d))[0]) )
#endif

uint32_t hsieh_hash(const char *key, size_t key_length)
{
  uint32_t hash = 0, tmp;
  int rem;

  if (key_length <= 0 || key == NULL)
    return 0;

  rem = key_length & 3;
  key_length >>= 2;

  /* Main loop */
  for (;key_length > 0; key_length--)
  {
    hash  += get16bits (key);
    tmp    = (get16bits (key+2) << 11) ^ hash;
    hash   = (hash << 16) ^ tmp;
    key  += 2*sizeof (uint16_t);
    hash  += hash >> 11;
  }

  /* Handle end cases */
  switch (rem)
  {
  case 3: hash += get16bits (key);
          hash ^= hash << 16;
          hash ^= key[sizeof (uint16_t)] << 18;
          hash += hash >> 11;
          break;
  case 2: hash += get16bits (key);
          hash ^= hash << 11;
          hash += hash >> 17;
          break;
  case 1: hash += *key;
          hash ^= hash << 10;
          hash += hash >> 1;
  }

  /* Force "avalanching" of final 127 bits */
  hash ^= hash << 3;
  hash += hash >> 5;
  hash ^= hash << 4;
  hash += hash >> 17;
  hash ^= hash << 25;
  hash += hash >> 6;

  return hash;
}

Version data entries

27 entries across 27 versions & 4 rubygems

Version Path
vinted-memcached-1.8.5 vendor/libmemcached-0.32/libmemcached/hsieh_hash.c
vinted-memcached-1.8.4 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
vinted-memcached-1.8.3 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
vinted-memcached-1.8.2 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
vinted-memcached-1.8.0 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
dalli_memcached-1.8.0 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.8.0 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.7.2 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.7.0 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.6.1 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.6.0 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.5.1 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.5.0 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
boourns-memcached-1.4.6 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.4.6 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.4.5 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.4.3 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.4.2 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.4.1 ext/libmemcached-0.32/libmemcached/hsieh_hash.c
memcached-1.3.7 ext/libmemcached-0.32/libmemcached/hsieh_hash.c