Blame lib/hash.h

Packit 33f14e
/* hash - hashing table processing.
Packit 33f14e
   Copyright (C) 1998-1999, 2001, 2003, 2009-2017 Free Software Foundation,
Packit 33f14e
   Inc.
Packit 33f14e
   Written by Jim Meyering <meyering@ascend.com>, 1998.
Packit 33f14e
Packit 33f14e
   This program is free software: you can redistribute it and/or modify
Packit 33f14e
   it under the terms of the GNU General Public License as published by
Packit 33f14e
   the Free Software Foundation; either version 3 of the License, or
Packit 33f14e
   (at your option) any later version.
Packit 33f14e
Packit 33f14e
   This program is distributed in the hope that it will be useful,
Packit 33f14e
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 33f14e
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 33f14e
   GNU General Public License for more details.
Packit 33f14e
Packit 33f14e
   You should have received a copy of the GNU General Public License
Packit 33f14e
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit 33f14e
Packit 33f14e
/* A generic hash table package.  */
Packit 33f14e
Packit 33f14e
/* Make sure USE_OBSTACK is defined to 1 if you want the allocator to use
Packit 33f14e
   obstacks instead of malloc, and recompile 'hash.c' with same setting.  */
Packit 33f14e
Packit 33f14e
#ifndef HASH_H_
Packit 33f14e
# define HASH_H_
Packit 33f14e
Packit 33f14e
# include <stdio.h>
Packit 33f14e
# include <stdbool.h>
Packit 33f14e
Packit 33f14e
/* The __attribute__ feature is available in gcc versions 2.5 and later.
Packit 33f14e
   The warn_unused_result attribute appeared first in gcc-3.4.0.  */
Packit 33f14e
# if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4)
Packit 33f14e
#  define _GL_ATTRIBUTE_WUR __attribute__ ((__warn_unused_result__))
Packit 33f14e
# else
Packit 33f14e
#  define _GL_ATTRIBUTE_WUR /* empty */
Packit 33f14e
# endif
Packit 33f14e
Packit 33f14e
# ifndef _GL_ATTRIBUTE_DEPRECATED
Packit 33f14e
/* The __attribute__((__deprecated__)) feature
Packit 33f14e
   is available in gcc versions 3.1 and newer.  */
Packit 33f14e
#  if __GNUC__ < 3 || (__GNUC__ == 3 && __GNUC_MINOR__ < 1)
Packit 33f14e
#   define _GL_ATTRIBUTE_DEPRECATED /* empty */
Packit 33f14e
#  else
Packit 33f14e
#   define _GL_ATTRIBUTE_DEPRECATED __attribute__ ((__deprecated__))
Packit 33f14e
#  endif
Packit 33f14e
# endif
Packit 33f14e
Packit 33f14e
typedef size_t (*Hash_hasher) (const void *, size_t);
Packit 33f14e
typedef bool (*Hash_comparator) (const void *, const void *);
Packit 33f14e
typedef void (*Hash_data_freer) (void *);
Packit 33f14e
typedef bool (*Hash_processor) (void *, void *);
Packit 33f14e
Packit 33f14e
struct hash_tuning
Packit 33f14e
  {
Packit 33f14e
    /* This structure is mainly used for 'hash_initialize', see the block
Packit 33f14e
       documentation of 'hash_reset_tuning' for more complete comments.  */
Packit 33f14e
Packit 33f14e
    float shrink_threshold;     /* ratio of used buckets to trigger a shrink */
Packit 33f14e
    float shrink_factor;        /* ratio of new smaller size to original size */
Packit 33f14e
    float growth_threshold;     /* ratio of used buckets to trigger a growth */
Packit 33f14e
    float growth_factor;        /* ratio of new bigger size to original size */
Packit 33f14e
    bool is_n_buckets;          /* if CANDIDATE really means table size */
Packit 33f14e
  };
Packit 33f14e
Packit 33f14e
typedef struct hash_tuning Hash_tuning;
Packit 33f14e
Packit 33f14e
struct hash_table;
Packit 33f14e
Packit 33f14e
typedef struct hash_table Hash_table;
Packit 33f14e
Packit 33f14e
/* Information and lookup.  */
Packit 33f14e
size_t hash_get_n_buckets (const Hash_table *) _GL_ATTRIBUTE_PURE;
Packit 33f14e
size_t hash_get_n_buckets_used (const Hash_table *) _GL_ATTRIBUTE_PURE;
Packit 33f14e
size_t hash_get_n_entries (const Hash_table *) _GL_ATTRIBUTE_PURE;
Packit 33f14e
size_t hash_get_max_bucket_length (const Hash_table *) _GL_ATTRIBUTE_PURE;
Packit 33f14e
bool hash_table_ok (const Hash_table *) _GL_ATTRIBUTE_PURE;
Packit 33f14e
void hash_print_statistics (const Hash_table *, FILE *);
Packit 33f14e
void *hash_lookup (const Hash_table *, const void *);
Packit 33f14e
Packit 33f14e
/* Walking.  */
Packit 33f14e
void *hash_get_first (const Hash_table *) _GL_ATTRIBUTE_PURE;
Packit 33f14e
void *hash_get_next (const Hash_table *, const void *);
Packit 33f14e
size_t hash_get_entries (const Hash_table *, void **, size_t);
Packit 33f14e
size_t hash_do_for_each (const Hash_table *, Hash_processor, void *);
Packit 33f14e
Packit 33f14e
/* Allocation and clean-up.  */
Packit 33f14e
size_t hash_string (const char *, size_t) _GL_ATTRIBUTE_PURE;
Packit 33f14e
void hash_reset_tuning (Hash_tuning *);
Packit 33f14e
Hash_table *hash_initialize (size_t, const Hash_tuning *,
Packit 33f14e
                             Hash_hasher, Hash_comparator,
Packit 33f14e
                             Hash_data_freer) _GL_ATTRIBUTE_WUR;
Packit 33f14e
void hash_clear (Hash_table *);
Packit 33f14e
void hash_free (Hash_table *);
Packit 33f14e
Packit 33f14e
/* Insertion and deletion.  */
Packit 33f14e
bool hash_rehash (Hash_table *, size_t) _GL_ATTRIBUTE_WUR;
Packit 33f14e
void *hash_insert (Hash_table *, const void *) _GL_ATTRIBUTE_WUR;
Packit 33f14e
Packit 33f14e
int hash_insert_if_absent (Hash_table *table, const void *entry,
Packit 33f14e
                           const void **matched_ent);
Packit 33f14e
void *hash_delete (Hash_table *, const void *);
Packit 33f14e
Packit 33f14e
#endif