File: st.h

package info (click to toggle)
xgraph 12.1-16
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 1,204 kB
  • sloc: ansic: 7,914; sh: 330; makefile: 36
file content (117 lines) | stat: -rw-r--r-- 2,517 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/* $Header$ */

#ifndef ST_INCLUDED
#define ST_INCLUDED

/* Function prototypes */
#ifdef __STDC__
#define ARGS(args)	args
#else
#define ARGS(args)	()
#endif

extern char st_pkg_name[];

/* Fatal error codes */
#define ST_NO_MEM	0
#define ST_BAD_RET	1
#define ST_BAD_GEN	2


typedef struct st_table_entry {
    char *key;
    char *record;
    struct st_table_entry *next;
}ST_TABLE_ENTRY;


typedef struct st_table {
    int (*compare)();
    int (*hash)();
    int num_bins;
    int num_entries;
    int max_density;
    int reorder_flag;
    double grow_factor;
    ST_TABLE_ENTRY **bins;
}ST_TABLE;


typedef struct st_generator {
    ST_TABLE *table;
    ST_TABLE_ENTRY *entry;
    int st_index;
}ST_GENERATOR;

#define st_is_member(table,key) st_lookup(table,key,(char **) 0)
#define st_count(table) ((table)->num_entries)

enum st_retval {ST_CONTINUE, ST_STOP, ST_DELETE};

extern ST_TABLE *st_init_table_with_params
  ARGS((int (*compare)(), int (*hash)(), int size, int density,
	double grow_factor, int reorder_flag));

extern ST_TABLE *st_init_table
  ARGS((int (*compare)(), int (*hash)()));

extern void st_free_table
  ARGS((ST_TABLE *table));

extern int st_lookup
  ARGS((ST_TABLE *table, char *key, char **value));

extern int st_insert
  ARGS((ST_TABLE *table, char *key, char *value));

extern void st_add_direct
  ARGS((ST_TABLE *table, char *key, char *value));

extern int st_find_or_add
  ARGS((ST_TABLE *table, char *key, char ***slot));

extern int st_find
  ARGS((ST_TABLE *table, char *key, char ***slot));

extern ST_TABLE *st_copy
  ARGS((ST_TABLE *old_table));

extern int st_delete
  ARGS((ST_TABLE *table, char **keyp, char **value));

extern int st_foreach
  ARGS((ST_TABLE *table, enum st_retval (*func)(), char *arg));

extern int st_strhash
  ARGS((char *string, int modulus));

extern int st_numhash
  ARGS((char *x, int size));

extern int st_ptrhash
  ARGS((char *x, int size));

extern int st_numcmp
  ARGS((char *x, char *y));

extern int st_ptrcmp
  ARGS((char *x, char *y));

extern ST_GENERATOR *st_init_gen
  ARGS((ST_TABLE *table));

extern int st_gen
  ARGS((ST_GENERATOR *gen, char **key_p, char **value_p));

extern void st_free_gen
  ARGS((ST_GENERATOR *gen));

#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_foreach_item(table, gen, key_p, value_p) \
    for(gen=st_init_gen(table); st_gen(gen,key_p,value_p) || (st_free_gen(gen),0);)

#endif /* ST_INCLUDED */