Added GSocket motif (it compiles but I didn't tested it)

Changed wxSockFlags type (switched to int)


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3105 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Guilhem Lavaux 1999-07-23 17:24:25 +00:00
parent 54c13c66d2
commit dbd300df5c
9 changed files with 149 additions and 35 deletions

View File

@ -3,19 +3,6 @@
* Name: gsocket.h
* Purpose: GSocket include file (system independent)
* CVSID: $Id$
* Log: $Log$
* Log: Revision 1.1 1999/07/22 17:51:47 GL
* Log: Added GSocket for Unix (only GTK for the moment)
* Log: Updated wxSocket to use GSocket API
* Log: Added a progress bar to client.cpp
* Log: Added CopyTo to wxMemoryOutputStream to copy the internal buffer to a specified buffer.
* Log: Various changes/fixes to the high-level protocols FTP/HTTP
* Log: Various Unicode fixes
* Log: Removed sckint.*
* Log:
* Log: Revision 1.2 1999/07/18 15:54:28 guilhem
* Log: Copyright, etc.
* Log:
* -------------------------------------------------------------------------
*/
#ifndef __GSOCKET_H

View File

@ -39,7 +39,8 @@ class WXDLLEXPORT wxSocketBase : public wxEvtHandler
DECLARE_CLASS(wxSocketBase)
public:
enum wxSockFlags { NONE=0, NOWAIT=1, WAITALL=2, SPEED=4 };
enum { NONE=0, NOWAIT=1, WAITALL=2, SPEED=4 };
typedef int wxSockFlags;
// Type of request
enum wxSockType { SOCK_CLIENT, SOCK_SERVER, SOCK_INTERNAL, SOCK_UNINIT };

View File

@ -83,7 +83,7 @@ wxSocketBase::wxSocketBase(wxSocketBase::wxSockFlags _flags,
wxSocketBase::wxSocketBase() :
wxEvtHandler(),
m_socket(NULL), m_flags((wxSockFlags)SPEED | WAITALL), m_type(SOCK_UNINIT),
m_socket(NULL), m_flags(SPEED | WAITALL), m_type(SOCK_UNINIT),
m_neededreq(GSOCK_INPUT_FLAG | GSOCK_LOST_FLAG),
m_lcount(0), m_timeout(3600),
m_unread(NULL), m_unrd_size(0), m_unrd_cur(0),
@ -413,7 +413,7 @@ void wxSocketBase::Discard()
size_t recv_size = MAX_BUFSIZE;
SaveState();
SetFlags((wxSockFlags)(NOWAIT | SPEED));
SetFlags(NOWAIT | SPEED);
while (recv_size == MAX_BUFSIZE)
{

View File

@ -1,3 +1,10 @@
/* -------------------------------------------------------------------------
* Project: GSocket (Generic Socket) for WX
* Name: gsockgtk.c
* Purpose: GSocket: GTK part
* CVSID: $Id$
* -------------------------------------------------------------------------
*/
#include <stdlib.h>
#include <gdk/gdk.h>
#include <glib.h>

View File

@ -1,3 +1,10 @@
/* -------------------------------------------------------------------------
* Project: GSocket (Generic Socket) for WX
* Name: gsockgtk.c
* Purpose: GSocket: GTK part
* CVSID: $Id$
* -------------------------------------------------------------------------
*/
#include <stdlib.h>
#include <gdk/gdk.h>
#include <glib.h>

View File

@ -31,6 +31,8 @@ libwx_motif_la_SOURCES = \
extended.c \
parser.c \
xmcombo.c \
gsocket.c \
gsockmot.cpp \
\
cmndata.cpp \
dynarray.cpp \
@ -90,7 +92,6 @@ libwx_motif_la_SOURCES = \
resource.cpp \
sckaddr.cpp \
sckfile.cpp \
sckint.cpp \
sckipc.cpp \
sckstrm.cpp \
serbase.cpp \

120
src/motif/gsockmot.cpp Normal file
View File

@ -0,0 +1,120 @@
// -------------------------------------------------------------------------
// Project: GSocket (Generic Socket) for WX
// Name: gsockmot.cpp
// Purpose: GSocket: Motif part
// CVSID: $Id$
// Log: $Log$
// Log: Revision 1.1 1999/07/23 17:24:24 GL
// Log: Added GSocket motif (it compiles but I didn't tested it)
// Log: Changed wxSockFlags type (switched to int)
// Log:
// -------------------------------------------------------------------------
#include <stdlib.h>
#include <X11/Intrinsic.h>
#include <wx/gsocket.h>
#include <wx/app.h>
#include "../unix/gsockunx.h"
#define wxAPP_CONTEXT ((XtAppContext)wxTheApp->GetAppContext())
static void _GSocket_Motif_Input(XtPointer data, int *fid,
XtInputId *id)
{
GSocket *socket = (GSocket *)data;
_GSocket_Detected_Read(socket);
}
static void _GSocket_Motif_Output(XtPointer data, int *fid,
XtInputId *id)
{
GSocket *socket = (GSocket *)data;
_GSocket_Detected_Write(socket);
}
void _GSocket_GUI_Init(GSocket *socket)
{
int i;
int *m_id;
socket->m_gui_dependent = (char *)malloc(sizeof(int)*3);
m_id = (int *)(socket->m_gui_dependent);
for (i=0;i<3;i++)
m_id[i] = -1;
}
void _GSocket_GUI_Destroy(GSocket *socket)
{
int i;
int *m_id;
m_id = (int *)(socket->m_gui_dependent);
for (i=0;i<3;i++)
if (m_id[i] == -1)
XtRemoveInput(m_id[i]);
free(socket->m_gui_dependent);
}
void _GSocket_Install_Fallback(GSocket *socket, GSocketEvent event)
{
int *m_id;
m_id = (int *)(socket->m_gui_dependent);
switch (event) {
case GSOCK_CONNECTION:
case GSOCK_LOST:
case GSOCK_INPUT:
if (m_id[0] != -1)
XtRemoveInput(m_id[0]);
m_id[0] = XtAppAddInput(wxAPP_CONTEXT, socket->m_fd,
(XtPointer *)XtInputReadMask,
(XtInputCallbackProc) _GSocket_Motif_Input,
(XtPointer) socket);
break;
case GSOCK_OUTPUT:
if (m_id[1] != -1)
XtRemoveInput(m_id[1]);
m_id[1] = XtAppAddInput(wxAPP_CONTEXT, socket->m_fd,
(XtPointer *)XtInputWriteMask,
(XtInputCallbackProc) _GSocket_Motif_Output,
(XtPointer) socket);
break;
default: return;
}
}
void _GSocket_Uninstall_Fallback(GSocket *socket, GSocketEvent event)
{
int c;
int *m_id;
m_id = (int *)(socket->m_gui_dependent);
switch (event) {
case GSOCK_CONNECTION:
case GSOCK_LOST:
case GSOCK_INPUT: c = 0; break;
case GSOCK_OUTPUT: c = 1; break;
break;
default: return;
}
if (m_id[c] != -1)
XtRemoveInput(m_id[c]);
m_id[c] = -1;
}
unsigned long GSocket_GetEventID(GSocket *socket)
{
return 0;
}
void GSocket_DoEvent(unsigned long evt_id)
{
}

View File

@ -3,22 +3,6 @@
* Name: gsocket.c
* Purpose: GSocket main Unix file
* CVSID: $Id$
* Log: $Log$
* Log: Revision 1.2 1999/07/23 09:48:31 KB
* Log: Fixed stupid new bugs :-(
* Log:
* Log: Revision 1.1 1999/07/22 17:51:54 GL
* Log: Added GSocket for Unix (only GTK for the moment)
* Log: Updated wxSocket to use GSocket API
* Log: Added a progress bar to client.cpp
* Log: Added CopyTo to wxMemoryOutputStream to copy the internal buffer to a specified buffer.
* Log: Various changes/fixes to the high-level protocols FTP/HTTP
* Log: Various Unicode fixes
* Log: Removed sckint.*
* Log:
* Log: Revision 1.2 1999/07/18 15:52:34 guilhem
* Log: * Copyright, etc.
* Log:
* -------------------------------------------------------------------------
*/
@ -89,11 +73,11 @@ void GSocket_destroy(GSocket *socket)
{
assert(socket != NULL);
_GSocket_GUI_Destroy(socket);
if (socket->m_fd != -1)
GSocket_Shutdown(socket);
_GSocket_GUI_Destroy(socket);
if (socket->m_local)
GAddress_destroy(socket->m_local);

View File

@ -1,3 +1,10 @@
/* -------------------------------------------------------------------------
* Project: GSocket (Generic Socket) for WX
* Name: gsockunx.h
* Purpose: GSocket Unix header
* CVSID: $Id$
* -------------------------------------------------------------------------
*/
#ifndef __GSOCK_UNX_H
#define __GSOCK_UNX_H