X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/mLib/blobdiff_plain/3fd896a441c904c3f3608dba41d5e1db84fad776..573eadb534c42c4feace5e493cc135dd5e7b00d9:/pkbuf.h diff --git a/pkbuf.h b/pkbuf.h index 00c437b..3305992 100644 --- a/pkbuf.h +++ b/pkbuf.h @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: pkbuf.h,v 1.3 2001/02/03 16:23:33 mdw Exp $ + * $Id: pkbuf.h,v 1.4 2002/01/13 13:33:51 mdw Exp $ * * Simple packet buffering * @@ -30,6 +30,9 @@ /*----- Revision history --------------------------------------------------* * * $Log: pkbuf.h,v $ + * Revision 1.4 2002/01/13 13:33:51 mdw + * Packet handler functions now have a @typedef@ name. + * * Revision 1.3 2001/02/03 16:23:33 mdw * Bug fix: handle a disable during a close-induced flush without dumping * core. @@ -63,14 +66,18 @@ /*----- Data structures ---------------------------------------------------*/ +struct pkbuf; + +typedef void pkbuf_func(octet */*b*/, size_t /*sz*/, + struct pkbuf */*pk*/, size_t */*keep*/, + void */*p*/); + typedef struct pkbuf { size_t sz; /* Size of current buffer */ size_t len; /* Length of data in the buffer */ size_t want; /* Want this many bytes for packet */ unsigned f; /* Various state flags */ - void (*func)(octet */*b*/, size_t /*sz*/, - struct pkbuf */*pk*/, size_t */*keep*/, - void */*p*/); /* Handler function */ + pkbuf_func *func; /* Handler function */ void *p; /* Argument for handler */ arena *a; /* Memory allocation arena */ octet *buf; /* Actual buffer space */ @@ -164,9 +171,7 @@ extern void pkbuf_want(pkbuf */*pk*/, size_t /*want*/); /* --- @pkbuf_init@ --- * * * Arguments: @pkbuf *pk@ = pointer to buffer block - * @void (*func)(octet *b, size_t sz, pkbuf *pk,@ - * @size_t *keep, void *p)@ = - * handler function + * @pkbuf_func *func@ = handler function * @void *p@ = argument pointer for @func@ * * Returns: --- @@ -175,11 +180,7 @@ extern void pkbuf_want(pkbuf */*pk*/, size_t /*want*/); * the provided function for handling. */ -extern void pkbuf_init(pkbuf */*pk*/, - void (*/*func*/)(octet */*b*/, size_t /*sz*/, - pkbuf */*pk*/, size_t */*keep*/, - void */*p*/), - void */*p*/); +extern void pkbuf_init(pkbuf */*pk*/, pkbuf_func */*func*/, void */*p*/); /* --- @pkbuf_destroy@ --- * *