From f3e390e3b31c45f64e9739943f461d2321ff9dd5 Mon Sep 17 00:00:00 2001
From: Chris Hanson <org/chris-hanson/cph>
Date: Wed, 25 Apr 2018 23:48:49 -0700
Subject: [PATCH] Update hash-table documentation in the reference manual.

---
 doc/ref-manual/associations.texi | 468 +++++++++++++++++++++----------
 1 file changed, 314 insertions(+), 154 deletions(-)

diff --git a/doc/ref-manual/associations.texi b/doc/ref-manual/associations.texi
index e1b5ac4b2..0ee70ba62 100644
--- a/doc/ref-manual/associations.texi
+++ b/doc/ref-manual/associations.texi
@@ -381,28 +381,24 @@ is proportional to the number of associations in the table; the
 constant of proportionality is described below (@pxref{Resizing of Hash
 Tables}).
 
-In addition to the hash table interface described in the following,
-MIT Scheme implements @usrfi{69}: ``Basic hash tables''.  The reason
-for supporting two interfaces is partly historical---MIT Scheme
-supported hash tables prior to the existence of @asrfi{69}---and partly
-technical---SFRI 69 fails to specify certain optimization-enabling
-exceptions to its semantics, forcing a correct implementation to pay
-the non-negligible performance cost of completely safe behavior.
-@footnote{@asrfi{69} does not give hash functions the flexibility to
-return new hash values after a garbage collection, which prevents a
-system whose garbage collector may relocate objects from hashing based
-on the addresses of objects in memory (@pxref{Address Hashing}).
-@asrfi{69} also does not specify circumstances when procedures passed
-as arguments to hash table operations may not themselves modify the
-hash table, which requires defensive copying and defensive repetitions
-of lookups.}  The MIT Scheme native hash table interface, in contrast,
-specifies the minor exceptions it needs, and is therefore implemented
-more efficiently.  We do not describe the @asrfi{69}-compliant interface
-here, as that would be redundant with the SRFI document.
-
-(Previously, the hash-table implementation was a run-time-loadable
-option, but as of release 7.7.0 it is loaded by default.  It's no longer
-necessary to call @code{load-option} prior to using hash tables.)
+The hash table interface described below is a superset of @usrfi{69}:
+``Basic hash tables''.  The reason for supporting the extra
+functionality is that @asrfi{69} fails to specify certain
+optimization-enabling exceptions to its semantics, forcing a correct
+implementation to pay the non-negligible performance cost of
+completely safe behavior.  @footnote{@asrfi{69} does not give hash
+functions the flexibility to return new hash values after a garbage
+collection, which prevents a system whose garbage collector may
+relocate objects from hashing based on the addresses of objects in
+memory (@pxref{Address Hashing}).  @asrfi{69} also does not specify
+circumstances when procedures passed as arguments to hash table
+operations may not themselves modify the hash table, which requires
+defensive copying and defensive repetitions of lookups.}  The MIT/GNU
+Scheme native hash table interface, in contrast, specifies the minor
+exceptions it needs, and is therefore implemented more efficiently.
+
+We do not describe the @asrfi{69}-compliant interface here, as that
+would be redundant with the SRFI document.
 
 @menu
 * Construction of Hash Tables::
@@ -438,6 +434,7 @@ arrangements are possible, where a table may hold keys or data
 @dfn{weakly} or @dfn{ephemerally} (@pxref{Weak References}).
 
 @deffn procedure make-strong-eq-hash-table [initial-size]
+@deffnx {obsolete procedure} make-symbol-hash-table [initial-size]
 @findex eq?
 Returns a newly allocated hash table that accepts arbitrary objects as
 keys, and compares those keys with @code{eq?}.  The keys and data are held
@@ -445,13 +442,23 @@ strongly.  These are the fastest of the standard hash tables.
 @end deffn
 
 @deffn procedure make-key-weak-eq-hash-table [initial-size]
+@deffnx {obsolete procedure} make-weak-eq-hash-table [initial-size]
+@deffnx {obsolete procedure} make-eq-hash-table [initial-size]
 @findex eq?
 Returns a newly allocated hash table that accepts arbitrary objects as
 keys, and compares those keys with @code{eq?}.  The keys are held
