Updated gsocket.c to current unix version, use gsockunx.h instead of gsockos2.h

Added gsockpm.c.
Hooked socket handling into main loop.


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@10242 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Stefan Neis
2001-05-20 13:25:28 +00:00
parent 5d5b1c0ce0
commit 3958ae62ba
5 changed files with 999 additions and 403 deletions

View File

@@ -12,12 +12,16 @@
#ifndef _WX_APP_H_ #ifndef _WX_APP_H_
#define _WX_APP_H_ #define _WX_APP_H_
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>
#include "wx/event.h" #include "wx/event.h"
#include "wx/icon.h" #include "wx/icon.h"
class WXDLLEXPORT wxFrame; class WXDLLEXPORT wxFrame;
class WXDLLEXPORT wxWindow; class WXDLLEXPORT wxWindow;
class WXDLLEXPORT wxApp ; class WXDLLEXPORT wxApp;
class WXDLLEXPORT wxKeyEvent; class WXDLLEXPORT wxKeyEvent;
class WXDLLEXPORT wxLog; class WXDLLEXPORT wxLog;
@@ -36,6 +40,7 @@ extern MRESULT EXPENTRY wxWndProc( HWND
,MPARAM ,MPARAM
); );
// Represents the application. Derive OnInit and declare // Represents the application. Derive OnInit and declare
// a new App object to start application // a new App object to start application
class WXDLLEXPORT wxApp : public wxAppBase class WXDLLEXPORT wxApp : public wxAppBase
@@ -76,6 +81,11 @@ public:
void SetAuto3D(bool bFlag) { m_bAuto3D = bFlag; } void SetAuto3D(bool bFlag) { m_bAuto3D = bFlag; }
bool GetAuto3D(void) const { return m_bAuto3D; } bool GetAuto3D(void) const { return m_bAuto3D; }
int AddSocketHandler(int handle, int mask,
void (*callback)(void*), void * gsock);
void RemoveSocketHandler(int handle);
void HandleSockets();
protected: protected:
bool m_bShowOnInit; bool m_bShowOnInit;
int m_nPrintMode; // wxPRINT_WINDOWS, wxPRINT_POSTSCRIPT int m_nPrintMode; // wxPRINT_WINDOWS, wxPRINT_POSTSCRIPT
@@ -84,6 +94,13 @@ protected:
// //
// PM-specific wxApp definitions */ // PM-specific wxApp definitions */
// //
private:
int m_maxSocketHandles;
int m_maxSocketNr;
int m_lastUsedHandle;
fd_set m_readfds, m_writefds;
void *m_sockCallbackInfo;
public: public:
// Implementation // Implementation
@@ -98,13 +115,12 @@ public:
public: public:
int m_nCmdShow; int m_nCmdShow;
HMQ m_hMq;
protected: protected:
bool m_bKeepGoing ; bool m_bKeepGoing ;
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
private:
HMQ m_hMq;
}; };
int WXDLLEXPORT wxEntry( int argc, char *argv[] ); int WXDLLEXPORT wxEntry( int argc, char *argv[] );

View File

