mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	 40ca06cb4b
			
		
	
	
		40ca06cb4b
		
	
	
	
	
		
			
			[ruby-dev:28988] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@10498 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
		
			
				
	
	
		
			72 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* This is a public domain general purpose hash table package written by Peter Moore @ UCB. */
 | |
| 
 | |
| /* @(#) st.h 5.1 89/12/14 */
 | |
| 
 | |
| #ifndef ST_INCLUDED
 | |
| 
 | |
| #define ST_INCLUDED
 | |
| 
 | |
| #if SIZEOF_LONG == SIZEOF_VOIDP
 | |
| typedef unsigned long st_data_t;
 | |
| #elif SIZEOF_LONG_LONG == SIZEOF_VOIDP
 | |
| typedef unsigned LONG_LONG st_data_t;
 | |
| #else
 | |
| # error ---->> st.c requires sizeof(void*) == sizeof(long) to be compiled. <<---
 | |
| -
 | |
| #endif
 | |
| #define ST_DATA_T_DEFINED
 | |
| 
 | |
| typedef struct st_table st_table;
 | |
| 
 | |
| struct st_hash_type {
 | |
|     int (*compare)();
 | |
|     int (*hash)();
 | |
| };
 | |
| 
 | |
| struct st_table {
 | |
|     struct st_hash_type *type;
 | |
|     int num_bins;
 | |
|     int num_entries;
 | |
|     struct st_table_entry **bins;
 | |
| };
 | |
| 
 | |
| #define st_is_member(table,key) st_lookup(table,key,(st_data_t *)0)
 | |
| 
 | |
| enum st_retval {ST_CONTINUE, ST_STOP, ST_DELETE, ST_CHECK};
 | |
| 
 | |
| #ifndef _
 | |
| # define _(args) args
 | |
| #endif
 | |
| #ifndef ANYARGS
 | |
| # ifdef __cplusplus
 | |
| #   define ANYARGS ...
 | |
| # else
 | |
| #   define ANYARGS
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| st_table *st_init_table _((struct st_hash_type *));
 | |
| st_table *st_init_table_with_size _((struct st_hash_type *, int));
 | |
| st_table *st_init_numtable _((void));
 | |
| st_table *st_init_numtable_with_size _((int));
 | |
| st_table *st_init_strtable _((void));
 | |
| st_table *st_init_strtable_with_size _((int));
 | |
| int st_delete _((st_table *, st_data_t *, st_data_t *));
 | |
| int st_delete_safe _((st_table *, st_data_t *, st_data_t *, st_data_t));
 | |
| int st_insert _((st_table *, st_data_t, st_data_t));
 | |
| int st_lookup _((st_table *, st_data_t, st_data_t *));
 | |
| int st_foreach _((st_table *, int (*)(ANYARGS), st_data_t));
 | |
| void st_add_direct _((st_table *, st_data_t, st_data_t));
 | |
| void st_free_table _((st_table *));
 | |
| void st_cleanup_safe _((st_table *, st_data_t));
 | |
| st_table *st_copy _((st_table *));
 | |
| 
 | |
| #define ST_NUMCMP	((int (*)()) 0)
 | |
| #define ST_NUMHASH	((int (*)()) -2)
 | |
| 
 | |
| #define st_numcmp	ST_NUMCMP
 | |
| #define st_numhash	ST_NUMHASH
 | |
| 
 | |
| int st_strhash();
 | |
| 
 | |
| #endif /* ST_INCLUDED */
 |