Home | History | Annotate | Line # | Download | only in libgettextpo
hash.h revision 1.1.1.1
      1 /* Copyright (C) 1995, 2000-2003, 2005-2006 Free Software Foundation, Inc.
      2 
      3    The GNU C Library is free software; you can redistribute it and/or
      4    modify it under the terms of the GNU Library General Public License as
      5    published by the Free Software Foundation; either version 2 of the
      6    License, or (at your option) any later version.
      7 
      8    The GNU C Library is distributed in the hope that it will be useful,
      9    but WITHOUT ANY WARRANTY; without even the implied warranty of
     10    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     11    Library General Public License for more details.
     12 
     13    You should have received a copy of the GNU Library General Public
     14    License along with the GNU C Library; see the file COPYING.LIB.  If
     15    not, write to the Free Software Foundation, Inc., 51 Franklin Street,
     16    Fifth Floor, Boston, MA 02110-1301, USA.  */
     17 
     18 #ifndef _HASH_H
     19 #define _HASH_H
     20 
     21 #include "obstack.h"
     22 
     23 #ifdef __cplusplus
     24 extern "C" {
     25 #endif
     26 
     27 struct hash_entry;
     28 
     29 typedef struct hash_table
     30 {
     31   unsigned long int size;   /* Number of allocated entries.  */
     32   unsigned long int filled; /* Number of used entries.  */
     33   struct hash_entry *first; /* Pointer to head of list of entries.  */
     34   struct hash_entry *table; /* Pointer to array of entries.  */
     35   struct obstack mem_pool;  /* Memory pool holding the keys.  */
     36 }
     37 hash_table;
     38 
     39 /* Initialize a hash table.  INIT_SIZE > 1 is the initial number of available
     40    entries.
     41    Return 0 upon successful completion, -1 upon memory allocation error.  */
     42 extern int hash_init (hash_table *htab, unsigned long int init_size);
     43 
     44 /* Delete a hash table's contents.
     45    Return 0 always.  */
     46 extern int hash_destroy (hash_table *htab);
     47 
     48 /* Look up the value of a key in the given table.
     49    If found, return 0 and set *RESULT to it.  Otherwise return -1.  */
     50 extern int hash_find_entry (hash_table *htab,
     51 			    const void *key, size_t keylen,
     52 			    void **result);
     53 
     54 /* Try to insert the pair (KEY[0..KEYLEN-1], DATA) in the hash table.
     55    Return non-NULL (more precisely, the address of the KEY inside the table's
     56    memory pool) if successful, or NULL if there is already an entry with the
     57    given key.  */
     58 extern const void * hash_insert_entry (hash_table *htab,
     59 				       const void *key, size_t keylen,
     60 				       void *data);
     61 
     62 /* Insert the pair (KEY[0..KEYLEN-1], DATA) in the hash table.
     63    Return 0.  */
     64 extern int hash_set_value (hash_table *htab,
     65 			   const void *key, size_t keylen,
     66 			   void *data);
     67 
     68 /* Steps *PTR forward to the next used entry in the given hash table.  *PTR
     69    should be initially set to NULL.  Store information about the next entry
     70    in *KEY, *KEYLEN, *DATA.
     71    Return 0 normally, -1 when the whole hash table has been traversed.  */
     72 extern int hash_iterate (hash_table *htab, void **ptr,
     73 			 const void **key, size_t *keylen,
     74 			 void **data);
     75 
     76 /* Steps *PTR forward to the next used entry in the given hash table.  *PTR
     77    should be initially set to NULL.  Store information about the next entry
     78    in *KEY, *KEYLEN, *DATAP.  *DATAP is set to point to the storage of the
     79    value; modifying **DATAP will modify the value of the entry.
     80    Return 0 normally, -1 when the whole hash table has been traversed.  */
     81 extern int hash_iterate_modify (hash_table *htab, void **ptr,
     82 				const void **key, size_t *keylen,
     83 				void ***datap);
     84 
     85 /* Given SEED > 1, return the smallest odd prime number >= SEED.  */
     86 extern unsigned long int next_prime (unsigned long int seed);
     87 
     88 #ifdef __cplusplus
     89 }
     90 #endif
     91 
     92 #endif /* not _HASH_H */
     93