@@ -1,105 +0,0 @@
/* -------------------------------------------------------------------------
* Project: GSocket (Generic Socket) for WX
* Name: gsockos2.h
* Purpose: GSocket OS/2 header
* CVSID: $Id$
* -------------------------------------------------------------------------
*/
#ifndef __GSOCK_OS2_H
#define __GSOCK_OS2_H
#ifndef __GSOCKET_STANDALONE__
#include "wx/setup.h"
#endif
#if wxUSE_SOCKETS || defined(__GSOCKET_STANDALONE__)
#ifndef __GSOCKET_STANDALONE__
#include "wx/gsocket.h"
#else
#include "gsocket.h"
#endif
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
#define SIGPIPE 13
/* Definition of GSocket */
struct _GSocket
{
int m_fd;
GAddress *m_local;
GAddress *m_peer;
GSocketError m_error;
int m_non_blocking;
int m_server;
int m_stream;
int m_oriented;
int m_establishing;
unsigned long m_timeout;
/* Callbacks */
GSocketEventFlags m_detected;
GSocketCallback m_cbacks[GSOCK_MAX_EVENT];
char *m_data[GSOCK_MAX_EVENT];
char *m_gui_dependent;
};
/* Definition of GAddress */
struct _GAddress
{
struct sockaddr *m_addr;
size_t m_len;
GAddressType m_family;
int m_realfamily;
GSocketError m_error;
};
/* Input / Output */
GSocketError _GSocket_Input_Timeout(GSocket *socket);
GSocketError _GSocket_Output_Timeout(GSocket *socket);
int _GSocket_Recv_Stream(GSocket *socket, char *buffer, int size);
int _GSocket_Recv_Dgram(GSocket *socket, char *buffer, int size);
int _GSocket_Send_Stream(GSocket *socket, const char *buffer, int size);
int _GSocket_Send_Dgram(GSocket *socket, const char *buffer, int size);
/* Callbacks */
void _GSocket_Enable(GSocket *socket, GSocketEvent event);
void _GSocket_Disable(GSocket *socket, GSocketEvent event);
void _GSocket_Detected_Read(GSocket *socket);
void _GSocket_Detected_Write(GSocket *socket);
void _GSocket_GUI_Init(GSocket *socket);
void _GSocket_GUI_Destroy(GSocket *socket);
void _GSocket_Enable_Events(GSocket *socket);
void _GSocket_Disable_Events(GSocket *socket);
void _GSocket_Install_Callback(GSocket *socket, GSocketEvent event);
void _GSocket_Uninstall_Callback(GSocket *socket, GSocketEvent event);
/* GAddress */
GSocketError _GAddress_translate_from(GAddress *address,
struct sockaddr *addr, int len);
GSocketError _GAddress_translate_to(GAddress *address,
struct sockaddr **addr, int *len);
GSocketError _GAddress_Init_INET(GAddress *address);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* wxUSE_SOCKETS || defined(__GSOCKET_STANDALONE__) */
#endif /* __GSOCK_UNX_H */

View File

