friend class PDU_AssocThread;
PDU_Assoc_priv *m_p;
IPDU_Observer *m_PDU_Observer;
-
int flush_PDU();
- COMSTACK comstack(const char *type_and_host, void **vp);
public:
- /// Create object using specified socketObservable
PDU_Assoc(yazpp_1::ISocketObservable *socketObservable);
- /// Create Object using existing comstack
- PDU_Assoc(yazpp_1::ISocketObservable *socketObservable,
- COMSTACK cs);
- /// virtual ~PDU_Assoc();
+
+ PDU_Assoc(yazpp_1::ISocketObservable *socketObservable, COMSTACK cs);
+
virtual ~PDU_Assoc();
- /// Clone the object
+
+ // optional feature implemented by PDU_Assoc (also by PDU_Asso_Thread)
+ virtual void childNotify(COMSTACK cs);
+
+ // mefhods below are from IPDU_Observable
IPDU_Observable *clone();
- /// Send PDU
int send_PDU(const char *buf, int len);
- /// connect to server (client role)
int connect(IPDU_Observer *observer, const char *addr);
- /// listen for clients (server role)
int listen(IPDU_Observer *observer, const char *addr);
- /// Socket notification
void socketNotify(int event);
- /// Close socket
void shutdown();
- /// Close and destroy
void destroy();
- /// Set Idle Time
void idleTime(int timeout);
- /// Child start...
- virtual void childNotify(COMSTACK cs);
- /// close session
void close_session();
const char *getpeername();
};
int idleTime;
int log;
void init(yazpp_1::ISocketObservable *socketObservable);
+ COMSTACK comstack(const char *type_and_host, void **vp);
bool m_session_is_dead;
};
}
return 0;
}
-COMSTACK PDU_Assoc::comstack(const char *type_and_host, void **vp)
+COMSTACK PDU_Assoc_priv::comstack(const char *type_and_host, void **vp)
{
return cs_create_host(type_and_host, 2, vp);
}
m_PDU_Observer = observer;
void *ap;
- m_p->cs = comstack(addr, &ap);
+ m_p->cs = m_p->comstack(addr, &ap);
if (!m_p->cs)
return -1;
shutdown();
m_PDU_Observer = observer;
void *ap;
- m_p->cs = comstack(addr, &ap);
+ m_p->cs = m_p->comstack(addr, &ap);
if (!m_p->cs)
return -1;
int res = cs_connect(m_p->cs, ap);