You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							232 lines
						
					
					
						
							7.0 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							232 lines
						
					
					
						
							7.0 KiB
						
					
					
				
								/**CHeaderFile*****************************************************************
							 | 
						|
								
							 | 
						|
								  FileName    [st.h]
							 | 
						|
								
							 | 
						|
								  PackageName [st]
							 | 
						|
								
							 | 
						|
								  Synopsis    [Symbol table package.]
							 | 
						|
								
							 | 
						|
								  Description [The st library provides functions to create, maintain,
							 | 
						|
								  and query symbol tables.]
							 | 
						|
								
							 | 
						|
								  SeeAlso     []
							 | 
						|
								
							 | 
						|
								  Author      []
							 | 
						|
								
							 | 
						|
								  Copyright   []
							 | 
						|
								
							 | 
						|
								  Revision    [$Id: st.h,v 1.10 2004/01/02 07:40:31 fabio Exp fabio $]
							 | 
						|
								
							 | 
						|
								******************************************************************************/
							 | 
						|
								
							 | 
						|
								#ifndef ST_INCLUDED
							 | 
						|
								#define ST_INCLUDED
							 | 
						|
								
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								/* Nested includes                                                           */
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								
							 | 
						|
								#ifdef __cplusplus
							 | 
						|
								extern "C" {
							 | 
						|
								#endif
							 | 
						|
								
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								/* Constant declarations                                                     */
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								
							 | 
						|
								#define ST_DEFAULT_MAX_DENSITY 5
							 | 
						|
								#define ST_DEFAULT_INIT_TABLE_SIZE 11
							 | 
						|
								#define ST_DEFAULT_GROW_FACTOR 2.0
							 | 
						|
								#define ST_DEFAULT_REORDER_FLAG 0
							 | 
						|
								#define ST_OUT_OF_MEM -10000
							 | 
						|
								
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								/* Stucture declarations                                                     */
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								/* Type declarations                                                         */
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								
							 | 
						|
								typedef struct st_table_entry st_table_entry;
							 | 
						|
								struct st_table_entry {
							 | 
						|
								    char *key;
							 | 
						|
								    char *record;
							 | 
						|
								    st_table_entry *next;
							 | 
						|
								};
							 | 
						|
								
							 | 
						|
								typedef struct st_table st_table;
							 | 
						|
								struct st_table {
							 | 
						|
								    int (*compare)(const char *, const char *);
							 | 
						|
								    int (*hash)(char *, int);
							 | 
						|
								    int num_bins;
							 | 
						|
								    int num_entries;
							 | 
						|
								    int max_density;
							 | 
						|
								    int reorder_flag;
							 | 
						|
								    double grow_factor;
							 | 
						|
								    st_table_entry **bins;
							 | 
						|
								};
							 | 
						|
								
							 | 
						|
								typedef struct st_generator st_generator;
							 | 
						|
								struct st_generator {
							 | 
						|
								    st_table *table;
							 | 
						|
								    st_table_entry *entry;
							 | 
						|
								    int index;
							 | 
						|
								};
							 | 
						|
								
							 | 
						|
								enum st_retval {ST_CONTINUE, ST_STOP, ST_DELETE};
							 | 
						|
								
							 | 
						|
								typedef enum st_retval (*ST_PFSR)(char *, char *, char *);
							 | 
						|
								
							 | 
						|
								typedef int (*ST_PFICPCP)(const char *, const char *); /* type for comparison function */
							 | 
						|
								
							 | 
						|
								typedef int (*ST_PFICPI)(char *, int);     /* type for hash function */
							 | 
						|
								
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								/* Variable declarations                                                     */
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								/* Macro declarations                                                        */
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								
							 | 
						|
								/**Macro***********************************************************************
							 | 
						|
								
							 | 
						|
								  Synopsis    [Checks whethere `key' is in `table'.]
							 | 
						|
								
							 | 
						|
								  Description [Returns 1 if there is an entry under `key' in `table', 0
							 | 
						|
								  otherwise.]
							 | 
						|
								
							 | 
						|
								  SideEffects [None]
							 | 
						|
								
							 | 
						|
								  SeeAlso     [st_lookup]
							 | 
						|
								
							 | 
						|
								******************************************************************************/
							 | 
						|
								#define st_is_member(table,key) st_lookup(table,key,(char **) 0)
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								/**Macro***********************************************************************
							 | 
						|
								
							 | 
						|
								  Synopsis    [Returns the number of entries in the table `table'.]
							 | 
						|
								
							 | 
						|
								  Description [Returns the number of entries in the table `table'.]
							 | 
						|
								
							 | 
						|
								  SideEffects [None]
							 | 
						|
								
							 | 
						|
								  SeeAlso     []
							 | 
						|
								
							 | 
						|
								******************************************************************************/
							 | 
						|
								#define st_count(table) ((table)->num_entries)
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								/**Macro***********************************************************************
							 | 
						|
								
							 | 
						|
								  Synopsis    [Iteration macro.]
							 | 
						|
								
							 | 
						|
								  Description [An iteration macro which loops over all the entries in
							 | 
						|
								  `table', setting `key' to point to the key and `value' to the
							 | 
						|
								  associated value (if it is not nil). `gen' is a generator variable
							 | 
						|
								  used internally. Sample usage:
							 | 
						|
								  <pre>
							 | 
						|
								     	char *key, *value;
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
									st_generator *gen;
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
								
							 | 
						|
									st_foreach_item(table, gen, &key, &value) {
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
									    process_item(value);
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
									}
							 | 
						|
								  </pre>
							 | 
						|
								  ]
							 | 
						|
								
							 | 
						|
								  SideEffects [None]
							 | 
						|
								
							 | 
						|
								  SeeAlso     [st_foreach_item_int st_foreach]
							 | 
						|
								
							 | 
						|
								******************************************************************************/
							 | 
						|
								#define st_foreach_item(table, gen, key, value) \
							 | 
						|
								    for(gen=st_init_gen(table); st_gen(gen,key,value) || (st_free_gen(gen),0);)
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								/**Macro***********************************************************************
							 | 
						|
								
							 | 
						|
								  Synopsis    [Iteration macro.]
							 | 
						|
								
							 | 
						|
								  Description [An iteration macro which loops over all the entries in
							 | 
						|
								  `table', setting `key' to point to the key and `value' to the
							 | 
						|
								  associated value (if it is not nil). `value' is assumed to be a
							 | 
						|
								  pointer to an integer.  `gen' is a generator variable used
							 | 
						|
								  internally. Sample usage:
							 | 
						|
								  <pre>
							 | 
						|
								     	char *key;
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
									int value;
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
									st_generator *gen;
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
								
							 | 
						|
									st_foreach_item_int(table, gen, &key, &value) {
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
									    process_item(value);
							 | 
						|
								  </pre>
							 | 
						|
								  <pre>
							 | 
						|
									}
							 | 
						|
								  </pre>
							 | 
						|
								  ]
							 | 
						|
								
							 | 
						|
								  SideEffects [None]
							 | 
						|
								
							 | 
						|
								  SeeAlso     [st_foreach_item st_foreach]
							 | 
						|
								
							 | 
						|
								******************************************************************************/
							 | 
						|
								#define st_foreach_item_int(table, gen, key, value) \
							 | 
						|
								    for(gen=st_init_gen(table); st_gen_int(gen,key,value) || (st_free_gen(gen),0);)
							 | 
						|
								
							 | 
						|
								/**AutomaticStart*************************************************************/
							 | 
						|
								
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								/* Function prototypes                                                       */
							 | 
						|
								/*---------------------------------------------------------------------------*/
							 | 
						|
								
							 | 
						|
								extern st_table *st_init_table_with_params (ST_PFICPCP, ST_PFICPI, int, int, double, int);
							 | 
						|
								extern st_table *st_init_table (ST_PFICPCP, ST_PFICPI); 
							 | 
						|
								extern void st_free_table (st_table *);
							 | 
						|
								extern int st_lookup (st_table *, void *, void *);
							 | 
						|
								extern int st_lookup_int (st_table *, void *, int *);
							 | 
						|
								extern int st_insert (st_table *, void *, void *);
							 | 
						|
								extern int st_add_direct (st_table *, void *, void *);
							 | 
						|
								extern int st_find_or_add (st_table *, void *, void *);
							 | 
						|
								extern int st_find (st_table *, void *, void *);
							 | 
						|
								extern st_table *st_copy (st_table *);
							 | 
						|
								extern int st_delete (st_table *, void *, void *);
							 | 
						|
								extern int st_delete_int (st_table *, void *, int *);
							 | 
						|
								extern int st_foreach (st_table *, ST_PFSR, char *);
							 | 
						|
								extern int st_strhash (char *, int);
							 | 
						|
								extern int st_numhash (char *, int);
							 | 
						|
								extern int st_ptrhash (char *, int);
							 | 
						|
								extern int st_numcmp (const char *, const char *);
							 | 
						|
								extern int st_ptrcmp (const char *, const char *);
							 | 
						|
								extern st_generator *st_init_gen (st_table *);
							 | 
						|
								extern int st_gen (st_generator *, void *, void *);
							 | 
						|
								extern int st_gen_int (st_generator *, void *, int *);
							 | 
						|
								extern void st_free_gen (st_generator *);
							 | 
						|
								
							 | 
						|
								/**AutomaticEnd***************************************************************/
							 | 
						|
								
							 | 
						|
								#ifdef __cplusplus
							 | 
						|
								} /* end of extern "C" */
							 | 
						|
								#endif
							 | 
						|
								
							 | 
						|
								#endif /* ST_INCLUDED */
							 |