Blame gnulib-tests/hash-pjw.c

Packit 33f14e
/* hash-pjw.c -- compute a hash value from a NUL-terminated string.
Packit 33f14e
Packit 33f14e
   Copyright (C) 2001, 2003, 2006, 2009-2017 Free Software Foundation, Inc.
Packit 33f14e
Packit 33f14e
   This program is free software: you can redistribute it and/or modify
Packit 33f14e
   it under the terms of the GNU General Public License as published by
Packit 33f14e
   the Free Software Foundation; either version 3 of the License, or
Packit 33f14e
   (at your option) any later version.
Packit 33f14e
Packit 33f14e
   This program is distributed in the hope that it will be useful,
Packit 33f14e
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 33f14e
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 33f14e
   GNU General Public License for more details.
Packit 33f14e
Packit 33f14e
   You should have received a copy of the GNU General Public License
Packit 33f14e
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit 33f14e
Packit 33f14e
#include <config.h>
Packit 33f14e
Packit 33f14e
#include "hash-pjw.h"
Packit 33f14e
Packit 33f14e
#include <limits.h>
Packit 33f14e
Packit 33f14e
#define SIZE_BITS (sizeof (size_t) * CHAR_BIT)
Packit 33f14e
Packit 33f14e
/* A hash function for NUL-terminated char* strings using
Packit 33f14e
   the method described by Bruno Haible.
Packit 33f14e
   See http://www.haible.de/bruno/hashfunc.html.  */
Packit 33f14e
Packit 33f14e
size_t
Packit 33f14e
hash_pjw (const void *x, size_t tablesize)
Packit 33f14e
{
Packit 33f14e
  const char *s;
Packit 33f14e
  size_t h = 0;
Packit 33f14e
Packit 33f14e
  for (s = x; *s; s++)
Packit 33f14e
    h = *s + ((h << 9) | (h >> (SIZE_BITS - 9)));
Packit 33f14e
Packit 33f14e
  return h % tablesize;
Packit 33f14e
}