-weakly, but the data are held strongly.  Note that if a datum holds a
+weakly and the data are held strongly.  Note that if a datum holds a
 key strongly, the table will effectively hold that key strongly.
 @end deffn
 
+@deffn procedure make-datum-weak-eq-hash-table [initial-size]
+@findex eq?
+Returns a newly allocated hash table that accepts arbitrary objects as
+keys, and compares those keys with @code{eq?}.  The keys are held
+strongly and the data are held weakly.  Note that if a key holds a
+datum strongly, the table will effectively hold that datum strongly.
+@end deffn
+
 @deffn procedure make-key-ephemeral-eq-hash-table [initial-size]
 @findex eq?
 Returns a newly allocated hash table that accepts arbitrary objects as
@@ -469,6 +476,9 @@ strongly.  These hash tables are a little slower than those made by
 @end deffn
 
 @deffn procedure make-key-weak-eqv-hash-table [initial-size]
+@deffnx {obsolete procedure} make-weak-eqv-hash-table [initial-size]
+@deffnx {obsolete procedure} make-eqv-hash-table [initial-size]
+@deffnx {obsolete procedure} make-object-hash-table [initial-size]
 @findex eqv?
 Returns a newly allocated hash table that accepts arbitrary objects as
 keys, and compares those keys with @code{eqv?}.  The keys are held
@@ -478,6 +488,14 @@ a datum holds a key strongly, the table will effectively hold that key
 strongly.
 @end deffn
 
+@deffn procedure make-datum-weak-eqv-hash-table [initial-size]
+@findex eqv?
+Returns a newly allocated hash table that accepts arbitrary objects as
+keys, and compares those keys with @code{eqv?}.  The keys are held
+strongly and the data are held weakly.  Note that if a key holds a
+datum strongly, the table will effectively hold that datum strongly.
+@end deffn
+
 @deffn procedure make-key-ephemeral-eqv-hash-table [initial-size]
 @findex eqv?
 Returns a newly allocated hash table that accepts arbitrary objects as
@@ -502,37 +520,94 @@ keys, and compares them with @code{string=?}.  The keys and data are held
 strongly.
 @end deffn
 
-The next procedure is used to create new hash-table constructors.  All
-of the above hash table constructors could have been created by calls
-to this ``constructor-constructor''; see the examples below.
+All of the above are highly optimized table implementations.  Next are
+some general constructors that allow for more flexible table
+definitions.
+
+@deffn procedure make-hash-table [key=? [hash-function [arg @dots{}]]]
+@deffnx procedure alist->hash-table alist [key=? [hash-function [arg @dots{}]]]
+These are the @asrfi{69} constructors.  The @var{key=?} argument
+specifies how keys are compared and defaults to @code{equal?}.  The
+@var{hash-function} argument specifies the hash function to use. If
+@var{hash-function} is not specified, it defaults to a standard value that
+depends on @var{key=?}; an error is signaled if there's no standard
+value.  The @var{arg} arguments are allowed but are implementation
+dependent; do not provide them.
 
