]> git.saurik.com Git - wxWidgets.git/blame - src/motif/gsockmot.c
yet another file I added on the wxUniv branch and forgot to merge
[wxWidgets.git] / src / motif / gsockmot.c
CommitLineData
d391a345
VZ
1/* -------------------------------------------------------------------------
2 * Project: GSocket (Generic Socket) for WX
3 * Name: gsockmot.c
4 * Purpose: GSocket: Motif part
5 * CVSID: $Id$
6 * ------------------------------------------------------------------------- */
813c20a6
VZ
7
8#include "wx/setup.h"
9
10#if wxUSE_SOCKETS
11
dbd300df
GL
12#include <stdlib.h>
13#include <X11/Intrinsic.h>
483249fc 14#include "wx/gsocket.h"
483249fc 15#include "wx/unix/gsockunx.h"
dbd300df 16
d391a345 17extern XtAppContext wxGetAppContext();
dbd300df
GL
18
19static void _GSocket_Motif_Input(XtPointer data, int *fid,
20 XtInputId *id)
21{
22 GSocket *socket = (GSocket *)data;
23
24 _GSocket_Detected_Read(socket);
25}
26
27static void _GSocket_Motif_Output(XtPointer data, int *fid,
28 XtInputId *id)
29{
30 GSocket *socket = (GSocket *)data;
31
32 _GSocket_Detected_Write(socket);
33}
34
27a97d02 35int _GSocket_GUI_Init(GSocket *socket)
dbd300df 36{
dbd300df
GL
37 int *m_id;
38
483249fc 39 socket->m_gui_dependent = (char *)malloc(sizeof(int)*2);
dbd300df
GL
40 m_id = (int *)(socket->m_gui_dependent);
41
483249fc
GRG
42 m_id[0] = -1;
43 m_id[1] = -1;
5ff86996
GRG
44
45 return TRUE;
dbd300df
GL
46}
47
48void _GSocket_GUI_Destroy(GSocket *socket)
49{
dbd300df
GL
50 free(socket->m_gui_dependent);
51}
52
39b91eca 53void _GSocket_Install_Callback(GSocket *socket, GSocketEvent event)
dbd300df 54{
483249fc
GRG
55 int *m_id = (int *)(socket->m_gui_dependent);
56 int c;
dbd300df 57
483249fc
GRG
58 if (socket->m_fd == -1)
59 return;
dbd300df 60
483249fc
GRG
61 switch (event)
62 {
63 case GSOCK_LOST: /* fall-through */
d391a345 64 case GSOCK_INPUT: c = 0; break;
483249fc
GRG
65 case GSOCK_OUTPUT: c = 1; break;
66 case GSOCK_CONNECTION: c = ((socket->m_server) ? 0 : 1); break;
67 default: return;
68 }
69
70 if (m_id[c] != -1)
71 XtRemoveInput(m_id[c]);
72
73 if (c == 0)
74 {
d391a345 75 m_id[0] = XtAppAddInput(wxGetAppContext(), socket->m_fd,
dbd300df
GL
76 (XtPointer *)XtInputReadMask,
77 (XtInputCallbackProc) _GSocket_Motif_Input,
78 (XtPointer) socket);
483249fc
GRG
79 }
80 else
81 {
d391a345 82 m_id[1] = XtAppAddInput(wxGetAppContext(), socket->m_fd,
dbd300df
GL
83 (XtPointer *)XtInputWriteMask,
84 (XtInputCallbackProc) _GSocket_Motif_Output,
85 (XtPointer) socket);
dbd300df
GL
86 }
87}
88
39b91eca 89void _GSocket_Uninstall_Callback(GSocket *socket, GSocketEvent event)
dbd300df 90{
483249fc 91 int *m_id = (int *)(socket->m_gui_dependent);
dbd300df 92 int c;
dbd300df 93
483249fc
GRG
94 switch (event)
95 {
96 case GSOCK_LOST: /* fall-through */
d391a345 97 case GSOCK_INPUT: c = 0; break;
483249fc
GRG
98 case GSOCK_OUTPUT: c = 1; break;
99 case GSOCK_CONNECTION: c = ((socket->m_server) ? 0 : 1); break;
100 default: return;
dbd300df
GL
101 }
102
103 if (m_id[c] != -1)
104 XtRemoveInput(m_id[c]);
105
106 m_id[c] = -1;
107}
108
483249fc 109void _GSocket_Enable_Events(GSocket *socket)
dbd300df 110{
483249fc
GRG
111 _GSocket_Install_Callback(socket, GSOCK_INPUT);
112 _GSocket_Install_Callback(socket, GSOCK_OUTPUT);
dbd300df
GL
113}
114
483249fc 115void _GSocket_Disable_Events(GSocket *socket)
dbd300df 116{
483249fc
GRG
117 _GSocket_Uninstall_Callback(socket, GSOCK_INPUT);
118 _GSocket_Uninstall_Callback(socket, GSOCK_OUTPUT);
dbd300df 119}
813c20a6 120
26dfedc4
VZ
121#else /* !wxUSE_SOCKETS */
122
123/* some compilers don't like having empty source files */
124static int wxDummyGsockVar = 0;
125
126#endif /* wxUSE_SOCKETS/!wxUSE_SOCKETS */