]> git.saurik.com Git - wxWidgets.git/blame - include/wx/unix/gsockunx.h
Document revisioning (including more wx-like formatting and internal function removal)
[wxWidgets.git] / include / wx / unix / gsockunx.h
CommitLineData
dbd300df 1/* -------------------------------------------------------------------------
99d80019
JS
2 * Project: GSocket (Generic Socket) for WX
3 * Name: gsockunx.h
4 * Copyright: (c) Guilhem Lavaux
5 * Licence: wxWindows Licence
6 * Purpose: GSocket Unix header
7 * CVSID: $Id$
dbd300df
GL
8 * -------------------------------------------------------------------------
9 */
483249fc 10
2804f77d
VZ
11#ifndef _WX_UNIX_GSOCKUNX_H_
12#define _WX_UNIX_GSOCKUNX_H_
d422d01e 13
5e1eac14
VZ
14class wxGSocketIOHandler;
15
ba2a81d7
DE
16class GSocket
17{
18public:
19 GSocket();
20 virtual ~GSocket();
09e6e5ec
DE
21 bool IsOk() { return m_ok; }
22 void Close();
23 void Shutdown();
24 GSocketError SetLocal(GAddress *address);
25 GSocketError SetPeer(GAddress *address);
26 GAddress *GetLocal();
27 GAddress *GetPeer();
28 GSocketError SetServer();
29 GSocket *WaitConnection();
948c96ef 30 bool SetReusable();
60edcf45
VZ
31 bool SetBroadcast();
32 bool DontDoBind();
09e6e5ec
DE
33 GSocketError Connect(GSocketStream stream);
34 GSocketError SetNonOriented();
35 int Read(char *buffer, int size);
36 int Write(const char *buffer, int size);
37 GSocketEventFlags Select(GSocketEventFlags flags);
948c96ef 38 void SetNonBlocking(bool non_block);
09e6e5ec 39 void SetTimeout(unsigned long millisec);
ba2a81d7 40 GSocketError WXDLLIMPEXP_NET GetError();
09e6e5ec
DE
41 void SetCallback(GSocketEventFlags flags,
42 GSocketCallback callback, char *cdata);
43 void UnsetCallback(GSocketEventFlags flags);
b082b524
DE
44 GSocketError GetSockOpt(int level, int optname, void *optval, int *optlen);
45 GSocketError SetSockOpt(int level, int optname,
46 const void *optval, int optlen);
2804f77d
VZ
47 //attach or detach from main loop
48 void Notify(bool flag);
ba2a81d7
DE
49 virtual void Detected_Read();
50 virtual void Detected_Write();
8c029a5b
VZ
51 void SetInitialSocketBuffers(int recv, int send)
52 {
53 m_initialRecvBufferSize = recv;
54 m_initialSendBufferSize = send;
55 }
56
09e6e5ec 57protected:
2804f77d
VZ
58 //enable or disable event callback using gsocket gui callback table
59 void EnableEvents(bool flag = true);
60 void DisableEvents() { EnableEvents(false); }
09e6e5ec
DE
61 void Enable(GSocketEvent event);
62 void Disable(GSocketEvent event);
63 GSocketError Input_Timeout();
64 GSocketError Output_Timeout();
65 int Recv_Stream(char *buffer, int size);
66 int Recv_Dgram(char *buffer, int size);
67 int Send_Stream(const char *buffer, int size);
68 int Send_Dgram(const char *buffer, int size);
09e6e5ec 69 bool m_ok;
8c029a5b
VZ
70 int m_initialRecvBufferSize;
71 int m_initialSendBufferSize;
09e6e5ec 72public:
b6db2e91
SN
73 /* DFE: We can't protect these data member until the GUI code is updated */
74 /* protected: */
a324a7bc 75 int m_fd;
5e1eac14 76 wxGSocketIOHandler *m_handler;
483249fc
GRG
77 GAddress *m_local;
78 GAddress *m_peer;
a324a7bc
GL
79 GSocketError m_error;
80
948c96ef
DE
81 bool m_non_blocking;
82 bool m_server;
83 bool m_stream;
84 bool m_establishing;
85 bool m_reusable;
60edcf45
VZ
86 bool m_broadcast;
87 bool m_dobind;
39b91eca 88 unsigned long m_timeout;
a324a7bc 89
2804f77d
VZ
90 // true if socket should fire events
91 bool m_use_events;
92
39b91eca 93 /* Callbacks */
483249fc 94 GSocketEventFlags m_detected;
98781fa3 95 GSocketCallback m_cbacks[GSOCK_MAX_EVENT];
a324a7bc
GL
96 char *m_data[GSOCK_MAX_EVENT];
97
2804f77d
VZ
98 // pointer for storing extra (usually GUI-specific) data
99 void *m_gui_dependent;
a324a7bc
GL
100};
101
102/* Definition of GAddress */
483249fc
GRG
103struct _GAddress
104{
a324a7bc
GL
105 struct sockaddr *m_addr;
106 size_t m_len;
107
108 GAddressType m_family;
109 int m_realfamily;
110
111 GSocketError m_error;
112};
5ff86996 113
483249fc 114/* GAddress */
e00f35bb 115
54e575f9
GL
116GSocketError _GAddress_translate_from(GAddress *address,
117 struct sockaddr *addr, int len);
9bf10d6b
GRG
118GSocketError _GAddress_translate_to (GAddress *address,
119 struct sockaddr **addr, int *len);
54e575f9 120GSocketError _GAddress_Init_INET(GAddress *address);
54e575f9 121GSocketError _GAddress_Init_UNIX(GAddress *address);
a324a7bc 122
2804f77d
VZ
123// A version of GSocketManager which uses FDs for socket IO
124//
125// This class uses GSocket::m_gui_dependent field to store the 2 (for input and
126// output) FDs associated with the socket.
127class GSocketFDBasedManager : public GSocketManager
128{
129public:
130 // no special initialization/cleanup needed when using FDs
131 virtual bool OnInit() { return true; }
132 virtual void OnExit() { }
133
134 // allocate/free the storage we need
135 virtual bool Init_Socket(GSocket *socket)
136 {
137 socket->m_gui_dependent = malloc(sizeof(int)*2);
138 int * const fds = wx_static_cast(int *, socket->m_gui_dependent);
139
140 fds[0] = -1;
141 fds[1] = -1;
9bf10d6b 142
2804f77d
VZ
143 return true;
144 }
145 virtual void Destroy_Socket(GSocket *socket)
146 {
147 free(socket->m_gui_dependent);
148 }
d422d01e 149
2804f77d
VZ
150 virtual void Enable_Events(GSocket *socket)
151 {
152 Install_Callback(socket, GSOCK_INPUT);
153 Install_Callback(socket, GSOCK_OUTPUT);
154 }
155 virtual void Disable_Events(GSocket *socket)
156 {
157 Uninstall_Callback(socket, GSOCK_INPUT);
158 Uninstall_Callback(socket, GSOCK_OUTPUT);
159 }
160
161protected:
162 // identifies either input or output direction
163 //
164 // NB: the values of this enum shouldn't change
165 enum SocketDir
166 {
167 FD_INPUT,
168 FD_OUTPUT
169 };
170
171 // get the FD index corresponding to the given GSocketEvent
172 SocketDir GetDirForEvent(GSocket *socket, GSocketEvent event)
173 {
174 switch ( event )
175 {
176 default:
177 wxFAIL_MSG( "unexpected socket event" );
178 // fall through
179
180 case GSOCK_LOST:
181 // fall through
182
183 case GSOCK_INPUT:
184 return FD_INPUT;
185
186 case GSOCK_OUTPUT:
187 return FD_OUTPUT;
188
189 case GSOCK_CONNECTION:
190 // FIXME: explain this?
191 return socket->m_server ? FD_INPUT : FD_OUTPUT;
192 }
193 }
194
195 // access the FDs we store
196 int& FD(GSocket *socket, SocketDir d)
197 {
198 return wx_static_cast(int *, socket->m_gui_dependent)[d];
199 }
200};
201
202// Common base class for all ports using X11-like (and hence implemented in
203// X11, Motif and GTK) AddInput() and RemoveInput() functions
204class GSocketInputBasedManager : public GSocketFDBasedManager
205{
206public:
207 virtual void Install_Callback(GSocket *socket, GSocketEvent event)
208 {
209 wxCHECK_RET( socket->m_fd != -1,
210 "shouldn't be called on invalid socket" );
211
212 const SocketDir d = GetDirForEvent(socket, event);
213
214 int& fd = FD(socket, d);
215 if ( fd != -1 )
216 RemoveInput(fd);
217
218 fd = AddInput(socket, d);
219 }
220
221 virtual void Uninstall_Callback(GSocket *socket, GSocketEvent event)
222 {
223 const SocketDir d = GetDirForEvent(socket, event);
224
225 int& fd = FD(socket, d);
226 if ( fd != -1 )
227 {
228 RemoveInput(fd);
229 fd = -1;
230 }
231 }
232
233private:
234 // these functions map directly to XtAdd/RemoveInput() or
235 // gdk_input_add/remove()
236 virtual int AddInput(GSocket *socket, SocketDir d) = 0;
237 virtual void RemoveInput(int fd) = 0;
238};
d422d01e 239
2804f77d 240#endif /* _WX_UNIX_GSOCKUNX_H_ */