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