summaryrefslogtreecommitdiff
path: root/comm/TkMultiplexer.cc
blob: 3272851f5074d38986f43f23f8f9a1382c8e0446 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
 *	The Unix Channel
 *
 *	by Michel Beaudouin-Lafon and Stephane Chatty
 *
 *	Copyright 1990-1993
 *	Laboratoire de Recherche en Informatique (LRI)
 *	Centre d'Etudes de la Navigation Aerienne
 *
 *	Tk-based multiplexers
 *
 *	$Id$
 *	$CurLog$
 */

#include "TkMultiplexer.h"
#include "error.h"

#include <memory.h>

static void
ioHandler (ClientData client_data, int mask)
{
	UchChannel* ch = (UchChannel*) client_data;
	if (mask & TK_WRITABLE)
		ch->HandleWrite ();
	if (mask & TK_READABLE)
		ch->HandleRead ();
}

UchTkMultiplexer :: UchTkMultiplexer ()
: UchBaseMultiplexer ()
{
	memset (Active, 0, NFILE * sizeof (bool));
}


UchTkMultiplexer :: ~UchTkMultiplexer ()
{
}

void
UchTkMultiplexer :: SetMasks (int fd, IOMODE mode)
{
	UchChannel* ch = Channels [fd];
	if (!ch)
		return;

	/* remove if already there */
	if (Active [fd]) {
		Tk_DeleteFileHandler (fd);
		ReadCount--;
	}

	/* add channel */
	int mask = 0;

	if (mode & IORead)
		mask |= TK_READABLE;

	if (mode & IOWrite)
		mask |= TK_WRITABLE;

	if (mode & IOSelect)
		Error (ErrWarn, "AddChannel", "select condition ignored");

	if (mask) {
		Tk_CreateFileHandler (fd, mask, ioHandler, (ClientData) ch);
		ReadCount++;
		Active [fd] = TRUE;
	}
}

void
UchTkMultiplexer :: FireTimers (ClientData mpx)
{
	CcuCoreTimer::Fire (((UchTkMultiplexer*) mpx)->GetTimerSet ());
}

void
UchTkMultiplexer :: SetTimeOut (Millisecond delay)
{
	TimeOut = Tk_CreateTimerHandler (int (delay), &UchTkMultiplexer::FireTimers, (ClientData) this);
}

void
UchTkMultiplexer :: SuppressTimeOut ()
{
	Tk_DeleteTimerHandler (TimeOut);
	TimeOut = 0;
}

void
UchTkMultiplexer :: FireSignals (ClientData mpx)
{
	((UchTkMultiplexer*) mpx)->HandleDeferredSignals ();
}

void
UchTkMultiplexer :: AddSignalHook ()
{
	Tk_DoWhenIdle (&UchTkMultiplexer::FireSignals, (ClientData) this);
}
		
MPX_RES
UchTkMultiplexer :: Loop ()
{
	Looping = TRUE;

	Tk_MainLoop ();

	if (Looping) {
		Looping = FALSE;
		return isMpxEmpty;
	}
	return isMpxTerminated;
}