X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fyaz-pdu-assoc.h;h=6576bb1728e30030e76ec3223ec40b873459dd19;hb=9ada255ef9d4261a79d9ccae6c1bfedf456087ce;hp=425a230b2a91a964eb8bed4d8d61caa3fc477591;hpb=97118338f9ac93e767e5589d449d3f9abacb3190;p=yazpp-moved-to-github.git diff --git a/include/yaz-pdu-assoc.h b/include/yaz-pdu-assoc.h index 425a230..6576bb1 100644 --- a/include/yaz-pdu-assoc.h +++ b/include/yaz-pdu-assoc.h @@ -1,19 +1,14 @@ /* - * Copyright (c) 1998-1999, Index Data. + * Copyright (c) 1998-2000, Index Data. * See the file LICENSE for details. - * Sebastian Hammer, Adam Dickmeiss * - * $Log: yaz-pdu-assoc.h,v $ - * Revision 1.2 1999-01-28 13:08:40 adam - * Yaz_PDU_Assoc better encapsulated. Memory leak fix in - * yaz-socket-manager.cc. - * - * Revision 1.1.1.1 1999/01/28 09:41:07 adam - * First implementation of YAZ++. - * + * $Id: yaz-pdu-assoc.h,v 1.11 2000-09-12 16:40:33 heikki Exp $ */ -#include +#ifndef YAZ_PDU_ASSOC_INCLUDED +#define YAZ_PDU_ASSOC_INCLUDED + +#include #include #include @@ -23,9 +18,9 @@ the method connect. The server role is initiated by using the listen method. */ -class Yaz_PDU_Assoc : public IYaz_PDU_Observable, IYazSocketObserver { +class YAZ_EXPORT Yaz_PDU_Assoc : public IYaz_PDU_Observable, IYazSocketObserver { private: - enum { Connecting, Connected, Listen, Ready, Closed } m_state; + enum { Connecting, Listen, Ready, Closed } m_state; class PDU_Queue { public: PDU_Queue(const char *buf, int len); @@ -37,7 +32,6 @@ class Yaz_PDU_Assoc : public IYaz_PDU_Observable, IYazSocketObserver { Yaz_PDU_Assoc *m_parent; Yaz_PDU_Assoc *m_children; Yaz_PDU_Assoc *m_next; - COMSTACK Yaz_PDU_Assoc::comstack(); COMSTACK m_cs; IYazSocketObservable *m_socketObservable; IYaz_PDU_Observer *m_PDU_Observer; @@ -46,11 +40,14 @@ class Yaz_PDU_Assoc : public IYaz_PDU_Observable, IYazSocketObserver { PDU_Queue *m_queue_out; int Yaz_PDU_Assoc::flush_PDU(); int *m_destroyed; + int m_idleTime; + int m_log; public: + COMSTACK comstack(); /// Create object using specified socketObservable - Yaz_PDU_Assoc(IYazSocketObservable *socketObservable, COMSTACK cs); + Yaz_PDU_Assoc(IYazSocketObservable *socketObservable); /// Close socket and destroy object. - virtual ~Yaz_PDU_Assoc(); + /// virtual ~Yaz_PDU_Assoc(); /// Clone the object IYaz_PDU_Observable *clone(); /// Send PDU @@ -59,10 +56,18 @@ class Yaz_PDU_Assoc : public IYaz_PDU_Observable, IYazSocketObserver { void connect(IYaz_PDU_Observer *observer, const char *addr); /// listen for clients (server role) void listen(IYaz_PDU_Observer *observer, const char *addr); + /// open with existing socket + void socket(IYaz_PDU_Observer *observer, int fd); /// Socket notification void socketNotify(int event); /// Close socket void close(); /// Close and destroy void destroy(); + /// Set Idle Time + void idleTime (int timeout); + /// Child start... + virtual void childNotify(int fd); }; + +#endif \ No newline at end of file