1/*
2Copyright (C) 1990, 2000, 2002 Free Software Foundation
3    written by Doug Lea <dl@rocky.oswego.edu>
4*/
5
6#include <hash.h>
7
8/*
9 Some useful hash function.
10 It's not a particularly good hash function (<< 5 would be better than << 4),
11 but people believe in it because it comes from Dragon book.
12*/
13
14unsigned int
15hashpjw (const unsigned char *x, unsigned int len) // From Dragon book, p436
16{
17  unsigned int h = 0;
18  unsigned int g;
19
20  for (; len > 0; len--)
21    {
22      h = (h << 4) + *x++;
23      if ((g = h & 0xf0000000) != 0)
24        h = (h ^ (g >> 24)) ^ g;
25    }
26  return h;
27}
28