-@deffn procedure hash-table/constructor key-hash key=? rehash-after-gc? entry-type
+The procedure @code{alist->hash-table} creates a new hash table, as
+with @code{make-hash-table}, and then fills it with the contents of
+@var{alist}.
+@end deffn
+
+The remaining constructors use @dfn{hash-table types} to encapsulate
+the hashing parameters.
+
+@deffn procedure make-hash-table* type [initial-size]
+Constructs a new hash table using the hashing parameters in
+@var{type}.
+@end deffn
+
+@deffn procedure hash-table-constructor type
+Returns a procedure that, when called, constructs a new hash table
+using the hashing parameters in @var{type}.  The returned procedure
+accepts an optional @var{initial-size}.
+
+This is equivalent to
+@lisp
+(lambda (#!optional initial-size)
+  (make-hash-table* @var{type} initial-size))
+@end lisp
+@end deffn
+
+The next two procedures are used to create hash-table types.  The
+procedures are equivalent in power; they differ only in how the types
+are described.
+
+@deffn procedure make-hash-table-type hash-function key=? rehash-after-gc? entry-type
 @cindex hashing, of key in hash table
 @cindex modulus, of hashing procedure
-This procedure accepts four arguments and returns a hash-table
-constructor.  The @var{key=?} argument is an equivalence predicate for
-the keys of the hash table.  The @var{key-hash} argument is a procedure
-that computes a hash number.  Specifically, @var{key-hash} accepts two
-arguments, a key and an exact positive integer (the @dfn{modulus}), and
-returns an exact non-negative integer that is less than the modulus.
+This procedure accepts four arguments and returns a hash-table type,
+which can be used to make hash tables of that type.  The @var{key=?}
+argument is an equivalence predicate for the keys of the hash table.
+The @var{hash-function} argument is a procedure that computes a hash
+number.  Specifically, @var{hash-function} accepts two arguments, a key and
+an exact positive integer (the @dfn{modulus}), and returns an exact
+non-negative integer that is less than the modulus.
 
 The argument @var{rehash-after-gc?}, if true, says that the
-values returned by @var{key-hash} might change after a garbage
+values returned by @var{hash-function} might change after a garbage
 collection.  If so, the hash-table implementation arranges for the table
 to be rehashed when necessary.  (@xref{Address Hashing}, for
 information about hash procedures that have this property.)  Otherwise,
-it is assumed that @var{key-hash} always returns the same value for the
+it is assumed that @var{hash-function} always returns the same value for the
 same arguments.
 
 The argument @var{entry-type} determines the strength with which the
-hash table will hold its keys and values.  It must be one of
-@code{hash-table-entry-type:strong},
-@code{hash-table-entry-type:key-weak},
-@code{hash-table-entry-type:datum-weak},
-@code{hash-table-entry-type:key/datum-weak},
-@code{hash-table-entry-type:key-ephemeral},
-@code{hash-table-entry-type:datum-ephemeral}, or
-@code{hash-table-entry-type:key&datum-ephemeral}.
+hash table will hold its keys and values.  It must be one of the
+entry-type variables described below, which all start with
+@code{hash-table-entry-type:}.
+@end deffn
+
+@deffn procedure make-hash-table-type* key=? hash-function rehash-after-gc? entry-type
+This procedure's arguments, except for @var{key=?}, are keyword
+arguments; that is, each argument is a symbol of the same name
+followed by its value.  Aside from how they are passed, the arguments
+have the same meaning as those for @code{make-hash-table-type}.  Note
+that all of the keyword arguments are optional, while @var{key=?} is
+required.
+
+The argument @var{entry-type} specifies @emph{the name of} an entry
+type.  It must be a symbol corresponding to one of the entry-type
+variables described below.  The name of an entry type is the symbol
+composed of the suffix of the corresponding variable; for example the
+type @code{hash-table-entry-type:key-weak} has the name
+@code{key-weak}.
+
+The default values for the keyword arguments are as follows.  The
+arguments @var{hash-function} and @var{rehash-after-gc?} default to
+standard values that depend on @var{key=?}; an error is signaled if
+@var{key=?} has no standard values.  The argument @var{entry-type}
+defaults to @var{strong}.
 @end deffn
 
 @defvr variable hash-table-entry-type:strong
@@ -559,7 +634,8 @@ if some key holds some datum strongly, the table will effectively hold
 that datum strongly.
 @end defvr
 
-@defvr variable hash-table-entry-type:key/datum-weak
+@defvr variable hash-table-entry-type:key&datum-weak
+@defvrx {obsolete variable} hash-table-entry-type:key/datum-weak
 The entry type for hash tables that hold both keys and data weakly.
 An entry of this type is a weak list, holding both the key and the
 datum in the weak (car) slot of weak pairs (@pxref{Weak Pairs}).  If
@@ -609,60 +685,47 @@ been defined:
 @example
 @group
 (define make-weak-eq-hash-table
-  (hash-table/constructor eq-hash-mod eq? #t
-    hash-table-entry-type:key-weak))
+  (hash-table-constructor
+    (make-hash-table-type eq-hash-mod eq? #t
+      hash-table-entry-type:key-weak)))
 
 (define make-equal-hash-table
-  (hash-table/constructor equal-hash-mod equal? #t
-    hash-table-entry-type:strong))
+  (hash-table-constructor
+    (make-hash-table-type equal-hash-mod equal? #t
+      hash-table-entry-type:strong)))
 
 (define make-string-hash-table
-  (hash-table/constructor string-hash-mod string=? #f
-    hash-table-entry-type:strong))
+  (hash-table-constructor
+    (make-hash-table-type string-hash-mod string=? #f
+      hash-table-entry-type:strong)))
 @end group
 @end example
 
