X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=chiark-tcl.git;a=blobdiff_plain;f=hbytes%2Fhbytes.h;h=b49301f02a935950b0c9a17c725ce395dde0671e;hp=2b032877587cebcf815a987fd8883edcc2da9293;hb=9b2c18cc9d122b45f9e737864921d32baa599f0c;hpb=9e72d3c3d91b86842aa947297e0d30bbc741c7b1 diff --git a/hbytes/hbytes.h b/hbytes/hbytes.h index 2b03287..b49301f 100644 --- a/hbytes/hbytes.h +++ b/hbytes/hbytes.h @@ -215,10 +215,9 @@ void scriptinv_invoke(ScriptToInvoke *si, int argc, Tcl_Obj **argv); /* from idtable.c */ typedef struct { - const char *const prefix; - int n; - void **a; -} IdDataTable; + const char *valprefix, *assockey; + void (*destroyitem)(Tcl_Interp *ip, void *val); +} IdDataSpec; /* The stored struct must start with a single int, conventionally * named `ix'. When the struct is returned for the first time ix must @@ -226,10 +225,10 @@ typedef struct { * the struct is registered by the iddatatable machinery. */ extern Tcl_ObjType tabledataid_nearlytype; -int tabledataid_parse(Tcl_Interp *ip, Tcl_Obj *o, IdDataTable *tab); -void tabledataid_disposing(void *val, IdDataTable *tab); +int tabledataid_parse(Tcl_Interp *ip, Tcl_Obj *o, const IdDataSpec *idds); +void tabledataid_disposing(Tcl_Interp *ip, void *val, const IdDataSpec *idds); /* call this when you destroy the struct, to remove its name; - * _disposing is idempotent*/ + * _disposing is idempotent */ /* from adns.c */ @@ -238,16 +237,16 @@ typedef struct { adns_rrtype number; } AdnsTclRRTypeInfo; -extern IdDataTable adnstcl_queries, adnstcl_resolvers; +extern const IdDataSpec adnstcl_queries, adnstcl_resolvers; /* from dgram.c */ -extern IdDataTable dgram_socks; +extern const IdDataSpec dgram_socks; int newfdposixerr(Tcl_Interp *ip, int fd, const char *m); /* from tuntap.c */ -extern IdDataTable tuntap_socks; +extern const IdDataSpec tuntap_socks; /* from hook.c */