ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/iom.h
Revision: 1.28
Committed: Wed May 31 00:32:56 2006 UTC (17 years, 11 months ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.27: +12 -12 lines
Log Message:
updated callback.h/iom.h from gvpe

File Contents

# User Rev Content
1 pcg 1.1 /*
2 root 1.20 iom.h -- generic I/O multiplexer
3 root 1.26 Copyright (C) 2003-2006 Marc Lehmann <gvpe@schmorp.de>
4 pcg 1.1
5 root 1.23 This file is part of GVPE.
6    
7     GVPE is free software; you can redistribute it and/or modify
8 pcg 1.1 it under the terms of the GNU General Public License as published by
9     the Free Software Foundation; either version 2 of the License, or
10     (at your option) any later version.
11    
12     This program is distributed in the hope that it will be useful,
13     but WITHOUT ANY WARRANTY; without even the implied warranty of
14     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15     GNU General Public License for more details.
16    
17     You should have received a copy of the GNU General Public License
18 root 1.23 along with gvpe; if not, write to the Free Software
19 root 1.22 Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 pcg 1.1 */
21    
22 pcg 1.7 #ifndef IOM_H__
23     #define IOM_H__
24 pcg 1.1
25 pcg 1.7 // required:
26     // - a vector template like simplevec or stl's vector
27     // - defines for all watcher types required in your app
28     // edit iom_conf.h as appropriate.
29     #include "iom_conf.h"
30 pcg 1.1
31 root 1.25 #if IOM_CHILD
32     # undef IOM_SIG
33     # define IOM_SIG 1
34     #endif
35    
36 pcg 1.6 #include "callback.h"
37 pcg 1.1
38 pcg 1.6 typedef double tstamp;
39     extern tstamp NOW;
40 pcg 1.2
41 root 1.23 // TSTAMP_MAX must still fit into a positive struct timeval
42     #define TSTAMP_MAX (double)(1UL<<31)
43    
44 pcg 1.7 struct watcher;
45 pcg 1.2 #if IOM_IO
46 pcg 1.7 struct io_watcher;
47 pcg 1.2 #endif
48     #if IOM_TIME
49 pcg 1.7 struct time_watcher;
50 pcg 1.2 #endif
51     #if IOM_CHECK
52 pcg 1.7 struct check_watcher;
53 pcg 1.2 #endif
54 pcg 1.5 #if IOM_IDLE
55 pcg 1.7 struct idle_watcher;
56 pcg 1.5 #endif
57 pcg 1.12 #if IOM_SIG
58     struct sig_watcher;
59     #endif
60 root 1.25 #if IOM_CHILD
61     struct child_watcher;
62     #endif
63 pcg 1.1
64 pcg 1.6 template<class watcher>
65 pcg 1.10 struct io_manager_vec : vector<watcher *> {
66 pcg 1.6 void erase_unordered (unsigned int pos)
67     {
68 root 1.13 watcher *w = (*this)[this->size () - 1];
69     this->pop_back ();
70 pcg 1.6
71 root 1.20 if (!this->empty ())
72     if (((*this)[pos] = w)) // '=' is correct!
73 pcg 1.6 w->active = pos + 1;
74     }
75     };
76    
77 root 1.15 // only used as a namespace, and for initialisation purposes
78 pcg 1.2 class io_manager {
79     template<class watcher>
80 root 1.15 static void reg (watcher &w, io_manager_vec<watcher> &queue);
81 pcg 1.1
82 pcg 1.2 template<class watcher>
83 root 1.15 static void unreg (watcher &w, io_manager_vec<watcher> &queue);
84 pcg 1.1
85     public:
86 root 1.21 #if IOM_TIME
87     // fetch time only
88     static tstamp now ();
89    
90     // set NOW
91     static void set_now ();
92     #endif
93    
94 pcg 1.1 // register a watcher
95 pcg 1.2 #if IOM_IO
96 root 1.15 static void reg (io_watcher &w); static void unreg (io_watcher &w);
97 pcg 1.2 #endif
98     #if IOM_TIME
99 root 1.15 static void reg (time_watcher &w); static void unreg (time_watcher &w);
100 pcg 1.2 #endif
101     #if IOM_CHECK
102 root 1.15 static void reg (check_watcher &w); static void unreg (check_watcher &w);
103 pcg 1.2 #endif
104 pcg 1.5 #if IOM_IDLE
105 root 1.15 static void reg (idle_watcher &w); static void unreg (idle_watcher &w);
106 pcg 1.5 #endif
107 pcg 1.12 #if IOM_SIG
108 root 1.15 static void reg (sig_watcher &w); static void unreg (sig_watcher &w);
109 pcg 1.12 #endif
110 root 1.25 #if IOM_CHILD
111     static void reg (child_watcher &w); static void unreg (child_watcher &w);
112     #endif
113 pcg 1.1
114 root 1.15 static void loop ();
115 pcg 1.1 };
116    
117 pcg 1.6 struct watcher {
118     int active; /* 0 == inactive, else index into respective vector */
119    
120 root 1.27 bool is_active () { return active; }
121    
122 pcg 1.11 watcher () : active (0) { }
123 pcg 1.6 };
124    
125 pcg 1.2 #if IOM_IO
126 root 1.24 enum { EVENT_UNDEF = -1, EVENT_NONE = 0, EVENT_READ = 1, EVENT_WRITE = 2 };
127 pcg 1.1
128 root 1.28 struct io_watcher : watcher, callback<void (io_watcher &, short)> {
129 pcg 1.1 int fd;
130     short events;
131    
132 pcg 1.5 void set (int fd_, short events_) { fd = fd_; events = events_; }
133 pcg 1.1
134 pcg 1.5 void set (short events_) { set (fd, events_); }
135 root 1.15 void start () { io_manager::reg (*this); }
136     void start (int fd_, short events_) { set (fd_, events_); io_manager::reg (*this); }
137     void stop () { io_manager::unreg (*this); }
138 pcg 1.6
139     template<class O1, class O2>
140 pcg 1.11 io_watcher (O1 *object, void (O2::*method) (io_watcher &, short))
141 root 1.28 : callback<void (io_watcher &, short)> (object, method)
142 pcg 1.6 { }
143     ~io_watcher () { stop (); }
144 pcg 1.1 };
145 pcg 1.2 #endif
146 pcg 1.1
147 pcg 1.2 #if IOM_TIME
148 root 1.28 struct time_watcher : watcher, callback<void (time_watcher &)> {
149 pcg 1.1 tstamp at;
150    
151     void trigger ();
152    
153     void set (tstamp when) { at = when; }
154 pcg 1.11 void operator () () { trigger (); }
155 root 1.15 void start () { io_manager::reg (*this); }
156     void start (tstamp when) { set (when); io_manager::reg (*this); }
157     void stop () { io_manager::unreg (*this); }
158 pcg 1.1
159 pcg 1.6 template<class O1, class O2>
160 pcg 1.11 time_watcher (O1 *object, void (O2::*method) (time_watcher &))
161 root 1.28 : callback<void (time_watcher &)> (object, method), at (0)
162 pcg 1.6 { }
163     ~time_watcher () { stop (); }
164 pcg 1.1 };
165 pcg 1.2 #endif
166    
167     #if IOM_CHECK
168     // run before checking for new events
169 root 1.28 struct check_watcher : watcher, callback<void (check_watcher &)> {
170 root 1.15 void start () { io_manager::reg (*this); }
171     void stop () { io_manager::unreg (*this); }
172 pcg 1.6
173 pcg 1.2 template<class O1, class O2>
174 pcg 1.11 check_watcher (O1 *object, void (O2::*method) (check_watcher &))
175 root 1.28 : callback<void (check_watcher &)> (object, method)
176 pcg 1.6 { }
177     ~check_watcher () { stop (); }
178 pcg 1.5 };
179     #endif
180    
181     #if IOM_IDLE
182     // run after checking for any i/o, but before waiting
183 root 1.28 struct idle_watcher : watcher, callback<void (idle_watcher &)> {
184 root 1.15 void start () { io_manager::reg (*this); }
185     void stop () { io_manager::unreg (*this); }
186 pcg 1.6
187 pcg 1.5 template<class O1, class O2>
188 pcg 1.11 idle_watcher (O1 *object, void (O2::*method) (idle_watcher &))
189 root 1.28 : callback<void (idle_watcher &)> (object, method)
190 pcg 1.5 { }
191 pcg 1.6 ~idle_watcher () { stop (); }
192 pcg 1.2 };
193     #endif
194 pcg 1.1
195 pcg 1.12 #if IOM_SIG
196 root 1.28 struct sig_watcher : watcher, callback<void (sig_watcher &)> {
197 pcg 1.12 int signum;
198    
199     void start (int signum);
200 root 1.15 void stop () { io_manager::unreg (*this); }
201 pcg 1.12
202     template<class O1, class O2>
203     sig_watcher (O1 *object, void (O2::*method) (sig_watcher &))
204 root 1.28 : callback<void(sig_watcher &)> (object, method), signum (0)
205 pcg 1.12 { }
206     ~sig_watcher () { stop (); }
207     };
208     #endif
209    
210 root 1.25 #if IOM_CHILD
211 root 1.28 struct child_watcher : watcher, callback<void (child_watcher &, int)> {
212 root 1.25 int /*pid_t*/ pid;
213    
214     void start (int pid) { this->pid = pid; io_manager::reg (*this); }
215     void stop () { io_manager::unreg (*this); }
216    
217     template<class O1, class O2>
218     child_watcher (O1 *object, void (O2::*method) (child_watcher &, int status))
219 root 1.28 : callback<void (child_watcher &, int)> (object, method), pid (0)
220 root 1.25 { }
221     ~child_watcher () { stop (); }
222     };
223     #endif
224    
225 pcg 1.1 #endif
226