X-Git-Url: https://git.distorted.org.uk/u/mdw/catacomb/blobdiff_plain/a351d052dda03a2cc1af01dcef4640891f551ada..59919ae4b1721ca271c3d3e5955c09d322573821:/ghash.h diff --git a/ghash.h b/ghash.h index 85b3d7f..9d63419 100644 --- a/ghash.h +++ b/ghash.h @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: ghash.h,v 1.3 2000/07/02 18:27:42 mdw Exp $ + * $Id: ghash.h,v 1.6 2004/04/04 19:42:30 mdw Exp $ * * Generic hash function interface * @@ -30,6 +30,15 @@ /*----- Revision history --------------------------------------------------* * * $Log: ghash.h,v $ + * Revision 1.6 2004/04/04 19:42:30 mdw + * Make tables of standard encryption schemes etc. + * + * Revision 1.5 2000/07/15 10:00:58 mdw + * New generic hash operation for copying hash contexts. + * + * Revision 1.4 2000/07/03 18:08:24 mdw + * Include `bits.h'. + * * Revision 1.3 2000/07/02 18:27:42 mdw * (ghash->ops->done): Interface change. Passing in a null buffer pointer * uses a buffer internal to the ghash object. The operation returns the @@ -55,6 +64,8 @@ #include +#include + /*----- Generic hash function interface -----------------------------------*/ typedef struct ghash { @@ -66,14 +77,36 @@ typedef struct ghash_ops { void (*hash)(ghash */*h*/, const void */*p*/, size_t /*sz*/); /* Hash */ octet *(*done)(ghash */*h*/, void */*buf*/); /* Write result */ void (*destroy)(ghash */*h*/); /* Destroy hash block */ + ghash *(*copy)(ghash */*h*/); /* Make a copy of the hash context */ } ghash_ops; +#define GH_INIT(ch) (ch)->init() +#define GH_CLASS(H) (h)->ops->c +#define GH_HASH(h, p, sz) (h)->ops->hash((h), (p), (sz)) +#define GH_DONE(h, buf) (h)->ops->done((h), (buf)) +#define GH_DESTROY(h) (h)->ops->destroy((h)) +#define GH_COPY(h) (h)->ops->copy((h)) + typedef struct gchash { const char *name; /* Name of the hash function */ size_t hashsz; /* Size of output hash */ ghash *(*init)(void); /* Create a new hash instance */ + size_t bufsz; /* Buffer size, or zero */ } gchash; +/*----- Tables ------------------------------------------------------------*/ + +extern const gchash *const ghashtab[]; + +/* --- @ghash_byname@ --- * + * + * Arguments: @const char *p@ = pointer to name string + * + * Returns: The named cipher class, or null. + */ + +extern const gchash *ghash_byname(const char */*p*/); + /*----- That's all, folks -------------------------------------------------*/ #ifdef __cplusplus