Blame gnulib-tests/hash-pjw.c

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