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