1da0c48c4Sopenharmony_ci/* Copyright (C) 2000-2010 Red Hat, Inc.
2da0c48c4Sopenharmony_ci   This file is part of elfutils.
3da0c48c4Sopenharmony_ci   Written by Ulrich Drepper <drepper@redhat.com>, 2000.
4da0c48c4Sopenharmony_ci
5da0c48c4Sopenharmony_ci   This file is free software; you can redistribute it and/or modify
6da0c48c4Sopenharmony_ci   it under the terms of either
7da0c48c4Sopenharmony_ci
8da0c48c4Sopenharmony_ci     * the GNU Lesser General Public License as published by the Free
9da0c48c4Sopenharmony_ci       Software Foundation; either version 3 of the License, or (at
10da0c48c4Sopenharmony_ci       your option) any later version
11da0c48c4Sopenharmony_ci
12da0c48c4Sopenharmony_ci   or
13da0c48c4Sopenharmony_ci
14da0c48c4Sopenharmony_ci     * the GNU General Public License as published by the Free
15da0c48c4Sopenharmony_ci       Software Foundation; either version 2 of the License, or (at
16da0c48c4Sopenharmony_ci       your option) any later version
17da0c48c4Sopenharmony_ci
18da0c48c4Sopenharmony_ci   or both in parallel, as here.
19da0c48c4Sopenharmony_ci
20da0c48c4Sopenharmony_ci   elfutils is distributed in the hope that it will be useful, but
21da0c48c4Sopenharmony_ci   WITHOUT ANY WARRANTY; without even the implied warranty of
22da0c48c4Sopenharmony_ci   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
23da0c48c4Sopenharmony_ci   General Public License for more details.
24da0c48c4Sopenharmony_ci
25da0c48c4Sopenharmony_ci   You should have received copies of the GNU General Public License and
26da0c48c4Sopenharmony_ci   the GNU Lesser General Public License along with this program.  If
27da0c48c4Sopenharmony_ci   not, see <http://www.gnu.org/licenses/>.  */
28da0c48c4Sopenharmony_ci
29da0c48c4Sopenharmony_ci#include <stddef.h>
30da0c48c4Sopenharmony_ci
31da0c48c4Sopenharmony_ci/* Before including this file the following macros must be defined:
32da0c48c4Sopenharmony_ci
33da0c48c4Sopenharmony_ci   NAME      name of the hash table structure.
34da0c48c4Sopenharmony_ci   TYPE      data type of the hash table entries
35da0c48c4Sopenharmony_ci
36da0c48c4Sopenharmony_ci   The following macros if present select features:
37da0c48c4Sopenharmony_ci
38da0c48c4Sopenharmony_ci   ITERATE   iterating over the table entries is possible
39da0c48c4Sopenharmony_ci   HASHTYPE  integer type for hash values, default unsigned long int
40da0c48c4Sopenharmony_ci */
41da0c48c4Sopenharmony_ci
42da0c48c4Sopenharmony_ci
43da0c48c4Sopenharmony_ci/* Optionally include an entry pointing to the first used entry.  */
44da0c48c4Sopenharmony_ci#ifdef ITERATE
45da0c48c4Sopenharmony_ci# define FIRST(name)	name##_ent *first;
46da0c48c4Sopenharmony_ci# define NEXT(name)	struct name##_ent *next;
47da0c48c4Sopenharmony_ci#else
48da0c48c4Sopenharmony_ci# define FIRST(name)
49da0c48c4Sopenharmony_ci# define NEXT(name)
50da0c48c4Sopenharmony_ci#endif
51da0c48c4Sopenharmony_ci
52da0c48c4Sopenharmony_ci#ifndef HASHTYPE
53da0c48c4Sopenharmony_ci# define HASHTYPE unsigned long int
54da0c48c4Sopenharmony_ci#endif
55da0c48c4Sopenharmony_ci
56da0c48c4Sopenharmony_ci
57da0c48c4Sopenharmony_ci/* Defined separately.  */
58da0c48c4Sopenharmony_ciextern size_t next_prime (size_t seed);
59da0c48c4Sopenharmony_ci
60da0c48c4Sopenharmony_ci
61da0c48c4Sopenharmony_ci/* Table entry type.  */
62da0c48c4Sopenharmony_ci#define _DYNHASHENTTYPE(name) \
63da0c48c4Sopenharmony_ci  typedef struct name##_ent						      \
64da0c48c4Sopenharmony_ci  {									      \
65da0c48c4Sopenharmony_ci    HASHTYPE hashval;							      \
66da0c48c4Sopenharmony_ci    TYPE data;								      \
67da0c48c4Sopenharmony_ci    NEXT (name)								      \
68da0c48c4Sopenharmony_ci  } name##_ent
69da0c48c4Sopenharmony_ci#define DYNHASHENTTYPE(name) _DYNHASHENTTYPE (name)
70da0c48c4Sopenharmony_ciDYNHASHENTTYPE (NAME);
71da0c48c4Sopenharmony_ci
72da0c48c4Sopenharmony_ci
73da0c48c4Sopenharmony_ci/* Type of the dynamic hash table data structure.  */
74da0c48c4Sopenharmony_ci#define _DYNHASHTYPE(name) \
75da0c48c4Sopenharmony_citypedef struct								      \
76da0c48c4Sopenharmony_ci{									      \
77da0c48c4Sopenharmony_ci  size_t size;								      \
78da0c48c4Sopenharmony_ci  size_t filled;							      \
79da0c48c4Sopenharmony_ci  name##_ent *table;							      \
80da0c48c4Sopenharmony_ci  FIRST	(name)								      \
81da0c48c4Sopenharmony_ci} name
82da0c48c4Sopenharmony_ci#define DYNHASHTYPE(name) _DYNHASHTYPE (name)
83da0c48c4Sopenharmony_ciDYNHASHTYPE (NAME);
84da0c48c4Sopenharmony_ci
85da0c48c4Sopenharmony_ci
86da0c48c4Sopenharmony_ci
87da0c48c4Sopenharmony_ci#define _FUNCTIONS(name) \
88da0c48c4Sopenharmony_ci/* Initialize the hash table.  */					      \
89da0c48c4Sopenharmony_ciextern int name##_init (name *htab, size_t init_size);			      \
90da0c48c4Sopenharmony_ci									      \
91da0c48c4Sopenharmony_ci/* Free resources allocated for hash table.  */				      \
92da0c48c4Sopenharmony_ciextern int name##_free (name *htab);					      \
93da0c48c4Sopenharmony_ci									      \
94da0c48c4Sopenharmony_ci/* Insert new entry.  */						      \
95da0c48c4Sopenharmony_ciextern int name##_insert (name *htab, HASHTYPE hval, TYPE data);	      \
96da0c48c4Sopenharmony_ci									      \
97da0c48c4Sopenharmony_ci/* Insert new entry, possibly overwrite old entry.  */			      \
98da0c48c4Sopenharmony_ciextern int name##_overwrite (name *htab, HASHTYPE hval, TYPE data);	      \
99da0c48c4Sopenharmony_ci									      \
100da0c48c4Sopenharmony_ci/* Find entry in hash table.  */					      \
101da0c48c4Sopenharmony_ciextern TYPE name##_find (name *htab, HASHTYPE hval, TYPE val);
102da0c48c4Sopenharmony_ci#define FUNCTIONS(name) _FUNCTIONS (name)
103da0c48c4Sopenharmony_ciFUNCTIONS (NAME)
104da0c48c4Sopenharmony_ci
105da0c48c4Sopenharmony_ci
106da0c48c4Sopenharmony_ci#ifdef ITERATE
107da0c48c4Sopenharmony_ci# define _XFUNCTIONS(name) \
108da0c48c4Sopenharmony_ci/* Get next element in table.  */					      \
109da0c48c4Sopenharmony_ciextern TYPE name##_iterate (name *htab, void **ptr);
110da0c48c4Sopenharmony_ci# define XFUNCTIONS(name) _XFUNCTIONS (name)
111da0c48c4Sopenharmony_ciXFUNCTIONS (NAME)
112da0c48c4Sopenharmony_ci#endif
113da0c48c4Sopenharmony_ci
114da0c48c4Sopenharmony_ci#ifndef NO_UNDEF
115da0c48c4Sopenharmony_ci# undef DYNHASHENTTYPE
116da0c48c4Sopenharmony_ci# undef DYNHASHTYPE
117da0c48c4Sopenharmony_ci# undef FUNCTIONS
118da0c48c4Sopenharmony_ci# undef _FUNCTIONS
119da0c48c4Sopenharmony_ci# undef XFUNCTIONS
120da0c48c4Sopenharmony_ci# undef _XFUNCTIONS
121da0c48c4Sopenharmony_ci# undef NAME
122da0c48c4Sopenharmony_ci# undef TYPE
123da0c48c4Sopenharmony_ci# undef ITERATE
124da0c48c4Sopenharmony_ci# undef COMPARE
125da0c48c4Sopenharmony_ci# undef FIRST
126da0c48c4Sopenharmony_ci# undef NEXT
127da0c48c4Sopenharmony_ci#endif
128