/* * Revision Control Information * * /projects/hsis/CVS/utilities/st/st.h,v * serdar * 1.1 * 1993/07/29 01:00:21 * */ /* LINTLIBRARY */ /* /projects/hsis/CVS/utilities/st/st.h,v 1.1 1993/07/29 01:00:21 serdar Exp */ #ifndef ABC__misc__st__stmm_h #define ABC__misc__st__stmm_h #include "misc/util/abc_global.h" ABC_NAMESPACE_HEADER_START /* These are potential duplicates. */ #ifndef EXTERN # ifdef __cplusplus # ifdef ABC_NAMESPACE # define EXTERN extern # else # define EXTERN extern "C" # endif # else # define EXTERN extern # endif #endif #ifndef ARGS #define ARGS(protos) protos #endif typedef int (*stmm_compare_func_type)(const char*, const char*); typedef int (*stmm_hash_func_type)(const char*, int); typedef struct stmm_table_entry stmm_table_entry; typedef struct stmm_table stmm_table; typedef struct stmm_generator stmm_generator; struct stmm_table_entry { char *key; char *record; stmm_table_entry *next; }; struct stmm_table { stmm_compare_func_type compare; stmm_hash_func_type hash; int num_bins; int num_entries; int max_density; int reorder_flag; double grow_factor; stmm_table_entry **bins; // memory manager to improve runtime and prevent memory fragmentation // added by alanmi - January 16, 2003 void * pMemMan; }; struct stmm_generator { stmm_table *table; stmm_table_entry *entry; int index; }; #define stmm_is_member(table,key) stmm_lookup(table,key,(char **) 0) #define stmm_count(table) ((table)->num_entries) enum stmm_retval { STMM_CONTINUE, STMM_STOP, STMM_DELETE }; typedef enum stmm_retval (*STMM_PFSR) (char *, char *, char *); EXTERN stmm_table *stmm_init_table_with_params ARGS ((stmm_compare_func_type compare, stmm_hash_func_type hash, int size, int density, double grow_factor, int reorder_flag)); EXTERN stmm_table *stmm_init_table ARGS ((stmm_compare_func_type, stmm_hash_func_type)); EXTERN void stmm_free_table ARGS ((stmm_table *)); EXTERN int stmm_lookup ARGS ((stmm_table *, char *, char **)); EXTERN int stmm_lookup_int ARGS ((stmm_table *, char *, int *)); EXTERN int stmm_insert ARGS ((stmm_table *, char *, char *)); EXTERN int stmm_add_direct ARGS ((stmm_table *, char *, char *)); EXTERN int stmm_find_or_add ARGS ((stmm_table *, char *, char ***)); EXTERN int stmm_find ARGS ((stmm_table *, char *, char ***)); EXTERN stmm_table *stmm_copy ARGS ((stmm_table *)); EXTERN int stmm_delete ARGS ((stmm_table *, char **, char **)); EXTERN int stmm_delete_int ARGS ((stmm_table *, long *, char **)); EXTERN int stmm_foreach ARGS ((stmm_table *, STMM_PFSR, char *)); EXTERN int stmm_strhash ARGS ((const char *, int)); EXTERN int stmm_numhash ARGS ((const char *, int)); EXTERN int stmm_ptrhash ARGS ((const char *, int)); EXTERN int stmm_numcmp ARGS ((const char *, const char *)); EXTERN int stmm_ptrcmp ARGS ((const char *, const char *)); EXTERN stmm_generator *stmm_init_gen ARGS ((stmm_table *)); EXTERN int stmm_gen ARGS ((stmm_generator *, char **, char **)); EXTERN int stmm_gen_int ARGS ((stmm_generator *, char **, long *)); EXTERN void stmm_free_gen ARGS ((stmm_generator *)); // additional functions EXTERN void stmm_clean ARGS ((stmm_table *)); #define STMM_DEFAULT_MAX_DENSITY 5 #define STMM_DEFAULT_INIT_TABLE_SIZE 11 #define STMM_DEFAULT_GROW_FACTOR 2.0 #define STMM_DEFAULT_REORDER_FLAG 0 // added by Zhihong: no need for memory allocation #define stmm_foreach_item2(tb, /* stmm_generator */gen, key, value) \ for(gen.table=(tb), gen.entry=NULL, gen.index=0; \ stmm_gen(&(gen),key,value);) #define stmm_foreach_item(table, gen, key, value) \ for(gen=stmm_init_gen(table); stmm_gen(gen,key,value) || (stmm_free_gen(gen),0);) #define stmm_foreach_item_int(table, gen, key, value) \ for(gen=stmm_init_gen(table); stmm_gen_int(gen,key,value) || (stmm_free_gen(gen),0);) #define STMM_OUT_OF_MEM -10000 /* // consider adding these other other similar definitions #define st__table stmm_table #define st__insert stmm_insert #define st__delete stmm_delete #define st__lookup stmm_lookup #define st__init_table stmm_init_table #define st__free_table stmm_free_table */ ABC_NAMESPACE_HEADER_END #endif /* STMM_INCLUDED */