X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fcomstack.h;h=ee8ebd71aa8f84dbf435c4c31ae43a7af101524e;hb=a00dfa73d5d3796f8048f2134fec2685b62e2658;hp=e14b8eaf537858be38903464bfcb16b0eda4a90f;hpb=63cafe41a93427118959a74201b3e331169a71d9;p=yaz-moved-to-github.git diff --git a/include/comstack.h b/include/comstack.h index e14b8ea..ee8ebd7 100644 --- a/include/comstack.h +++ b/include/comstack.h @@ -24,7 +24,22 @@ * OF THIS SOFTWARE. * * $Log: comstack.h,v $ - * Revision 1.11 1995-09-29 17:12:01 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 @@ -99,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 { @@ -116,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 @@ -145,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)) @@ -156,13 +177,16 @@ 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 *cs_strerror(COMSTACK h); const char *cs_errmsg(int n); @@ -183,4 +207,8 @@ extern char *cs_errlist[]; #define CS_SR PROTO_SR #define CS_Z3950 PROTO_Z3950 +#ifdef __cplusplus +} +#endif + #endif