@@ -37,6 +37,24 @@
#include "wx/os2/private.h" #include "wx/os2/private.h"
#if defined(__VISAGECPP__) && __IBMCPP__ < 400
#include <machine\endian.h>
#include <ioctl.h>
#include <select.h>
#include <unistd.h>
#else
#include <sys\ioctl.h>
#include <sys\select.h>
#ifndef __EMX__
#define select(a,b,c,d,e) bsdselect(a,b,c,d,e)
int _System bsdselect(int,
struct fd_set *,
struct fd_set *,
struct fd_set *,
struct timeval *);
#endif
#endif
#if wxUSE_THREADS #if wxUSE_THREADS
#include "wx/thread.h" #include "wx/thread.h"
@@ -100,6 +118,92 @@ MRESULT EXPENTRY wxFrameWndProc( HWND hWnd,ULONG message,MPARAM mp1,MPARAM mp2);
// implementation // implementation
// =========================================================================== // ===========================================================================
// ---------------------------------------------------------------------------
// helper struct and functions for socket handling
// ---------------------------------------------------------------------------
struct GsocketCallbackInfo{
void (*proc)(void *);
int type;
int handle;
void* gsock;
};
// These defines and wrapper functions are used here and in gsockpm.c
#define wxSockReadMask 0x01
#define wxSockWriteMask 0x02
extern "C"
int wxAppAddSocketHandler(int handle, int mask,
void (*callback)(void*), void * gsock)
{
return wxTheApp->AddSocketHandler(handle, mask, callback, gsock);
}
extern "C"
void wxAppRemoveSocketHandler(int handle)
{
wxTheApp->RemoveSocketHandler(handle);
}
void wxApp::HandleSockets()
{
bool pendingEvent = false;
// Check whether it's time for Gsocket operation
if (m_maxSocketHandles > 0 && m_maxSocketNr > 0)
{
fd_set readfds = m_readfds;
fd_set writefds = m_writefds;
struct timeval timeout;
int i;
struct GsocketCallbackInfo
*CallbackInfo = (struct GsocketCallbackInfo *)m_sockCallbackInfo;
int r = 0;
timeout.tv_sec = 0;
timeout.tv_usec = 0;
if ( select(m_maxSocketNr, &readfds, &writefds, 0, &timeout) > 0)
{
for (i = m_lastUsedHandle + 1; i != m_lastUsedHandle; i++)
{
if (i == m_maxSocketNr)
i = 0;
if (FD_ISSET(i, &readfds))
{
int r;
for (r = 0; r < m_maxSocketHandles; r++){
if(CallbackInfo[r].handle == i &&
CallbackInfo[r].type == wxSockReadMask)
break;
}
if (r < m_maxSocketHandles)
{
CallbackInfo[r].proc(CallbackInfo[r].gsock);
pendingEvent = true;
wxYield();
}
}
if (FD_ISSET(i, &writefds))
{
int r;
for (r = 0; r < m_maxSocketHandles; r++)
if(CallbackInfo[r].handle == i &&
CallbackInfo[r].type == wxSockWriteMask)
break;
if (r < m_maxSocketHandles)
{
CallbackInfo[r].proc(CallbackInfo[r].gsock);
pendingEvent = true;
wxYield();
}
}
}
m_lastUsedHandle = i;
}
if (pendingEvent)
wxYield();
}
}
// --------------------------------------------------------------------------- // ---------------------------------------------------------------------------
// wxApp // wxApp
// --------------------------------------------------------------------------- // ---------------------------------------------------------------------------
@@ -560,6 +664,9 @@ wxApp::wxApp()
m_exitOnFrameDelete = TRUE; m_exitOnFrameDelete = TRUE;
m_bAuto3D = TRUE; m_bAuto3D = TRUE;
m_hMq = 0; m_hMq = 0;
m_maxSocketHandles = 0;
m_maxSocketNr = 0;
m_sockCallbackInfo = 0;
} // end of wxApp::wxApp } // end of wxApp::wxApp
wxApp::~wxApp() wxApp::~wxApp()
@@ -590,6 +697,7 @@ bool wxApp::Initialized()
// Get and process a message, returning FALSE if WM_QUIT // Get and process a message, returning FALSE if WM_QUIT
// received (and also set the flag telling the app to exit the main loop) // received (and also set the flag telling the app to exit the main loop)
// //
bool wxApp::DoMessage() bool wxApp::DoMessage()
{ {
BOOL bRc = ::WinGetMsg(vHabmain, &svCurrentMsg, HWND(NULL), 0, 0); BOOL bRc = ::WinGetMsg(vHabmain, &svCurrentMsg, HWND(NULL), 0, 0);
@@ -694,11 +802,17 @@ int wxApp::MainLoop()
#if wxUSE_THREADS #if wxUSE_THREADS
wxMutexGuiLeaveOrEnter(); wxMutexGuiLeaveOrEnter();
#endif // wxUSE_THREADS #endif // wxUSE_THREADS
while (/*Pending() &&*/ ProcessIdle()) while (!Pending() && ProcessIdle())
{ {
// wxUsleep(10000); HandleSockets();
wxUsleep(10000);
} }
DoMessage(); HandleSockets();
if (Pending())
DoMessage();
else
wxUsleep(10000);
} }
return (int)svCurrentMsg.mp1; return (int)svCurrentMsg.mp1;
} // end of wxApp::MainLoop } // end of wxApp::MainLoop
@@ -1041,6 +1155,54 @@ wxIcon wxApp::GetStdIcon(
return wxIcon("wxICON_ERROR"); return wxIcon("wxICON_ERROR");
} // end of wxApp::GetStdIcon } // end of wxApp::GetStdIcon
int wxApp::AddSocketHandler(int handle, int mask,
void (*callback)(void*), void * gsock)
{
int find;
struct GsocketCallbackInfo
*CallbackInfo = (struct GsocketCallbackInfo *)m_sockCallbackInfo;
for (find = 0; find < m_maxSocketHandles; find++)
if (CallbackInfo[find].handle == -1)
break;
if (find == m_maxSocketHandles)
{
// Allocate new memory
m_sockCallbackInfo = realloc(m_sockCallbackInfo,
(m_maxSocketHandles+=10)*
sizeof(struct GsocketCallbackInfo));
CallbackInfo = (struct GsocketCallbackInfo *)m_sockCallbackInfo;
for (find = m_maxSocketHandles - 10; find < m_maxSocketHandles; find++)
CallbackInfo[find].handle = -1;
find = m_maxSocketHandles - 10;
}
CallbackInfo[find].proc = callback;
CallbackInfo[find].type = mask;
CallbackInfo[find].handle = handle;
CallbackInfo[find].gsock = gsock;
if (mask & wxSockReadMask)
FD_SET(handle, &m_readfds);
if (mask & wxSockWriteMask)
FD_SET(handle, &m_writefds);
if (handle >= m_maxSocketNr)
m_maxSocketNr = handle + 1;
return find;
}
void wxApp::RemoveSocketHandler(int handle)
{
struct GsocketCallbackInfo
*CallbackInfo = (struct GsocketCallbackInfo *)m_sockCallbackInfo;
if (handle < m_maxSocketHandles)
{
if (CallbackInfo[handle].type & wxSockReadMask)
FD_CLR(CallbackInfo[handle].handle, &m_readfds);
if (CallbackInfo[handle].type & wxSockWriteMask)
FD_CLR(CallbackInfo[handle].handle, &m_writefds);
CallbackInfo[handle].handle = -1;
}
}
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// wxWakeUpIdle // wxWakeUpIdle
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------