-The following procedure is sometimes useful in conjunction with weak
-and ephemeral hash tables.  Normally it is not needed, because such
-hash tables clean themselves automatically as they are used.
-
-@deffn procedure hash-table/clean! hash-table
-If @var{hash-table} is a type of hash table that holds its keys or
-data weakly or ephemerally, this procedure recovers any space that was
-being used to record associations for objects that have been reclaimed
-by the garbage collector.  Otherwise, this procedure does nothing.  In
-either case, it returns an unspecified result.
-@end deffn
-
 The following procedures are provided only for backward compatibility.
 They should be considered @strong{deprecated} and should not be used
 in new programs.
 
-@deffn procedure make-weak-eq-hash-table [initial-size]
-@deffnx procedure make-eq-hash-table [initial-size]
-@findex eq?
-These are aliases of @code{make-key-weak-eq-hash-table}.
-@end deffn
-
-@deffn procedure make-weak-eqv-hash-table [initial-size]
-@deffnx procedure make-eqv-hash-table [initial-size]
-@findex eq?
-These are aliases of @code{make-key-weak-eqv-hash-table}.
+@deffn {obsolete procedure} hash-table/constructor hash-function key=? rehash-after-gc? entry-type
+This procedure is @strong{deprecated}. Instead use the equivalent
+@lisp
+(hash-table-constructor
+  (make-hash-table-type @var{hash-function} @var{key=?} @var{rehash-after-gc?}
+                        @var{entry-type}))
+@end lisp
 @end deffn
 
