Commit 9475035103cd17a79c6ef7a7374b7b01bad26483
1 parent
08f6b59a
Exists in
master
and in
1 other branch
Updating I/O Sources. Starting split of windows/linux sources.
Showing
6 changed files
with
266 additions
and
339 deletions
Show diff stats
Makefile.in
gitsync.sh
src/v3270/iocallback.c
... | ... | @@ -1,322 +0,0 @@ |
1 | -/* | |
2 | - * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
3 | - * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
4 | - * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
5 | - * | |
6 | - * Copyright (C) <2008> <Banco do Brasil S.A.> | |
7 | - * | |
8 | - * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
9 | - * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
10 | - * Free Software Foundation. | |
11 | - * | |
12 | - * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
13 | - * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
14 | - * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
15 | - * obter mais detalhes. | |
16 | - * | |
17 | - * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
18 | - * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
19 | - * St, Fifth Floor, Boston, MA 02110-1301 USA | |
20 | - * | |
21 | - * Este programa está nomeado como iocallback.c e possui - linhas de código. | |
22 | - * | |
23 | - * Contatos: | |
24 | - * | |
25 | - * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
26 | - * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
27 | - * licinio@bb.com.br (Licínio Luis Branco) | |
28 | - * kraucer@bb.com.br (Kraucer Fernandes Mazuco) | |
29 | - * | |
30 | - */ | |
31 | - | |
32 | - #include <config.h> | |
33 | - | |
34 | - #define ENABLE_NLS | |
35 | - #define GETTEXT_PACKAGE PACKAGE_NAME | |
36 | - | |
37 | - #include <gtk/gtk.h> | |
38 | - #include <libintl.h> | |
39 | - #include <glib/gi18n.h> | |
40 | - | |
41 | -#if defined(_WIN32) /*[*/ | |
42 | - #include <windows.h> | |
43 | -#elif defined(__APPLE__) | |
44 | - #include <poll.h> | |
45 | - #include <string.h> | |
46 | -#else | |
47 | - #include <poll.h> | |
48 | - #include <string.h> | |
49 | -#endif /*]*/ | |
50 | - | |
51 | -#include <lib3270.h> | |
52 | -#include <v3270.h> | |
53 | -#include <stdio.h> | |
54 | -#include <glib.h> | |
55 | - | |
56 | -static void * static_AddSource(H3270 *session, int fd, LIB3270_IO_FLAG flag, void(*proc)(H3270 *, int, LIB3270_IO_FLAG, void *), void *userdata); | |
57 | -static void static_RemoveSource(H3270 *session, void *id); | |
58 | - | |
59 | -static void * static_AddTimeOut(H3270 *session, unsigned long interval_ms, void (*proc)(H3270 *session)); | |
60 | -static void static_RemoveTimeOut(H3270 *session, void * timer); | |
61 | -static int static_Sleep(H3270 *hSession, int seconds); | |
62 | -static int static_RunPendingEvents(H3270 *hSession, int wait); | |
63 | - | |
64 | -static gboolean IO_prepare(GSource *source, gint *timeout); | |
65 | -static gboolean IO_check(GSource *source); | |
66 | -static gboolean IO_dispatch(GSource *source, GSourceFunc callback, gpointer user_data); | |
67 | -static void IO_finalize(GSource *source); /* Can be NULL */ | |
68 | -static gboolean IO_closure(gpointer data); | |
69 | - | |
70 | -/*---[ Structs ]-------------------------------------------------------------------------------------------*/ | |
71 | - | |
72 | - typedef struct _IO_Source | |
73 | - { | |
74 | - GSource gsrc; | |
75 | - GPollFD poll; | |
76 | - int fd; | |
77 | - void (*call)(H3270 *, int, LIB3270_IO_FLAG, void *); | |
78 | - H3270 *session; | |
79 | - void *userdata; | |
80 | - } IO_Source; | |
81 | - | |
82 | - typedef struct _timer | |
83 | - { | |
84 | - unsigned char remove; | |
85 | - void * userdata; | |
86 | - void (*call)(H3270 *session); | |
87 | - H3270 * session; | |
88 | - } TIMER; | |
89 | - | |
90 | - static GSourceFuncs IOSources = | |
91 | - { | |
92 | - IO_prepare, | |
93 | - IO_check, | |
94 | - IO_dispatch, | |
95 | - IO_finalize, | |
96 | - IO_closure, | |
97 | - NULL | |
98 | - }; | |
99 | - | |
100 | -/*---[ Implement ]-----------------------------------------------------------------------------------------*/ | |
101 | - | |
102 | -static void * static_AddSource(H3270 *session, int fd, LIB3270_IO_FLAG flag, void(*call)(H3270 *, int, LIB3270_IO_FLAG, void *), void *userdata) | |
103 | -{ | |
104 | - IO_Source *src = (IO_Source *) g_source_new(&IOSources,sizeof(IO_Source)); | |
105 | - | |
106 | - src->fd = fd; | |
107 | - src->call = call; | |
108 | - src->userdata = userdata; | |
109 | - src->session = session; | |
110 | - | |
111 | - src->poll.fd = (int) fd; | |
112 | - src->poll.events = G_IO_HUP|G_IO_ERR; | |
113 | - | |
114 | - if(flag & LIB3270_IO_FLAG_READ) | |
115 | - src->poll.events |= G_IO_IN; | |
116 | - | |
117 | - if(flag & LIB3270_IO_FLAG_WRITE) | |
118 | - src->poll.events |= G_IO_OUT; | |
119 | - | |
120 | - g_source_attach((GSource *) src,NULL); | |
121 | - g_source_add_poll((GSource *) src,&src->poll); | |
122 | - | |
123 | - return src; | |
124 | -} | |
125 | - | |
126 | -static void static_RemoveSource(G_GNUC_UNUSED H3270 *session, void *id) | |
127 | -{ | |
128 | - if(id) | |
129 | - g_source_destroy((GSource *) id); | |
130 | -} | |
131 | - | |
132 | -static gboolean do_timer(TIMER *t) | |
133 | -{ | |
134 | - if(!t->remove) | |
135 | - t->call(t->session); | |
136 | - return FALSE; | |
137 | -} | |
138 | - | |
139 | -static void * static_AddTimeOut(H3270 *session, unsigned long interval, void (*call)(H3270 *session)) | |
140 | -{ | |
141 | - TIMER *t = g_malloc0(sizeof(TIMER)); | |
142 | - | |
143 | - t->call = call; | |
144 | - t->session = session; | |
145 | - | |
146 | - g_timeout_add_full(G_PRIORITY_DEFAULT, (guint) interval, (GSourceFunc) do_timer, t, g_free); | |
147 | - | |
148 | - return t; | |
149 | -} | |
150 | - | |
151 | -static void static_RemoveTimeOut(G_GNUC_UNUSED H3270 *session, void * timer) | |
152 | -{ | |
153 | - ((TIMER *) timer)->remove++; | |
154 | -} | |
155 | - | |
156 | -static gboolean IO_prepare(G_GNUC_UNUSED GSource *source, G_GNUC_UNUSED gint *timeout) | |
157 | -{ | |
158 | - /* | |
159 | - * Called before all the file descriptors are polled. | |
160 | - * If the source can determine that it is ready here | |
161 | - * (without waiting for the results of the poll() call) | |
162 | - * it should return TRUE. | |
163 | - * | |
164 | - * It can also return a timeout_ value which should be the maximum | |
165 | - * timeout (in milliseconds) which should be passed to the poll() call. | |
166 | - * The actual timeout used will be -1 if all sources returned -1, | |
167 | - * or it will be the minimum of all the timeout_ values | |
168 | - * returned which were >= 0. | |
169 | - * | |
170 | - */ | |
171 | - return 0; | |
172 | -} | |
173 | - | |
174 | -static gboolean IO_check(GSource *source) | |
175 | -{ | |
176 | - /* | |
177 | - * Called after all the file descriptors are polled. | |
178 | - * The source should return TRUE if it is ready to be dispatched. | |
179 | - * Note that some time may have passed since the previous prepare | |
180 | - * function was called, so the source should be checked again here. | |
181 | - * | |
182 | - */ | |
183 | -#ifdef _WIN32 | |
184 | - | |
185 | - fd_set rfds, wfds; | |
186 | - struct timeval tm; | |
187 | - | |
188 | - memset(&tm,0,sizeof(tm)); | |
189 | - | |
190 | - FD_ZERO(&rfds); | |
191 | - FD_ZERO(&wfds); | |
192 | -// FD_ZERO(&xfds); | |
193 | - | |
194 | - if(((IO_Source *) source)->poll.events & G_IO_IN) | |
195 | - { | |
196 | - FD_SET(((IO_Source *) source)->poll.fd, &rfds); | |
197 | - } | |
198 | - | |
199 | - if(((IO_Source *) source)->poll.events & G_IO_OUT) | |
200 | - { | |
201 | - FD_SET(((IO_Source *) source)->poll.fd, &wfds); | |
202 | - } | |
203 | - | |
204 | - if(select(((IO_Source *) source)->poll.fd+1, &rfds, &wfds, NULL, &tm) > 0) | |
205 | - return TRUE; | |
206 | - | |
207 | -#else | |
208 | - | |
209 | - struct pollfd fds; | |
210 | - | |
211 | - memset(&fds,0,sizeof(fds)); | |
212 | - | |
213 | - fds.fd = ((IO_Source *) source)->poll.fd; | |
214 | - fds.events = ((IO_Source *) source)->poll.events; | |
215 | - | |
216 | - if(poll(&fds,1,0) > 0) | |
217 | - return TRUE; | |
218 | - | |
219 | -#endif // _WIN32 | |
220 | - | |
221 | - return FALSE; | |
222 | -} | |
223 | - | |
224 | -static gboolean IO_dispatch(GSource *source, G_GNUC_UNUSED GSourceFunc callback, G_GNUC_UNUSED gpointer user_data) | |
225 | -{ | |
226 | - /* | |
227 | - * Called to dispatch the event source, | |
228 | - * after it has returned TRUE in either its prepare or its check function. | |
229 | - * The dispatch function is passed in a callback function and data. | |
230 | - * The callback function may be NULL if the source was never connected | |
231 | - * to a callback using g_source_set_callback(). The dispatch function | |
232 | - * should call the callback function with user_data and whatever additional | |
233 | - * parameters are needed for this type of event source. | |
234 | - */ | |
235 | - IO_Source *obj = (IO_Source *) source; | |
236 | - | |
237 | - obj->call(obj->session,obj->fd,0,obj->userdata); | |
238 | - | |
239 | - return TRUE; | |
240 | -} | |
241 | - | |
242 | -static void IO_finalize(G_GNUC_UNUSED GSource *source) | |
243 | -{ | |
244 | - | |
245 | -} | |
246 | - | |
247 | -static gboolean IO_closure(G_GNUC_UNUSED gpointer data) | |
248 | -{ | |
249 | - return 0; | |
250 | -} | |
251 | - | |
252 | -struct bgParameter | |
253 | -{ | |
254 | - gboolean running; | |
255 | - H3270 *session; | |
256 | - int rc; | |
257 | - int(*callback)(H3270 *session, void *); | |
258 | - void *parm; | |
259 | - | |
260 | -}; | |
261 | - | |
262 | -gpointer BgCall(struct bgParameter *p) | |
263 | -{ | |
264 | - p->rc = p->callback(p->session, p->parm); | |
265 | - p->running = FALSE; | |
266 | - return 0; | |
267 | -} | |
268 | - | |
269 | -static int static_Sleep(G_GNUC_UNUSED H3270 *hSession, int seconds) | |
270 | -{ | |
271 | - time_t end = time(0) + seconds; | |
272 | - | |
273 | - while(time(0) < end) | |
274 | - gtk_main_iteration(); | |
275 | - | |
276 | - return 0; | |
277 | -} | |
278 | - | |
279 | -static int static_RunPendingEvents(G_GNUC_UNUSED H3270 *hSession, int wait) | |
280 | -{ | |
281 | - int rc = 0; | |
282 | - while(gtk_events_pending()) | |
283 | - { | |
284 | - rc = 1; | |
285 | - gtk_main_iteration(); | |
286 | - } | |
287 | - | |
288 | - if(wait) | |
289 | - gtk_main_iteration(); | |
290 | - | |
291 | - return rc; | |
292 | -} | |
293 | - | |
294 | -static void beep(G_GNUC_UNUSED H3270 *session) | |
295 | -{ | |
296 | - gdk_display_beep(gdk_display_get_default()); | |
297 | -} | |
298 | - | |
299 | -void v3270_register_io_handlers(G_GNUC_UNUSED v3270Class *cls) | |
300 | -{ | |
301 | - static const struct lib3270_callbacks hdl = | |
302 | - { | |
303 | - sizeof(struct lib3270_callbacks), | |
304 | - | |
305 | - static_AddTimeOut, | |
306 | - static_RemoveTimeOut, | |
307 | - | |
308 | - static_AddSource, | |
309 | - static_RemoveSource, | |
310 | - | |
311 | - static_Sleep, | |
312 | - static_RunPendingEvents, | |
313 | - beep | |
314 | - | |
315 | - }; | |
316 | - | |
317 | - if(lib3270_register_handlers(&hdl)) | |
318 | - { | |
319 | - g_error("%s",_( "Can't set lib3270 I/O handlers" ) ); | |
320 | - } | |
321 | - | |
322 | -} |
... | ... | @@ -0,0 +1,114 @@ |
1 | +/* | |
2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
5 | + * | |
6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | |
7 | + * | |
8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
10 | + * Free Software Foundation. | |
11 | + * | |
12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
15 | + * obter mais detalhes. | |
16 | + * | |
17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | |
20 | + * | |
21 | + * Este programa está nomeado como - e possui - linhas de código. | |
22 | + * | |
23 | + * Contatos: | |
24 | + * | |
25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
27 | + * | |
28 | + */ | |
29 | + | |
30 | + #include <config.h> | |
31 | + #include "../private.h" | |
32 | + | |
33 | +/*---[ Structs ]-------------------------------------------------------------------------------------------*/ | |
34 | + | |
35 | + typedef struct _IO_Source | |
36 | + { | |
37 | + GSource gsrc; | |
38 | + GPollFD poll; | |
39 | + gboolean enabled; | |
40 | + int fd; | |
41 | + void (*call)(H3270 *, int, LIB3270_IO_FLAG, void *); | |
42 | + H3270 * session; | |
43 | + void * userdata; | |
44 | + } IO_Source; | |
45 | + | |
46 | +/*---[ Implement ]-----------------------------------------------------------------------------------------*/ | |
47 | + | |
48 | +gboolean IO_prepare(G_GNUC_UNUSED GSource *source, G_GNUC_UNUSED gint *timeout) | |
49 | +{ | |
50 | + /* | |
51 | + * Called before all the file descriptors are polled. | |
52 | + * If the source can determine that it is ready here | |
53 | + * (without waiting for the results of the poll() call) | |
54 | + * it should return TRUE. | |
55 | + * | |
56 | + * It can also return a timeout_ value which should be the maximum | |
57 | + * timeout (in milliseconds) which should be passed to the poll() call. | |
58 | + * The actual timeout used will be -1 if all sources returned -1, | |
59 | + * or it will be the minimum of all the timeout_ values | |
60 | + * returned which were >= 0. | |
61 | + * | |
62 | + */ | |
63 | + return 0; | |
64 | +} | |
65 | + | |
66 | +gboolean IO_check(GSource *source) | |
67 | +{ | |
68 | + /* | |
69 | + * Called after all the file descriptors are polled. | |
70 | + * The source should return TRUE if it is ready to be dispatched. | |
71 | + * Note that some time may have passed since the previous prepare | |
72 | + * function was called, so the source should be checked again here. | |
73 | + * | |
74 | + */ | |
75 | + struct pollfd fds; | |
76 | + | |
77 | + memset(&fds,0,sizeof(fds)); | |
78 | + | |
79 | + fds.fd = ((IO_Source *) source)->poll.fd; | |
80 | + fds.events = ((IO_Source *) source)->poll.events; | |
81 | + | |
82 | + if(poll(&fds,1,0) > 0) | |
83 | + return TRUE; | |
84 | + | |
85 | + return FALSE; | |
86 | +} | |
87 | + | |
88 | +gboolean IO_dispatch(GSource *source, G_GNUC_UNUSED GSourceFunc callback, G_GNUC_UNUSED gpointer user_data) | |
89 | +{ | |
90 | + /* | |
91 | + * Called to dispatch the event source, | |
92 | + * after it has returned TRUE in either its prepare or its check function. | |
93 | + * The dispatch function is passed in a callback function and data. | |
94 | + * The callback function may be NULL if the source was never connected | |
95 | + * to a callback using g_source_set_callback(). The dispatch function | |
96 | + * should call the callback function with user_data and whatever additional | |
97 | + * parameters are needed for this type of event source. | |
98 | + */ | |
99 | + IO_Source *obj = (IO_Source *) source; | |
100 | + | |
101 | + obj->call(obj->session,obj->fd,0,obj->userdata); | |
102 | + | |
103 | + return TRUE; | |
104 | +} | |
105 | + | |
106 | +void IO_finalize(G_GNUC_UNUSED GSource *source) | |
107 | +{ | |
108 | + | |
109 | +} | |
110 | + | |
111 | +gboolean IO_closure(G_GNUC_UNUSED gpointer data) | |
112 | +{ | |
113 | + return 0; | |
114 | +} | ... | ... |
src/v3270/private.h
... | ... | @@ -315,25 +315,31 @@ G_GNUC_INTERNAL void v3270_update_cursor(H3270 *session, unsigned short row, |
315 | 315 | G_GNUC_INTERNAL void v3270_update_oia(H3270 *session, LIB3270_FLAG id, unsigned char on); |
316 | 316 | G_GNUC_INTERNAL void v3270_update_ssl(H3270 *session, LIB3270_SSL_STATE state); |
317 | 317 | |
318 | -G_GNUC_INTERNAL void v3270_update_luname(GtkWidget *widget,const gchar *name); | |
319 | -G_GNUC_INTERNAL void v3270_init_properties(GObjectClass * gobject_class); | |
320 | -G_GNUC_INTERNAL void v3270_queue_draw_area(GtkWidget *widget, gint x, gint y, gint width, gint height); | |
318 | +G_GNUC_INTERNAL void v3270_update_luname(GtkWidget *widget,const gchar *name); | |
319 | +G_GNUC_INTERNAL void v3270_init_properties(GObjectClass * gobject_class); | |
320 | +G_GNUC_INTERNAL void v3270_queue_draw_area(GtkWidget *widget, gint x, gint y, gint width, gint height); | |
321 | 321 | |
322 | -G_GNUC_INTERNAL void v3270_disable_updates(GtkWidget *widget); | |
323 | -G_GNUC_INTERNAL void v3270_enable_updates(GtkWidget *widget); | |
322 | +G_GNUC_INTERNAL void v3270_disable_updates(GtkWidget *widget); | |
323 | +G_GNUC_INTERNAL void v3270_enable_updates(GtkWidget *widget); | |
324 | 324 | |
325 | 325 | // Keyboard & Mouse |
326 | -G_GNUC_INTERNAL gboolean v3270_key_press_event(GtkWidget *widget, GdkEventKey *event); | |
327 | -G_GNUC_INTERNAL gboolean v3270_key_release_event(GtkWidget *widget, GdkEventKey *event); | |
328 | -G_GNUC_INTERNAL void v3270_key_commit(GtkIMContext *imcontext, gchar *str, v3270 *widget); | |
329 | -G_GNUC_INTERNAL gboolean v3270_button_press_event(GtkWidget *widget, GdkEventButton *event); | |
330 | -G_GNUC_INTERNAL gboolean v3270_button_release_event(GtkWidget *widget, GdkEventButton*event); | |
331 | -G_GNUC_INTERNAL gboolean v3270_motion_notify_event(GtkWidget *widget, GdkEventMotion *event); | |
332 | -G_GNUC_INTERNAL void v3270_emit_popup(v3270 *widget, int baddr, GdkEventButton *event); | |
333 | -G_GNUC_INTERNAL gint v3270_get_offset_at_point(v3270 *widget, gint x, gint y); | |
334 | -G_GNUC_INTERNAL gboolean v3270_scroll_event(GtkWidget *widget, GdkEventScroll *event); | |
335 | - | |
336 | -G_GNUC_INTERNAL const struct v3270_ssl_status_msg * v3270_get_ssl_status_msg(GtkWidget *widget); | |
337 | - | |
326 | +G_GNUC_INTERNAL gboolean v3270_key_press_event(GtkWidget *widget, GdkEventKey *event); | |
327 | +G_GNUC_INTERNAL gboolean v3270_key_release_event(GtkWidget *widget, GdkEventKey *event); | |
328 | +G_GNUC_INTERNAL void v3270_key_commit(GtkIMContext *imcontext, gchar *str, v3270 *widget); | |
329 | +G_GNUC_INTERNAL gboolean v3270_button_press_event(GtkWidget *widget, GdkEventButton *event); | |
330 | +G_GNUC_INTERNAL gboolean v3270_button_release_event(GtkWidget *widget, GdkEventButton*event); | |
331 | +G_GNUC_INTERNAL gboolean v3270_motion_notify_event(GtkWidget *widget, GdkEventMotion *event); | |
332 | +G_GNUC_INTERNAL void v3270_emit_popup(v3270 *widget, int baddr, GdkEventButton *event); | |
333 | +G_GNUC_INTERNAL gint v3270_get_offset_at_point(v3270 *widget, gint x, gint y); | |
334 | +G_GNUC_INTERNAL gboolean v3270_scroll_event(GtkWidget *widget, GdkEventScroll *event); | |
335 | + | |
336 | +G_GNUC_INTERNAL const struct v3270_ssl_status_msg * v3270_get_ssl_status_msg(GtkWidget *widget); | |
337 | + | |
338 | +// I/O Callbacks | |
339 | +G_GNUC_INTERNAL gboolean IO_prepare(GSource *source, gint *timeout); | |
340 | +G_GNUC_INTERNAL gboolean IO_check(GSource *source); | |
341 | +G_GNUC_INTERNAL gboolean IO_dispatch(GSource *source, GSourceFunc callback, gpointer user_data); | |
342 | +G_GNUC_INTERNAL void IO_finalize(GSource *source); /* Can be NULL */ | |
343 | +G_GNUC_INTERNAL gboolean IO_closure(gpointer data); | |
338 | 344 | |
339 | 345 | G_END_DECLS | ... | ... |
... | ... | @@ -0,0 +1,126 @@ |
1 | +/* | |
2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
5 | + * | |
6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | |
7 | + * | |
8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
10 | + * Free Software Foundation. | |
11 | + * | |
12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
15 | + * obter mais detalhes. | |
16 | + * | |
17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | |
20 | + * | |
21 | + * Este programa está nomeado como - e possui - linhas de código. | |
22 | + * | |
23 | + * Contatos: | |
24 | + * | |
25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
27 | + * | |
28 | + */ | |
29 | + | |
30 | + #include <config.h> | |
31 | + #include "../private.h" | |
32 | + | |
33 | +/*---[ Structs ]-------------------------------------------------------------------------------------------*/ | |
34 | + | |
35 | + typedef struct _IO_Source | |
36 | + { | |
37 | + GSource gsrc; | |
38 | + GPollFD poll; | |
39 | + gboolean enabled; | |
40 | + int fd; | |
41 | + void (*call)(H3270 *, int, LIB3270_IO_FLAG, void *); | |
42 | + H3270 * session; | |
43 | + void * userdata; | |
44 | + } IO_Source; | |
45 | + | |
46 | +/*---[ Implement ]-----------------------------------------------------------------------------------------*/ | |
47 | + | |
48 | +static gboolean IO_prepare(G_GNUC_UNUSED GSource *source, G_GNUC_UNUSED gint *timeout) | |
49 | +{ | |
50 | + /* | |
51 | + * Called before all the file descriptors are polled. | |
52 | + * If the source can determine that it is ready here | |
53 | + * (without waiting for the results of the poll() call) | |
54 | + * it should return TRUE. | |
55 | + * | |
56 | + * It can also return a timeout_ value which should be the maximum | |
57 | + * timeout (in milliseconds) which should be passed to the poll() call. | |
58 | + * The actual timeout used will be -1 if all sources returned -1, | |
59 | + * or it will be the minimum of all the timeout_ values | |
60 | + * returned which were >= 0. | |
61 | + * | |
62 | + */ | |
63 | + return 0; | |
64 | +} | |
65 | + | |
66 | +static gboolean IO_check(GSource *source) | |
67 | +{ | |
68 | + /* | |
69 | + * Called after all the file descriptors are polled. | |
70 | + * The source should return TRUE if it is ready to be dispatched. | |
71 | + * Note that some time may have passed since the previous prepare | |
72 | + * function was called, so the source should be checked again here. | |
73 | + * | |
74 | + */ | |
75 | + fd_set rfds, wfds; | |
76 | + struct timeval tm; | |
77 | + | |
78 | + memset(&tm,0,sizeof(tm)); | |
79 | + | |
80 | + FD_ZERO(&rfds); | |
81 | + FD_ZERO(&wfds); | |
82 | +// FD_ZERO(&xfds); | |
83 | + | |
84 | + if(((IO_Source *) source)->poll.events & G_IO_IN) | |
85 | + { | |
86 | + FD_SET(((IO_Source *) source)->poll.fd, &rfds); | |
87 | + } | |
88 | + | |
89 | + if(((IO_Source *) source)->poll.events & G_IO_OUT) | |
90 | + { | |
91 | + FD_SET(((IO_Source *) source)->poll.fd, &wfds); | |
92 | + } | |
93 | + | |
94 | + if(select(((IO_Source *) source)->poll.fd+1, &rfds, &wfds, NULL, &tm) > 0) | |
95 | + return TRUE; | |
96 | + | |
97 | + return FALSE; | |
98 | +} | |
99 | + | |
100 | +static gboolean IO_dispatch(GSource *source, G_GNUC_UNUSED GSourceFunc callback, G_GNUC_UNUSED gpointer user_data) | |
101 | +{ | |
102 | + /* | |
103 | + * Called to dispatch the event source, | |
104 | + * after it has returned TRUE in either its prepare or its check function. | |
105 | + * The dispatch function is passed in a callback function and data. | |
106 | + * The callback function may be NULL if the source was never connected | |
107 | + * to a callback using g_source_set_callback(). The dispatch function | |
108 | + * should call the callback function with user_data and whatever additional | |
109 | + * parameters are needed for this type of event source. | |
110 | + */ | |
111 | + IO_Source *obj = (IO_Source *) source; | |
112 | + | |
113 | + obj->call(obj->session,obj->fd,0,obj->userdata); | |
114 | + | |
115 | + return TRUE; | |
116 | +} | |
117 | + | |
118 | +static void IO_finalize(G_GNUC_UNUSED GSource *source) | |
119 | +{ | |
120 | + | |
121 | +} | |
122 | + | |
123 | +static gboolean IO_closure(G_GNUC_UNUSED gpointer data) | |
124 | +{ | |
125 | + return 0; | |
126 | +} | ... | ... |