Commit a4f6608c by Richard Stallman

Some comments and whitespace cleaned up. RCS headers removed.

Include gstddef.h and objc-proto.h.
Don't include objcP.h or objc-protoP.h.
Avoid use of u_int, etc. so no need for sys/types.h.
Adjust for change in node_table field data type.

Fix calls to DEBUG_PRINTF; no longer wants stream as arg.

From-SVN: r2456
parent 437b9337
/* Copyright (C) 1989, 1992 Free Software Foundation, Inc. /* Hash tables for Objective C method dispatch.
Copyright (C) 1992 Free Software Foundation, Inc.
This file is part of GNU CC. This file is part of GNU CC.
...@@ -22,79 +23,13 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ ...@@ -22,79 +23,13 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
This exception does not however invalidate any other reasons why This exception does not however invalidate any other reasons why
the executable file might be covered by the GNU General Public License. */ the executable file might be covered by the GNU General Public License. */
/*
$Header: /home/fsf/rms/c-runtime/dispatch/RCS/hash.c,v 0.15 1992/09/02 02:04:32 rms Exp rms $
$Author: rms $
$Date: 1992/09/02 02:04:32 $
$Log: hash.c,v $
* Revision 0.15 1992/09/02 02:04:32 rms
* Changed some decls.
*
* Revision 0.14 1992/08/31 21:09:15 dglattin
* minor documentation changes.
*
* Revision 0.13 1992/08/18 04:46:58 dglattin
* Saving a working version before release.
*
* Revision 0.12 1992/04/13 11:43:08 dennisg
* Check in after array version of run-time works.
* Expect more changes as hash version and other changes are made.
*
* Revision 0.11 1992/01/03 02:55:03 dennisg
* modified to handle new initialization scheme.
* fixed code structure.
*
* Revision 0.10 1991/12/10 12:05:28 dennisg
* Cleaned up file format for a distribution.
*
* Revision 0.9 1991/12/03 02:01:23 dennisg
* fixed assert macro.
* added memory allocation adjustment macro for hash size allocation.
*
* Revision 0.8 1991/11/24 01:20:02 dennisg
* changed shorts back to ints.
* the efficiency gained didn't out weight the grossness of the code.
*
* Revision 0.7 1991/11/23 22:18:29 dennisg
* deleted hashIndex and moved it to hash-inline.h
* converted hash_value_for_key to a inline and moved it to hash-inline.h.
*
* Revision 0.6 1991/11/21 22:27:06 dennisg
* changed hash value calculation.
* func name changed from hashValue to hashIndex. the
* func really calculated a index anyway.
* changed hash func impl. essentially it was calculating a hash value
* from a hash value. this is a implementation thing.
*
* Revision 0.5 1991/11/20 23:29:20 dennisg
* converted hashIndex to a inline.
*
* Revision 0.4 1991/11/19 12:34:41 dennisg
* bug in hash_delete. It was using void* to obtain nodes to
* pass to hash_remove. The value passed to hash_removed is a
* entry from the node structure rather than the node itself. Using
* void* removed compiler checking.
* Modified to implement cache expansion.
*
* Revision 0.3 1991/11/07 23:23:40 dennisg
* implemented hash table expansion as suggested by rms.
*
* Revision 0.2 1991/11/07 22:30:54 dennisg
* added copyleft
*
* Revision 0.1 1991/10/24 00:45:39 dennisg
* Initial check in. Preliminary development stage.
*
*/
#include "config.h" #include "config.h"
#include "gstddef.h"
#include "assert.h"
#include "hash.h" #include "hash.h"
#include "objc.h" #include "objc.h"
#include "objcP.h" #include "objc-proto.h"
#include "objc-protoP.h"
#include "assert.h"
/* These two macros determine when a hash table is full and /* These two macros determine when a hash table is full and
...@@ -107,7 +42,8 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ ...@@ -107,7 +42,8 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
((cache)->size * 2) ((cache)->size * 2)
cache_ptr cache_ptr
hash_new (u_int size, hash_func_type hash_func, compare_func_type compare_func) hash_new (unsigned int size, hash_func_type hash_func,
compare_func_type compare_func)
{ {
cache_ptr cache; cache_ptr cache;
...@@ -160,9 +96,9 @@ hash_delete (cache_ptr cache) ...@@ -160,9 +96,9 @@ hash_delete (cache_ptr cache)
void void
hash_add (cache_ptr *cachep, void *key, void *value) hash_add (cache_ptr *cachep, const void *key, void *value)
{ {
u_int indx = (*(*cachep)->hash_func)(*cachep, key); size_t indx = (*(*cachep)->hash_func)(*cachep, key);
node_ptr node = (node_ptr) calloc (1, sizeof (struct cache_node)); node_ptr node = (node_ptr) calloc (1, sizeof (struct cache_node));
...@@ -171,12 +107,12 @@ hash_add (cache_ptr *cachep, void *key, void *value) ...@@ -171,12 +107,12 @@ hash_add (cache_ptr *cachep, void *key, void *value)
/* Initialize the new node. */ /* Initialize the new node. */
node->key = key; node->key = key;
node->value = value; node->value = value;
node->next = (*(*cachep)->node_table)[indx]; node->next = (*cachep)->node_table[indx];
/* Debugging. /* Debugging.
Check the list for another key. */ Check the list for another key. */
#ifdef DEBUG #ifdef DEBUG
{ node_ptr node1 = (*(*cachep)->node_table)[indx]; { node_ptr node1 = (*cachep)->node_table[indx];
while (node1) { while (node1) {
...@@ -187,7 +123,7 @@ hash_add (cache_ptr *cachep, void *key, void *value) ...@@ -187,7 +123,7 @@ hash_add (cache_ptr *cachep, void *key, void *value)
#endif #endif
/* Install the node as the first element on the list. */ /* Install the node as the first element on the list. */
(*(*cachep)->node_table)[indx] = node; (*cachep)->node_table[indx] = node;
/* Bump the number of entries in the cache. */ /* Bump the number of entries in the cache. */
++(*cachep)->used; ++(*cachep)->used;
...@@ -207,7 +143,7 @@ hash_add (cache_ptr *cachep, void *key, void *value) ...@@ -207,7 +143,7 @@ hash_add (cache_ptr *cachep, void *key, void *value)
(*cachep)->hash_func, (*cachep)->hash_func,
(*cachep)->compare_func); (*cachep)->compare_func);
DEBUG_PRINTF (stderr, "Expanding cache %#x from %d to %d\n", DEBUG_PRINTF ("Expanding cache %#x from %d to %d\n",
*cachep, (*cachep)->size, new->size); *cachep, (*cachep)->size, new->size);
/* Copy the nodes from the first hash table to the new one. */ /* Copy the nodes from the first hash table to the new one. */
...@@ -224,10 +160,10 @@ hash_add (cache_ptr *cachep, void *key, void *value) ...@@ -224,10 +160,10 @@ hash_add (cache_ptr *cachep, void *key, void *value)
void void
hash_remove (cache_ptr cache, void *key) hash_remove (cache_ptr cache, const void *key)
{ {
u_int indx = (*cache->hash_func)(cache, key); size_t indx = (*cache->hash_func)(cache, key);
node_ptr node = (*cache->node_table)[indx]; node_ptr node = cache->node_table[indx];
/* We assume there is an entry in the table. Error if it is not. */ /* We assume there is an entry in the table. Error if it is not. */
...@@ -235,7 +171,7 @@ hash_remove (cache_ptr cache, void *key) ...@@ -235,7 +171,7 @@ hash_remove (cache_ptr cache, void *key)
/* Special case. First element is the key/value pair to be removed. */ /* Special case. First element is the key/value pair to be removed. */
if ((*cache->compare_func)(node->key, key)) { if ((*cache->compare_func)(node->key, key)) {
(*cache->node_table)[indx] = node->next; cache->node_table[indx] = node->next;
free (node); free (node);
} else { } else {
...@@ -284,8 +220,8 @@ hash_next (cache_ptr cache, node_ptr node) ...@@ -284,8 +220,8 @@ hash_next (cache_ptr cache, node_ptr node)
/* Scan the remainder of the buckets looking for an entry /* Scan the remainder of the buckets looking for an entry
at the head of the list. Return the first item found. */ at the head of the list. Return the first item found. */
while (cache->last_bucket < cache->size) while (cache->last_bucket < cache->size)
if ((*cache->node_table)[cache->last_bucket]) if (cache->node_table[cache->last_bucket])
return (*cache->node_table)[cache->last_bucket]; return cache->node_table[cache->last_bucket];
else else
++cache->last_bucket; ++cache->last_bucket;
...@@ -296,18 +232,15 @@ hash_next (cache_ptr cache, node_ptr node) ...@@ -296,18 +232,15 @@ hash_next (cache_ptr cache, node_ptr node)
} }
/* /* Given KEY, return corresponding value for it in CACHE.
* Given key, return its value. Return NULL if the Return NULL if the KEY is not recorded. */
* key/value pair isn't in the hash.
*/
void * void *
hash_value_for_key (cache_ptr cache, void *key) hash_value_for_key (cache_ptr cache, const void *key)
{ {
node_ptr node node_ptr node = cache->node_table[(*cache->hash_func)(cache, key)];
= (*cache->node_table)[(*cache->hash_func)(cache, key)];
void *retval = NULL; void *retval = NULL;
if (node) if (node)
do { do {
if ((*cache->compare_func)(node->key, key)) if ((*cache->compare_func)(node->key, key))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment