xref: /onnv-gate/usr/src/lib/libast/sparcv9/include/ast/hash.h (revision 12068:08a39a083754)
14887Schin 
24887Schin /* : : generated by proto : : */
34887Schin /***********************************************************************
44887Schin *                                                                      *
54887Schin *               This software is part of the ast package               *
6*12068SRoger.Faulkner@Oracle.COM *          Copyright (c) 1985-2010 AT&T Intellectual Property          *
74887Schin *                      and is licensed under the                       *
84887Schin *                  Common Public License, Version 1.0                  *
98462SApril.Chin@Sun.COM *                    by AT&T Intellectual Property                     *
104887Schin *                                                                      *
114887Schin *                A copy of the License is available at                 *
124887Schin *            http://www.opensource.org/licenses/cpl1.0.txt             *
134887Schin *         (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9)         *
144887Schin *                                                                      *
154887Schin *              Information and Software Systems Research               *
164887Schin *                            AT&T Research                             *
174887Schin *                           Florham Park NJ                            *
184887Schin *                                                                      *
194887Schin *                 Glenn Fowler <gsf@research.att.com>                  *
204887Schin *                  David Korn <dgk@research.att.com>                   *
214887Schin *                   Phong Vo <kpv@research.att.com>                    *
224887Schin *                                                                      *
234887Schin ***********************************************************************/
244887Schin 
254887Schin /*
264887Schin  * Glenn Fowler
274887Schin  * AT&T Research
284887Schin  *
294887Schin  * hash table library interface definitions
304887Schin  *
314887Schin  * NOTE: new code should use the more general <cdt.h>
324887Schin  */
334887Schin 
344887Schin #ifndef _HASH_H
354887Schin #if !defined(__PROTO__)
364887Schin #include <prototyped.h>
374887Schin #endif
384887Schin #if !defined(__LINKAGE__)
394887Schin #define __LINKAGE__		/* 2004-08-11 transition */
404887Schin #endif
414887Schin 
424887Schin #define _HASH_H
434887Schin 
444887Schin #define HASH_ALLOCATE	(1L<<0)		/* allocate new key names	*/
454887Schin #define HASH_FIXED	(1L<<1)		/* fixed table size		*/
464887Schin #define HASH_HASHED	(1L<<6)		/* key names already hashed	*/
474887Schin #define HASH_RESIZE	(1L<<2)		/* table has been resized	*/
484887Schin #define HASH_SCANNING	(1L<<3)		/* currently scanning scope	*/
494887Schin #define HASH_SCOPE	(1L<<4)		/* push scope / create in bot	*/
504887Schin #define HASH_STATIC	(1L<<5)		/* static table allocation	*/
514887Schin 
524887Schin #define HASH_CREATE	(1L<<8)		/* create bucket if not found	*/
534887Schin #define HASH_DELETE	(1L<<9)		/* delete bucket if found	*/
544887Schin #define HASH_LOOKUP	0		/* default op			*/
554887Schin #define HASH_RENAME	(1L<<7)		/* rename bucket if found	*/
564887Schin 
574887Schin #define HASH_BUCKET	(1L<<11)	/* name is installed bucket	*/
584887Schin #define HASH_INSTALL	(1L<<12)	/* install allocated bucket	*/
594887Schin #define HASH_NOSCOPE	(1L<<13)	/* top scope only		*/
604887Schin #define HASH_OPAQUE	(1L<<14)	/* opaque bucket		*/
614887Schin #define HASH_VALUE	(1L<<15)	/* value bucket field used	*/
624887Schin 
634887Schin #define HASH_SIZE(n)	(((long)(n))<<16)  /* fixed bucket size		*/
644887Schin #define HASH_SIZEOF(f)	((((long)(f))>>16)&0xffff) /* extract size	*/
654887Schin 
664887Schin #define HASH_DELETED	((unsigned long)1<<(8*sizeof(int)-1)) /* deleted placeholder	*/
674887Schin #define HASH_KEEP	(1L<<(8*sizeof(int)-2))	/* no free on bucket	*/
684887Schin #define HASH_HIDDEN	(1L<<(8*sizeof(int)-3))	/* hidden by scope	*/
694887Schin #define HASH_HIDES	(1L<<(8*sizeof(int)-4))	/* hides lower scope	*/
704887Schin #define HASH_OPAQUED	(1L<<(8*sizeof(int)-5))	/* opaqued placeholder	*/
714887Schin #define HASH_FREENAME	(1L<<(8*sizeof(int)-6))	/* free bucket name	*/
724887Schin 
734887Schin #define HASH_RESET	(HASH_RESIZE|HASH_SCOPE|HASH_STATIC|HASH_VALUE)
744887Schin #define HASH_INTERNAL	(HASH_BUCKET|HASH_RESIZE|HASH_SCANNING|HASH_STATIC)
754887Schin #define HASH_FLAGS	(HASH_DELETED|HASH_FREENAME|HASH_HIDDEN|HASH_HIDES|HASH_KEEP|HASH_OPAQUED)
764887Schin 
774887Schin #define HASH_alloc		1
784887Schin #define HASH_clear		2
794887Schin #define HASH_compare		3
804887Schin #define HASH_free		4
814887Schin #define HASH_hash		5
824887Schin #define HASH_meanchain		6
834887Schin #define HASH_name		7
844887Schin #define HASH_namesize		8
854887Schin #define HASH_set		9
864887Schin #define HASH_size		10
874887Schin #define HASH_table		11
884887Schin #define HASH_va_list		12
894887Schin 
904887Schin #define HASH_bucketsize		13
914887Schin 
924887Schin #define HASH_region		14
934887Schin 
944887Schin #include <hashpart.h>
954887Schin 
964887Schin #define hashclear(t,f)		((t)->flags &= ~((f) & ~HASH_INTERNAL))
974887Schin #define hashcover(b)		(((b)->hash&HASH_HIDES)?(Hash_bucket_t*)((b)->name):(Hash_bucket_t*)0)
984887Schin #define hashdel(t,n)		hashlook(t, (char*)(n), HASH_DELETE, (char*)0)
994887Schin #define hashget(t,n)		hashlook(t, (char*)(n), HASH_LOOKUP|HASH_VALUE, (char*)0)
1004887Schin #define hashgetbucket(s)	((Hash_bucket_t*)((s)-((sizeof(Hash_bucket_t)+sizeof(char*)-1)/sizeof(char*))*sizeof(char*)))
1014887Schin #define hashkeep(b)		((b)->hash|=HASH_KEEP)
1024887Schin #define hashname(b)		((((b)->hash&HASH_HIDES)?((Hash_bucket_t*)((b)->name)):(b))->name)
1034887Schin #define hashput(t,n,v)		hashlook(t, (char*)(n), HASH_CREATE|HASH_VALUE, (char*)(v))
1044887Schin #define hashref(t,n)		hashlook(t, (char*)(n), HASH_LOOKUP|HASH_INTERNAL|HASH_VALUE, (char*)0)
1054887Schin #define hashscope(t)		((t)->scope)
1064887Schin #define hashset(t,f)		((t)->flags |= ((f) & ~HASH_INTERNAL))
1074887Schin 
1084887Schin /*
1094887Schin  * DEPRECATED renames for compatibility
1104887Schin  */
1114887Schin 
1124887Schin #define Hashbin_t		Hash_bucket_t
1134887Schin #define HASHBUCKET		Hash_bucket_t
1144887Schin #define Hashhdr_t 		Hash_header_t
1154887Schin #define HASHHEADER 		Hash_header_t
1164887Schin #define Hashpos_t 		Hash_position_t
1174887Schin #define HASHPOSITION 		Hash_position_t
1184887Schin #define Hashtab_t		Hash_table_t
1194887Schin #define HASHTABLE		Hash_table_t
1204887Schin 
1214887Schin #define vhashalloc		hashvalloc
1224887Schin #define hashvalloc(t,a)		hashalloc(t,HASH_va_list,a,0)
1234887Schin 
1244887Schin /*
1254887Schin  * the #define's avoid union tags
1264887Schin  */
1274887Schin 
1284887Schin typedef struct Hash_bucket Hash_bucket_t;
1294887Schin typedef struct Hash_root Hash_root_t;
1304887Schin typedef struct Hash_table Hash_table_t;
1314887Schin 
1324887Schin #define HASH_HEADER			/* common bucket header		*/ \
1334887Schin 	Hash_bucket_t*	next;		/* next in collision chain	*/ \
1344887Schin 	unsigned int	hash;		/* hash flags and value		*/ \
1354887Schin 	char*		name		/* key name			*/
1364887Schin 
1374887Schin #define HASH_DEFAULT			/* HASH_VALUE bucket elements	*/ \
1384887Schin 	char*		value		/* key value			*/
1394887Schin 
1404887Schin typedef struct				/* bucket header		*/
1414887Schin {
1424887Schin 	HASH_HEADER;
1434887Schin } Hash_header_t;
1444887Schin 
1454887Schin struct Hash_bucket			/* prototype bucket		*/
1464887Schin {
1474887Schin 	HASH_HEADER;
1484887Schin 	HASH_DEFAULT;
1494887Schin };
1504887Schin 
1514887Schin typedef struct				/* hash scan bucket position	*/
1524887Schin {
1534887Schin 	Hash_bucket_t*	bucket;		/* bucket			*/
1544887Schin #ifdef _HASH_POSITION_PRIVATE_
1554887Schin 	_HASH_POSITION_PRIVATE_
1564887Schin #endif
1574887Schin } Hash_position_t;
1584887Schin 
1594887Schin typedef struct				/* last lookup cache		*/
1604887Schin {
1614887Schin 	Hash_table_t*	table;		/* last lookup table		*/
1624887Schin 	Hash_bucket_t*	bucket;		/* last lookup bucket		*/
1634887Schin #ifdef _HASH_LAST_PRIVATE_
1644887Schin 	_HASH_LAST_PRIVATE_
1654887Schin #endif
1664887Schin } Hash_last_t;
1674887Schin 
1684887Schin struct Hash_root			/* root hash table information	*/
1694887Schin {
1704887Schin 	int		accesses;	/* number of accesses		*/
1714887Schin 	int		collisions;	/* number of collisions		*/
1724887Schin 	int		flags;		/* flags: see HASH_[A-Z]*	*/
1734887Schin 	Hash_last_t	last;		/* last lookup cache		*/
1744887Schin 	__V_*		context;	/* user defined context		*/
1754887Schin #ifdef _HASH_ROOT_PRIVATE_
1764887Schin 	_HASH_ROOT_PRIVATE_
1774887Schin #endif
1784887Schin };
1794887Schin 
1804887Schin struct Hash_table			/* hash table information	*/
1814887Schin {
1824887Schin 	Hash_root_t*	root;		/* root hash table information	*/
1834887Schin 	int		size;		/* table size			*/
1844887Schin 	int		buckets;	/* active bucket count		*/
1854887Schin 	char*		name;		/* table name			*/
1864887Schin 	Hash_table_t*	scope;		/* scope covered table		*/
1874887Schin 	short		flags;		/* flags: see HASH_[A-Z]*	*/
1884887Schin #ifdef _HASH_TABLE_PRIVATE_
1894887Schin 	_HASH_TABLE_PRIVATE_
1904887Schin #endif
1914887Schin };
1924887Schin 
1934887Schin #if _BLD_ast && defined(__EXPORT__)
1944887Schin #undef __MANGLE__
1954887Schin #define __MANGLE__ __LINKAGE__		__EXPORT__
1964887Schin #endif
1974887Schin 
1984887Schin extern __MANGLE__ Hash_table_t*	hashalloc __PROTO__((Hash_table_t*, ...));
1994887Schin extern __MANGLE__ void		hashdone __PROTO__((Hash_position_t*));
2004887Schin extern __MANGLE__ void		hashdump __PROTO__((Hash_table_t*, int));
2014887Schin extern __MANGLE__ Hash_table_t*	hashfree __PROTO__((Hash_table_t*));
2024887Schin extern __MANGLE__ Hash_bucket_t*	hashlast __PROTO__((Hash_table_t*));
2034887Schin extern __MANGLE__ char*		hashlook __PROTO__((Hash_table_t*, const char*, long, const char*));
2044887Schin extern __MANGLE__ Hash_bucket_t*	hashnext __PROTO__((Hash_position_t*));
2054887Schin extern __MANGLE__ Hash_position_t*	hashscan __PROTO__((Hash_table_t*, int));
2064887Schin extern __MANGLE__ void		hashsize __PROTO__((Hash_table_t*, int));
2074887Schin extern __MANGLE__ Hash_table_t*	hashview __PROTO__((Hash_table_t*, Hash_table_t*));
2084887Schin extern __MANGLE__ int		hashwalk __PROTO__((Hash_table_t*, int, int (*)(const char*, char*, __V_*), __V_*));
2094887Schin 
2104887Schin #undef __MANGLE__
2114887Schin #define __MANGLE__ __LINKAGE__
2124887Schin 
2134887Schin #endif
214