2 * Copyright (c) 1998-2001, Index Data.
3 * See the file LICENSE for details.
5 * $Log: yaz-pdu-assoc-thread.cpp,v $
6 * Revision 1.2 2001-03-27 14:47:45 adam
7 * New server facility scheme.
9 * Revision 1.1 2001/03/26 14:43:49 adam
10 * New threaded PDU association.
24 #include <yaz/tcpip.h>
26 #include <yaz++/yaz-pdu-assoc.h>
27 #include <yaz++/yaz-socket-manager.h>
31 Yaz_PDU_AssocThread::Yaz_PDU_AssocThread(
32 IYazSocketObservable *socketObservable)
33 : Yaz_PDU_Assoc(socketObservable)
45 Yaz_SocketManager *s = (Yaz_SocketManager *) p;
47 logf (LOG_LOG, "thread started");
48 while (s->processEvent() > 0)
50 logf (LOG_LOG, "thread finished");
57 void Yaz_PDU_AssocThread::childNotify(COMSTACK cs)
59 Yaz_SocketManager *socket_observable = new Yaz_SocketManager;
60 Yaz_PDU_Assoc *new_observable = new Yaz_PDU_Assoc (socket_observable, cs);
62 /// Clone PDU Observer
63 new_observable->m_PDU_Observer =
64 m_PDU_Observer->sessionNotify(new_observable, cs_fileno(cs));
67 t_id = _beginthread (events, 0, socket_observable);
70 yaz_log (LOG_FATAL|LOG_ERRNO, "_beginthread failed");
76 int id = pthread_create (&tid, 0, events, socket_observable);
78 yaz_log (LOG_ERRNO|LOG_FATAL, "pthread_create returned id=%d", id);