X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=include%2Fcomstack.h;h=ee8ebd71aa8f84dbf435c4c31ae43a7af101524e;hp=b5e53896a0ffc65457b34b27d0bf571c6876ecf3;hb=bf4149c63ad2e11429e302a89f472de52b4d7ce8;hpb=9c459af695605b44a044ad206562818be10034f1 diff --git a/include/comstack.h b/include/comstack.h index b5e5389..ee8ebd7 100644 --- a/include/comstack.h +++ b/include/comstack.h @@ -24,7 +24,25 @@ * OF THIS SOFTWARE. * * $Log: comstack.h,v $ - * Revision 1.10 1995-09-29 17:01:48 quinn + * Revision 1.16 1997-05-14 06:53:37 adam + * C++ support. + * + * Revision 1.15 1996/07/06 19:58:32 quinn + * System headerfiles gathered in yconfig + * + * Revision 1.14 1996/02/10 12:23:41 quinn + * Enable inetd operations fro TCP/IP stack + * + * Revision 1.13 1995/11/01 13:54:33 quinn + * Minor adjustments + * + * Revision 1.12 1995/10/30 12:41:27 quinn + * Added hostname lookup for server. + * + * Revision 1.11 1995/09/29 17:12:01 quinn + * Smallish + * + * Revision 1.10 1995/09/29 17:01:48 quinn * More Windows work * * Revision 1.9 1995/09/28 10:12:36 quinn @@ -96,15 +114,20 @@ #ifndef COMSTACK_H #define COMSTACK_H +#define YNETINCLUDE #include #include -#include +#include + +#ifdef __cplusplus +extern "C" { +#endif #define COMSTACK_DEFAULT_TIMEOUT -1 /* not used yet */ struct comstack; typedef struct comstack *COMSTACK; -typedef COMSTACK (*CS_TYPE)(int blocking, int protocol); +typedef COMSTACK (*CS_TYPE)(int s, int blocking, int protocol); struct comstack { @@ -113,7 +136,7 @@ struct comstack char *stackerr;/* current lower-layer error string, or null if none */ int iofile; /* UNIX file descriptor for iochannel */ int timeout; /* how long to wait for trailing blocks (ignored for now) */ - void *private; /* state info for lower stack */ + void *cprivate;/* state info for lower stack */ int more; /* connection has extra data in buffer */ int state; /* current state */ #define CS_UNBND 0 @@ -142,6 +165,7 @@ struct comstack int (*f_listen)(COMSTACK handle, char *addrp, int *addrlen); COMSTACK (*f_accept)(COMSTACK handle); int (*f_close)(COMSTACK handle); + char *(*f_addrstr)(COMSTACK handle); }; #define cs_put(handle, buf, size) ((*(handle)->f_put)(handle, buf, size)) @@ -153,15 +177,18 @@ struct comstack #define cs_listen(handle, ap, al) ((*(handle)->f_listen)(handle, ap, al)) #define cs_accept(handle) ((*(handle)->f_accept)(handle)) #define cs_close(handle) ((*(handle)->f_close)(handle)) -#define cs_create(type, blocking, proto) ((*type)(blocking, proto)) +#define cs_create(type, blocking, proto) ((*type)(-1, blocking, proto)) +#define cs_createbysocket(sock, type, blocking, proto) \ + ((*type)(sock, blocking, proto)) #define cs_type(handle) ((handle)->type) #define cs_fileno(handle) ((handle)->iofile) #define cs_stackerr(handle) ((handle)->stackerr) #define cs_getstate(handle) ((handle)->getstate) #define cs_errno(handle) ((handle)->cerrno) #define cs_getproto(handle) ((handle)->protocol) +#define cs_addrstr(handle) ((*(handle)->f_addrstr)(handle)) -const char MDF *cs_strerror(COMSTACK h); +const char *cs_strerror(COMSTACK h); const char *cs_errmsg(int n); /* @@ -180,4 +207,8 @@ extern char *cs_errlist[]; #define CS_SR PROTO_SR #define CS_Z3950 PROTO_Z3950 +#ifdef __cplusplus +} +#endif + #endif