1da2e3ebdSchin /***********************************************************************
2da2e3ebdSchin *                                                                      *
3da2e3ebdSchin *               This software is part of the ast package               *
4*b30d1939SAndy Fiddaman *          Copyright (c) 1985-2012 AT&T Intellectual Property          *
5da2e3ebdSchin *                      and is licensed under the                       *
6*b30d1939SAndy Fiddaman *                 Eclipse Public License, Version 1.0                  *
77c2fbfb3SApril Chin *                    by AT&T Intellectual Property                     *
8da2e3ebdSchin *                                                                      *
9da2e3ebdSchin *                A copy of the License is available at                 *
10*b30d1939SAndy Fiddaman *          http://www.eclipse.org/org/documents/epl-v10.html           *
11*b30d1939SAndy Fiddaman *         (with md5 checksum b35adb5213ca9657e911e9befb180842)         *
12da2e3ebdSchin *                                                                      *
13da2e3ebdSchin *              Information and Software Systems Research               *
14da2e3ebdSchin *                            AT&T Research                             *
15da2e3ebdSchin *                           Florham Park NJ                            *
16da2e3ebdSchin *                                                                      *
17da2e3ebdSchin *                 Glenn Fowler <gsf@research.att.com>                  *
18da2e3ebdSchin *                  David Korn <dgk@research.att.com>                   *
19da2e3ebdSchin *                   Phong Vo <kpv@research.att.com>                    *
20da2e3ebdSchin *                                                                      *
21da2e3ebdSchin ***********************************************************************/
22da2e3ebdSchin /*
23da2e3ebdSchin  * Glenn Fowler
24da2e3ebdSchin  * AT&T Research
25da2e3ebdSchin  *
26da2e3ebdSchin  * 1-6 char lower-case keyword -> long hash
27da2e3ebdSchin  * digit args passed as HASHKEYN('2')
28da2e3ebdSchin  */
29da2e3ebdSchin 
30da2e3ebdSchin #ifndef _HASHKEY_H
31*b30d1939SAndy Fiddaman #define _HASHKEY_H			1
32da2e3ebdSchin 
33da2e3ebdSchin #define HASHKEYMAX			6
34da2e3ebdSchin #define HASHKEYBIT			5
35da2e3ebdSchin #define HASHKEYOFF			('a'-1)
36da2e3ebdSchin #define HASHKEYPART(h,c)		(((h)<<HASHKEYBIT)+HASHKEY1(c))
37da2e3ebdSchin 
38da2e3ebdSchin #define HASHKEYN(n)			((n)-'0'+'z'+1)
39da2e3ebdSchin 
40da2e3ebdSchin #define HASHKEY1(c1)			((c1)-HASHKEYOFF)
41da2e3ebdSchin #define HASHKEY2(c1,c2)			HASHKEYPART(HASHKEY1(c1),c2)
42da2e3ebdSchin #define HASHKEY3(c1,c2,c3)		HASHKEYPART(HASHKEY2(c1,c2),c3)
43da2e3ebdSchin #define HASHKEY4(c1,c2,c3,c4)		HASHKEYPART(HASHKEY3(c1,c2,c3),c4)
44da2e3ebdSchin #define HASHKEY5(c1,c2,c3,c4,c5)	HASHKEYPART(HASHKEY4(c1,c2,c3,c4),c5)
45da2e3ebdSchin #define HASHKEY6(c1,c2,c3,c4,c5,c6)	HASHKEYPART(HASHKEY5(c1,c2,c3,c4,c5),c6)
46da2e3ebdSchin 
47da2e3ebdSchin #define HASHNKEY1(n,c1)			HASHKEY2((n)+HASHKEYOFF,c1)
48da2e3ebdSchin #define HASHNKEY2(n,c2,c1)		HASHKEY3((n)+HASHKEYOFF,c2,c1)
49da2e3ebdSchin #define HASHNKEY3(n,c3,c2,c1)		HASHKEY4((n)+HASHKEYOFF,c3,c2,c1)
50da2e3ebdSchin #define HASHNKEY4(n,c4,c3,c2,c1)	HASHKEY5((n)+'a',c4,c3,c2,c1)
51da2e3ebdSchin #define HASHNKEY5(n,c5,c4,c3,c2,c1)	HASHKEY6((n)+'a',c5,c4,c3,c2,c1)
52da2e3ebdSchin 
53da2e3ebdSchin #if _BLD_ast && defined(__EXPORT__)
54da2e3ebdSchin #define extern		__EXPORT__
55da2e3ebdSchin #endif
56da2e3ebdSchin 
57da2e3ebdSchin extern long	strkey(const char*);
58da2e3ebdSchin 
59da2e3ebdSchin #undef	extern
60da2e3ebdSchin 
61da2e3ebdSchin #endif
62