-@deffn procedure strong-hash-table/constructor key-hash key=? [rehash-after-gc?]
+@deffn {obsolete procedure} strong-hash-table/constructor hash-function key=? [rehash-after-gc?]
 Like @code{hash-table/constructor} but always uses
 @code{hash-table-entry-type:strong}.  If @var{rehash-after-gc?}  is
 omitted, it defaults to @code{#f}.
 @end deffn
 
-@deffn procedure weak-hash-table/constructor key-hash key=? [rehash-after-gc?]
+@deffn {obsolete procedure} weak-hash-table/constructor hash-function key=? [rehash-after-gc?]
 Like @code{hash-table/constructor} but always uses
 @code{hash-table-entry-type:key-weak}.  If @var{rehash-after-gc?}  is
 omitted, it defaults to @code{#f}.
 @end deffn
 
-
 @node Basic Hash Table Operations, Resizing of Hash Tables, Construction of Hash Tables, Hash Tables
 @subsection Basic Hash Table Operations
 
@@ -677,75 +740,101 @@ Returns @code{#t} if @var{object} is a hash table, otherwise returns
 @code{#f}.
 @end deffn
 
-@deffn procedure hash-table/put! hash-table key datum
+@deffn procedure hash-table-set! hash-table key datum
+@deffnx {obsolete procedure} hash-table/put! hash-table key datum
 Associates @var{datum} with @var{key} in @var{hash-table} and returns an
-unspecified result.  The average time required by this operation is
-bounded by a constant.
+unspecified result.
+
+The average time required by this operation is bounded by a constant.
 @end deffn
 
-@deffn procedure hash-table/get hash-table key default
+@deffn procedure hash-table-ref hash-table key [get-default]
 Returns the datum associated with @var{key} in @var{hash-table}.  If
-there is no association for @var{key}, @var{default} is returned.  The
-average time required by this operation is bounded by a constant.
+there is no association for @var{key}, and @var{get-default} is
+provided, it is called with no arguments and the value it yields is
+returned; if @var{get-default} is not provided, an error is signaled.
+
+The average time required by this operation is bounded by a constant.
+@end deffn
+
+@deffn procedure hash-table-ref/default hash-table key default
+@deffnx {obsolete procedure} hash-table/get hash-table key default
+Equivalent to
+@lisp
+(hash-table-ref @var{hash-table} @var{key} (lambda () @var{default}))
+@end lisp
 @end deffn
 
-@deffn procedure hash-table/remove! hash-table key
+@deffn procedure hash-table-delete! hash-table key
+@deffnx {obsolete procedure} hash-table/remove! hash-table key
 If @var{hash-table} has an association for @var{key}, removes it.
-Returns an unspecified result.  The average time required by this
-operation is bounded by a constant.
+Returns an unspecified result.
+
+The average time required by this operation is bounded by a constant.
 @end deffn
 
-@deffn procedure hash-table/clear! hash-table
+@deffn procedure hash-table-clear! hash-table
+@deffnx {obsolete procedure} hash-table/clear! hash-table
 Removes all associations in @var{hash-table} and returns an unspecified
-result.  The average and worst-case times required by this operation are
+result.
+
+The average and worst-case times required by this operation are
 bounded by a constant.
 @end deffn
 
-@deffn procedure hash-table/count hash-table
+@deffn procedure hash-table-size hash-table
+@deffnx {obsolete procedure} hash-table/count hash-table
 Returns the number of associations in @var{hash-table} as an exact
-non-negative integer.  If @var{hash-table}
-does not hold its keys and data strongly, this
-is a conservative upper bound that may count some associations whose
-keys or data have recently been reclaimed by the garbage collector.  The average
-and worst-case times required by this operation are bounded by a
-constant.
+non-negative integer.  If @var{hash-table} does not hold its keys and
+data strongly, this is a conservative upper bound that may count some
+associations whose keys or data have recently been reclaimed by the
+garbage collector.
+
+The average and worst-case times required by this operation are
+bounded by a constant.
 @end deffn
 
 @deffn procedure hash-table->alist hash-table
 Returns the contents of @var{hash-table} as a newly allocated alist.
 Each element of the alist is a pair @code{(@var{key} . @var{datum})}
 where @var{key} is one of the keys of @var{hash-table}, and @var{datum}
-is its associated datum.  The average and worst-case times required by
-this operation are linear in the number of associations
-in the table.
+is its associated datum.
+
+The average and worst-case times required by this operation are linear
+in the number of associations in the table.
 @end deffn
 
-@deffn procedure hash-table/key-list hash-table
-Returns a newly allocated list of the keys in @var{hash-table}.  The
-average and worst-case times required by this operation are linear in
-the number of associations in the table.
+@deffn procedure hash-table-keys hash-table
+@deffnx {obsolete procedure} hash-table/key-list hash-table
+Returns a newly allocated list of the keys in @var{hash-table}.
+
+The average and worst-case times required by this operation are linear
+in the number of associations in the table.
 @end deffn
 
-@deffn procedure hash-table/datum-list hash-table
+@deffn procedure hash-table-values hash-table
+@deffnx {obsolete procedure} hash-table/datum-list hash-table
 Returns a newly allocated list of the datums in @var{hash-table}.  Each
 element of the list corresponds to one of the associations in
 @var{hash-table}; if the table contains multiple associations with the
-same datum, so will this list.  The average and worst-case times
-required by this operation are linear in the number of associations in
-the table.
+same datum, so will this list.
+
+The average and worst-case times required by this operation are linear
+in the number of associations in the table.
 @end deffn
 
-@deffn procedure hash-table/for-each hash-table procedure
+@deffn procedure hash-table-walk hash-table procedure
+@deffnx {obsolete procedure} hash-table/for-each hash-table procedure
 @var{Procedure} must be a procedure of two arguments.  Invokes
 @var{procedure} once for each association in @var{hash-table}, passing
 the association's @var{key} and @var{datum} as arguments, in that order.
 Returns an unspecified result.  @var{Procedure} must not modify
 @var{hash-table}, with one exception: it is permitted to call
-@code{hash-table/remove!} to remove the association being processed.
+@code{hash-table-delete!} to remove the association being processed.
 @end deffn
 
 The following procedure is useful when there is no sensible default
-value for @code{hash-table/get} and the caller must choose between
+value for @code{hash-table-ref} and the caller must choose between
 different actions depending on whether there is a datum associated
 with the key.
 
@@ -757,45 +846,75 @@ is invoked on the datum of the association.  Otherwise,
 @var{if-not-found} is invoked with no arguments.  In either case, the
 result yielded by the invoked procedure is returned as the result of
 @code{hash-table/lookup} (@code{hash-table/lookup} @emph{reduces} into
-the invoked procedure, i.e.@: calls it tail-recursively).  The average
-time required by this operation is bounded by a constant.
+the invoked procedure, i.e.@: calls it tail-recursively).
+
+The average time required by this operation is bounded by a constant.
+@end deffn
+
+@deffn procedure hash-table-update! hash-table key procedure [get-default]
+@var{Procedure} must be a procedure of one argument and
+@var{get-default}, if supplied, must be a procedure of zero arguments.
+Applies @var{procedure} to the datum associated with @var{key} in
+@var{hash-table} or to the value of calling @var{get-default} if there
+is no association for @var{key}, associates the result with @var{key},
+and returns that same result.  If @var{get-default} is not supplied
+and there's no association for @var{key}, an error is signaled.
+
+Neither @var{procedure} nor @var{get-default} may use @var{hash-table}.
+
+The average time required by this operation is bounded by a constant.
 @end deffn
 
-@deffn procedure hash-table/modify! hash-table key default procedure
-@var{Procedure} must be a procedure of one argument.  Applies
-@var{procedure} to the datum associated with @var{key} in
-@var{hash-table} or to @var{default} if there is no association for
-@var{key}, associates the result with @var{key}, and returns that
-same result.  @var{Procedure} must not use @var{hash-table}.  The average
-time required by this operation is bounded by a constant.
+@deffn procedure hash-table-update!/default hash-table key procedure default
+@deffnx {obsolete procedure} hash-table/modify! hash-table key default procedure
+Equivalent to
+@lisp
+(hash-table-update! @var{hash-table} @var{key} @var{procedure} (lambda () @var{default}))
+@end lisp
 @end deffn
 
-@c The reason that the procedure passed to hash-table/modify!  may not
-@c even use the hash table is that, e.g., hash-table/get may actually
+@c The reason that the procedure passed to hash-table-update!  may not
+@c even use the hash table is that, e.g., hash-table-ref may actually
 @c mutate the underlying table, because it may perform some deferred
 @c cleanup.  Specifically, if the table needs to be rehashed on GC, it
 @c is not actually rehashed when the garbage collector runs, but on
 @c the next access thereafter.  If the procedure given to
-@c hash-table/modify! accesses the hash table, and a garbage
+@c hash-table-update! accesses the hash table, and a garbage
 @c collection occurs after this procedure is invoked but before the
 @c (last) access it makes, the table may be rehashed, which may cause
-@c hash-table/modify! to insert the returned datum into the wrong
+@c hash-table-update! to insert the returned datum into the wrong
 @c bucket or into a dead hash table entry.  An analagous problem
 @c plagues weak and ephemeral tables; in this case, even if the table
 @c is not rehashed, accessing it after a GC may trigger a cleanup of
 @c entries whose keys or data have been garbage collected, which may
-@c trigger a resizing of the table and cause hash-table/modify!  to
+@c trigger a resizing of the table and cause hash-table-update!  to
 @c put its datum into the wrong place.  The same considerations apply
-@c to hash-table/intern!.
+@c to hash-table-intern!.
 
-@deffn procedure hash-table/intern! hash-table key get-default
-@var{Get-default} must be a procedure of no arguments.  Ensures that
+@deffn procedure hash-table-intern! hash-table key get-default
+@deffnx {obsolete procedure} hash-table/intern! hash-table key get-default
+@var{Get-default} must be a procedure of zero arguments.  Ensures that
 @var{hash-table} has an association for @var{key} and returns the
 associated datum.  If @var{hash-table} did not have a datum associated
-with @var{key}, @code{hash-table/intern!} applies @var{get-default} to
-zero arguments to generate one.  As with @code{hash-table/modify!},
-@var{get-default} must not use @var{hash-table}.  The average time
-required by this operation is bounded by a constant.
+with @var{key}, @var{get-default} is called and its value is used to
+create a new association for @var{key}.
+
+The @var{get-default} procedure must not use @var{hash-table}.
+
+The average time required by this operation is bounded by a constant.
+@end deffn
+
+The following procedure is sometimes useful in conjunction with weak
+and ephemeral hash tables.  Normally it is not needed, because such
+hash tables clean themselves automatically as they are used.
+
+@deffn procedure hash-table-clean! hash-table
+@deffnx {obsolete procedure} hash-table/clean! hash-table
+If @var{hash-table} is a type of hash table that holds its keys or
+data weakly or ephemerally, this procedure recovers any space that was
+being used to record associations for objects that have been reclaimed
+by the garbage collector.  Otherwise, this procedure does nothing.  In
+either case, it returns an unspecified result.
 @end deffn
 
 @node Resizing of Hash Tables, Address Hashing, Basic Hash Table Operations, Hash Tables
@@ -939,17 +1058,25 @@ times, but increases the physical size of the table for a given usable
 size.  The default rehash threshold of a newly constructed hash table is
 @code{1}.
 
-@deffn procedure hash-table/size hash-table
+@deffn procedure hash-table-grow-size hash-table
+@deffnx {obsolete procedure} hash-table/size hash-table
 Returns the usable size of @var{hash-table} as an exact positive
-integer.  This is the number of associations that @var{hash-table} can
-hold before it will grow.
+integer.  This is the maximum number of associations that
+@var{hash-table} can hold before it will grow.
 @end deffn
 
-@deffn procedure hash-table/rehash-size hash-table
+@deffn procedure hash-table-shrink-size hash-table
+Returns the minimum number of associations that @var{hash-table} can
+hold before it will shrink.
+@end deffn
+
+@deffn procedure hash-table-rehash-size hash-table
+@deffnx {obsolete procedure} hash-table/rehash-size hash-table
 Returns the rehash size of @var{hash-table}.
 @end deffn
 
-@deffn procedure set-hash-table/rehash-size! hash-table x
+@deffn procedure set-hash-table-rehash-size! hash-table x
+@deffnx {obsolete procedure} set-hash-table/rehash-size! hash-table x
 @var{X} must be either an exact positive integer, or a real number that
 is greater than one.  Sets the rehash size of @var{hash-table} to
 @var{x} and returns an unspecified result.  This operation adjusts the
@@ -957,11 +1084,13 @@ is greater than one.  Sets the rehash size of @var{hash-table} to
 of associations is less than the new threshold.
 @end deffn
 
-@deffn procedure hash-table/rehash-threshold hash-table
+@deffn procedure hash-table-rehash-threshold hash-table
+@deffnx {obsolete procedure} hash-table/rehash-threshold hash-table
 Returns the rehash threshold of @var{hash-table}.
 @end deffn
 
-@deffn procedure set-hash-table/rehash-threshold! hash-table x
+@deffn procedure set-hash-table-rehash-threshold! hash-table x
+@deffnx {obsolete procedure} set-hash-table/rehash-threshold! hash-table x
 @var{X} must be a real number between zero exclusive and one inclusive.
 Sets the rehash threshold of @var{hash-table} to @var{x} and returns an
 unspecified result.  This operation does not change the usable size of
@@ -982,13 +1111,13 @@ and takes the same amount of time for any object.
 
 The disadvantage of address hashing is that the garbage collector
 changes the addresses of most objects.  The hash-table implementation
-compensates for this disadvantage by automatically rehashing tables that
-use address hashing when garbage collections occur.  Thus, in order to
-use these procedures for key hashing, it is necessary to tell the
-hash-table implementation (by means of the @var{rehash-after-gc?}
-argument to the ``constructor-constructor'' procedure) that the hash
-numbers computed by your key-hashing procedure must be recomputed after
-a garbage collection.
+compensates for this disadvantage by automatically rehashing tables
+that use address hashing when garbage collections occur.  Thus, in
+order to use these procedures for key hashing, it is necessary to tell
+the hash-table implementation (by means of the @var{rehash-after-gc?}
+argument to the hash-table type constructors) that the hash numbers
+computed by your key-hashing procedure must be recomputed after a
+garbage collection.
 
 @deffn procedure eq-hash object
 @deffnx procedure eqv-hash object
@@ -1001,8 +1130,33 @@ same hash number when passed as arguments to these procedures, provided
 that the garbage collector does not run during or between the two calls.
 @end deffn
 
+The following procedures are the hash functions specified by
+@asrfi{69}.
+
+@deffn procedure hash-by-identity key [modulus]
+This procedure returns the same value as @code{eq-hash}, optionally
+limited by @var{modulus}.
+@end deffn
+
+@deffn procedure hash-by-eqv key [modulus]
+This procedure returns the same value as @code{eqv-hash}, optionally
+limited by @var{modulus}.
+
+This procedure is not specified by @asrfi{69}.
+@end deffn
+
+@deffn procedure hash-by-equal key [modulus]
+This procedure returns the same value as @code{equal-hash}, optionally
+limited by @var{modulus}.
+
+This procedure is called @code{hash} by @asrfi{69}, but that name was
+used for a different purpose by MIT/GNU Scheme long before @asrfi{69}
+was written.  The previous use of @code{hash} has been deprecated, but
+it will be some time until it can be removed.
+@end deffn
+
 The following procedures are the key-hashing procedures used by the
-standard address-hash-based hash tables.
+standard address-hash-based hash tables.  They are 
 
 @deffn procedure eq-hash-mod object modulus
 This procedure is the key-hashing procedure used by
@@ -1026,19 +1180,21 @@ This procedure is the key-hashing procedure used by
 @cindex hashing, of object
 The MIT/GNU Scheme object-hashing facility provides a mechanism for
 generating a unique hash number for an arbitrary object.  This hash
-number, unlike an object's address, is unchanged by garbage collection.
-The object-hashing facility is useful in conjunction with hash tables,
-but it may be used for other things as well.  In particular, it is used
-in the generation of the written representation for many objects
-(@pxref{Custom Output}).
+number, unlike an object's address, is unchanged by garbage
+collection.  The object-hashing facility is used in the generation of
+the written representation for many objects (@pxref{Custom Output}),
+but it can be used for anything that needs a stable identifier for an
+arbitrary object.
 
 All of these procedures accept an optional argument called
 @var{hasher} which contains the object-integer associations.  If
 given, this argument must be an object hasher as constructed by
-@code{make-object-hasher} (see below).  If not given, a default table
+@code{make-object-hasher} (see below).  If not given, a default hasher
 is used.
 
 @deffn procedure hash-object object [hasher]
+@deffnx {obsolete procedure} hash object [hasher]
+@deffnx {obsolete procedure} object-hash object [hasher]
 @findex eq?
 @code{hash-object} associates an exact non-negative integer with
 @var{object} and returns that integer.  If @code{hash-object} was
@@ -1049,6 +1205,8 @@ returned is the same as was returned by the previous call.
 @end deffn
 
 @deffn procedure unhash-object k [hasher]
+@deffnx {obsolete procedure} unhash k [hasher]
+@deffnx {obsolete procedure} object-unhash k [hasher]
 @code{unhash-object} takes an exact non-negative integer @var{k} and
 returns the object associated with that integer.  If there is no
 object associated with @var{k}, or if the object previously associated
@@ -1060,11 +1218,11 @@ call to @code{unhash-object}.
 @findex condition-type:bad-range-argument
 @end deffn
 
-An object that is passed to @code{hash} as an argument is not protected
-from being reclaimed by the garbage collector.  If all other references
-to that object are eliminated, the object will be reclaimed.
-Subsequently calling @code{unhash} with the hash number of the (now
-reclaimed) object will signal an error.
+An object that is passed to @code{hash-object} as an argument is not
+protected from being reclaimed by the garbage collector.  If all other
+references to that object are eliminated, the object will be
+reclaimed.  Subsequently calling @code{unhash-object} with the hash
+number of the (now reclaimed) object will signal an error.
 
 @example
 @group
@@ -1083,6 +1241,7 @@ This predicate is true iff @var{object} has an associated hash number.
 @end deffn
 
 @deffn procedure valid-object-hash? k [hasher]
+@deffnx {obsolete procedure} valid-hash-number? k [hasher]
 This predicate is true iff @var{k} is the hash number associated with
 some object.
 @end deffn
@@ -1090,6 +1249,7 @@ some object.
 Finally, this procedure makes new object hashers:
 
 @deffn procedure make-object-hasher
+@deffnx {obsolete procedure} hash-table/make
 This procedure creates and returns a new, empty object hasher that
 is suitable for use as the optional @var{hasher} argument to the above
 procedures.  The returned hasher contains no associations.
-- 
2.25.1