File diff suppressed because it is too large Load Diff

119
src/os2/gsockpm.c Normal file
View File

@@ -0,0 +1,119 @@
/* -------------------------------------------------------------------------
* Project: GSocket (Generic Socket) for WX
* Name: gsockpm.c
* Purpose: GSocket: PM part
* CVSID: $Id$
* ------------------------------------------------------------------------- */
#include "wx/setup.h"
#if wxUSE_SOCKETS
#include <stdlib.h>
#include "wx/unix/gsockunx.h"
#include "wx/gsocket.h"
extern int wxAppAddSocketHandler(int handle, int mask,
void (*callback)(void*), void * gsock);
extern void wxAppRemoveSocketHandler(int handle);
#define wxSockReadMask 0x01
#define wxSockWriteMask 0x02
static void _GSocket_PM_Input(void *data)
{
GSocket *socket = (GSocket *) data;
_GSocket_Detected_Read(socket);
}
static void _GSocket_PM_Output(void *data)
{
GSocket *socket = (GSocket *) data;
_GSocket_Detected_Write(socket);
}
int _GSocket_GUI_Init(GSocket *socket)
{
int *m_id;
socket->m_gui_dependent = (char *)malloc(sizeof(int)*2);
m_id = (int *)(socket->m_gui_dependent);
m_id[0] = -1;
m_id[1] = -1;
return TRUE;
}
void _GSocket_GUI_Destroy(GSocket *socket)
{
free(socket->m_gui_dependent);
}
void _GSocket_Install_Callback(GSocket *socket, GSocketEvent event)
{
int *m_id = (int *)(socket->m_gui_dependent);
int c;
if (socket->m_fd == -1)
return;
switch (event)
{
case GSOCK_LOST: /* fall-through */
case GSOCK_INPUT: c = 0; break;
case GSOCK_OUTPUT: c = 1; break;
case GSOCK_CONNECTION: c = ((socket->m_server) ? 0 : 1); break;
default: return;
}
if (m_id[c] != -1)
wxAppRemoveSocketHandler(m_id[c]);
if (c == 0)
{
m_id[0] = wxAppAddSocketHandler(socket->m_fd, wxSockReadMask,
_GSocket_PM_Input, (void *)socket);
}
else
{
m_id[1] = wxAppAddSocketHandler(socket->m_fd, wxSockWriteMask,
_GSocket_PM_Output, (void *)socket);
}
}
void _GSocket_Uninstall_Callback(GSocket *socket, GSocketEvent event)
{
int *m_id = (int *)(socket->m_gui_dependent);
int c;
switch (event)
{
case GSOCK_LOST: /* fall-through */
case GSOCK_INPUT: c = 0; break;
case GSOCK_OUTPUT: c = 1; break;
case GSOCK_CONNECTION: c = ((socket->m_server) ? 0 : 1); break;
default: return;
}
if (m_id[c] != -1)
wxAppRemoveSocketHandler(m_id[c]);
m_id[c] = -1;
}
void _GSocket_Enable_Events(GSocket *socket)
{
_GSocket_Install_Callback(socket, GSOCK_INPUT);
_GSocket_Install_Callback(socket, GSOCK_OUTPUT);
}
void _GSocket_Disable_Events(GSocket *socket)
{
_GSocket_Uninstall_Callback(socket, GSOCK_INPUT);
_GSocket_Uninstall_Callback(socket, GSOCK_OUTPUT);
}
#else /* !wxUSE_SOCKETS */
/* some compilers don't like having empty source files */
static int wxDummyGsockVar = 0;
#endif /* wxUSE_SOCKETS/!wxUSE_SOCKETS */