Mercurial > hg > xemacs-beta
comparison src/elhash.h @ 0:376386a54a3c r19-14
Import from CVS: tag r19-14
author | cvs |
---|---|
date | Mon, 13 Aug 2007 08:45:50 +0200 |
parents | |
children | 8eaf7971accc |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:376386a54a3c |
---|---|
1 /* Lisp interface to hash tables -- include file. | |
2 Copyright (C) 1995, 1996 Ben Wing. | |
3 | |
4 This file is part of XEmacs. | |
5 | |
6 XEmacs is free software; you can redistribute it and/or modify it | |
7 under the terms of the GNU General Public License as published by the | |
8 Free Software Foundation; either version 2, or (at your option) any | |
9 later version. | |
10 | |
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
14 for more details. | |
15 | |
16 You should have received a copy of the GNU General Public License | |
17 along with XEmacs; see the file COPYING. If not, write to | |
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
19 Boston, MA 02111-1307, USA. */ | |
20 | |
21 /* Synched up with: Not in FSF. */ | |
22 | |
23 #ifndef _XEMACS_ELHASH_H_ | |
24 #define _XEMACS_ELHASH_H_ | |
25 | |
26 DECLARE_LRECORD (hashtable, struct hashtable_struct); | |
27 | |
28 #define XHASHTABLE(x) XRECORD (x, hashtable, struct hashtable_struct) | |
29 #define XSETHASHTABLE(x, p) XSETRECORD (x, p, hashtable) | |
30 #define HASHTABLEP(x) RECORDP (x, hashtable) | |
31 #define GC_HASHTABLEP(x) GC_RECORDP (x, hashtable) | |
32 #define CHECK_HASHTABLE(x) CHECK_RECORD (x, hashtable) | |
33 #define CONCHECK_HASHTABLE(x) CONCHECK_RECORD (x, hashtable) | |
34 | |
35 enum hashtable_type | |
36 { | |
37 HASHTABLE_NONWEAK, | |
38 HASHTABLE_KEY_WEAK, | |
39 HASHTABLE_VALUE_WEAK, | |
40 HASHTABLE_KEY_CAR_WEAK, | |
41 HASHTABLE_VALUE_CAR_WEAK, | |
42 HASHTABLE_WEAK | |
43 }; | |
44 | |
45 enum hashtable_test_fun | |
46 { | |
47 HASHTABLE_EQ, | |
48 HASHTABLE_EQL, | |
49 HASHTABLE_EQUAL | |
50 }; | |
51 | |
52 Lisp_Object Fmake_hashtable (Lisp_Object size, Lisp_Object test_fun); | |
53 Lisp_Object Fcopy_hashtable (Lisp_Object old_table); | |
54 Lisp_Object Fgethash (Lisp_Object obj, Lisp_Object table, | |
55 Lisp_Object defalt); | |
56 Lisp_Object Fputhash (Lisp_Object obj, Lisp_Object val, | |
57 Lisp_Object table); | |
58 Lisp_Object Fremhash (Lisp_Object obj, Lisp_Object table); | |
59 Lisp_Object Fhashtable_fullness (Lisp_Object table); | |
60 | |
61 Lisp_Object make_lisp_hashtable (int size, | |
62 enum hashtable_type type, | |
63 enum hashtable_test_fun test_fun); | |
64 | |
65 void elisp_maphash (void (*fn) (CONST void *key, void *contents, | |
66 void *extra_arg), | |
67 Lisp_Object table, | |
68 void *extra_arg); | |
69 | |
70 void elisp_map_remhash (int (*fn) (CONST void *key, | |
71 CONST void *contents, | |
72 void *extra_arg), | |
73 Lisp_Object table, | |
74 void *extra_arg); | |
75 | |
76 int finish_marking_weak_hashtables (int (*obj_marked_p) (Lisp_Object), | |
77 void (*markobj) (Lisp_Object)); | |
78 void prune_weak_hashtables (int (*obj_marked_p) (Lisp_Object)); | |
79 | |
80 char *elisp_hvector_malloc (unsigned int, Lisp_Object); | |
81 void elisp_hvector_free (void *ptr, Lisp_Object table); | |
82 | |
83 #endif /* _XEMACS_ELHASH_H_ */ |