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.1 2001-03-26 14:43:49 adam
7 * New threaded PDU association.
12 #include <yaz/tcpip.h>
14 #include <yaz++/yaz-pdu-assoc.h>
15 #include <yaz++/yaz-socket-manager.h>
24 Yaz_PDU_AssocThread::Yaz_PDU_AssocThread(
25 IYazSocketObservable *socketObservable)
26 : Yaz_PDU_Assoc(socketObservable)
38 Yaz_SocketManager *s = (Yaz_SocketManager *) p;
40 logf (LOG_LOG, "thread started");
41 while (s->processEvent() > 0)
43 logf (LOG_LOG, "thread finished");
50 void Yaz_PDU_AssocThread::childNotify(COMSTACK cs)
52 Yaz_SocketManager *socket_observable = new Yaz_SocketManager;
53 Yaz_PDU_Assoc *new_observable = new Yaz_PDU_Assoc (socket_observable, cs);
55 /// Clone PDU Observer
56 new_observable->m_PDU_Observer =
57 m_PDU_Observer->sessionNotify(new_observable, cs_fileno(cs));
60 t_id = _beginthread (events, 0, socket_observable);
63 yaz_log (LOG_FATAL|LOG_ERRNO, "_beginthread failed");
69 int id = pthread_create (&type, 0, events, socket_observable);
70 yaz_log (LOG_LOG, "pthread_create returned id=%d", id);