update changelog
[alioth/cvs.git] / src / hash.h
1 /*
2  * Copyright (C) 1986-2005 The Free Software Foundation, Inc.
3  *
4  * Portions Copyright (C) 1998-2005 Derek Price, Ximbiot <http://ximbiot.com>,
5  *                                  and others.
6  *
7  * Portions Copyright (C) 1992, Brian Berliner and Jeff Polk
8  * 
9  * You may distribute under the terms of the GNU General Public License as
10  * specified in the README file that comes with the CVS source distribution.
11  */
12
13 /*
14  * The number of buckets for the hash table contained in each list.  This
15  * should probably be prime.
16  */
17 #define HASHSIZE        151
18
19 /*
20  * Types of nodes
21  */
22 enum ntype
23 {
24     NT_UNKNOWN, HEADER, ENTRIES, FILES, LIST, RCSNODE,
25     RCSVERS, DIRS, UPDATE, LOCK, NDBMNODE, FILEATTR,
26     VARIABLE, RCSFIELD, RCSCMPFLD
27 };
28 typedef enum ntype Ntype;
29
30 struct node
31 {
32     Ntype type;
33     struct node *next;
34     struct node *prev;
35     struct node *hashnext;
36     struct node *hashprev;
37     char *key;
38     void *data;
39     void (*delproc) (struct node *);
40 };
41 typedef struct node Node;
42
43 struct list
44 {
45     Node *list;
46     Node *hasharray[HASHSIZE];
47     struct list *next;
48 };
49 typedef struct list List;
50
51 List *getlist (void);
52 Node *findnode (List *list, const char *key);
53 Node *findnode_fn (List *list, const char *key);
54 Node *getnode (void);
55 int insert_before (List *list, Node *marker, Node *p);
56 int addnode (List *list, Node *p);
57 int addnode_at_front (List *list, Node *p);
58 int walklist (List *list, int (*)(Node *n, void *closure), void *closure);
59 int list_isempty (List *list);
60 void removenode (Node *p);
61 void mergelists (List *dest, List **src);
62 void dellist (List **listp);
63 void delnode (Node *p);
64 void freenode (Node *p);
65 void sortlist (List *list, int (*)(const Node *, const Node *));
66 int fsortcmp (const Node *p, const Node *q);