source: main/branches/64_bit_Greenstone/greenstone2/common-src/indexers/mgpp/text/hash.h@ 23508

Last change on this file since 23508 was 23508, checked in by sjm84, 13 years ago

Committing 64 bit changes into the branch

  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 1.3 KB
Line 
1/**************************************************************************
2 *
3 * hash.h -- Hash function
4 * Copyright (C) 1994 Neil Sharman
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 *
20 **************************************************************************/
21
22#ifndef H_HASH
23#define H_HASH
24
25#define HASH(h, step, wd, tablesize) \
26 do { \
27 register u_char *p=wd; \
28 register mg_s_long len = *p++; \
29 register mg_u_long hval; \
30 if (len>25) len = 25; \
31 for (hval=0; len; --len) \
32 hval = (hval << 5) - hval + *p++; \
33 step = hval % (tablesize - 2) + 1; \
34 h = hval % tablesize; \
35 } while (0)
36
37
38
39#endif
Note: See TracBrowser for help on using the repository browser.