summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/ChangeLog4
-rw-r--r--include/hashtab.h3
-rw-r--r--libiberty/ChangeLog4
-rw-r--r--libiberty/hashtab.c16
4 files changed, 27 insertions, 0 deletions
diff --git a/include/ChangeLog b/include/ChangeLog
index 305754fec07..b7d460e13aa 100644
--- a/include/ChangeLog
+++ b/include/ChangeLog
@@ -1,3 +1,7 @@
+2001-08-16 Richard Henderson <rth@redhat.com>
+
+ * hashtab.h (htab_hash_string): Declare.
+
2001-06-13 Andrew Cagney <ac131313@redhat.com>
* libiberty.h (lbasename): Change function declaration to return a
diff --git a/include/hashtab.h b/include/hashtab.h
index a577c5e2afe..8871710e5d8 100644
--- a/include/hashtab.h
+++ b/include/hashtab.h
@@ -145,6 +145,9 @@ extern htab_hash htab_hash_pointer;
/* An equality function for pointers. */
extern htab_eq htab_eq_pointer;
+/* A hash function for null-terminated strings. */
+extern hashval_t htab_hash_string PARAMS ((const PTR));
+
#ifdef __cplusplus
}
#endif /* __cplusplus */
diff --git a/libiberty/ChangeLog b/libiberty/ChangeLog
index a62db15285b..84653bbe2fd 100644
--- a/libiberty/ChangeLog
+++ b/libiberty/ChangeLog
@@ -1,3 +1,7 @@
+2001-08-16 Richard Henderson <rth@redhat.com>
+
+ * hashtab.c (htab_hash_string): New.
+
2001-08-13 Andrew Cagney <ac131313@redhat.com>
* floatformat.c (floatformat_ieee_double_littlebyte_bigword): Fix
diff --git a/libiberty/hashtab.c b/libiberty/hashtab.c
index 274ad9ec207..28078027fef 100644
--- a/libiberty/hashtab.c
+++ b/libiberty/hashtab.c
@@ -561,3 +561,19 @@ htab_collisions (htab)
return (double) htab->collisions / (double) htab->searches;
}
+
+/* Hash P as a null-terminated string. */
+
+hashval_t
+htab_hash_string (p)
+ const PTR p;
+{
+ const unsigned char *str = (const unsigned char *) p;
+ hashval_t r = 0;
+ unsigned char c;
+
+ while ((c = *str++) != 0)
+ r = r * 67 + c - 113;
+
+ return r;
+}