git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@5930 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			144 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        sckipc.h
 | |
| // Purpose:     Interprocess communication implementation (wxSocket version)
 | |
| // Author:      Julian Smart
 | |
| // Modified by: Guilhem Lavaux (big rewrite) May 1997, 1998
 | |
| //              Guillermo Rodriguez (updated for wxSocket v2) Jan 2000
 | |
| // Created:     1993
 | |
| // RCS-ID:      $Id$
 | |
| // Copyright:   (c) Julian Smart 1993
 | |
| //              (c) Guilhem Lavaux 1997, 1998
 | |
| //              (c) 2000 Guillermo Rodriguez <guille@iies.es>
 | |
| // Licence:     wxWindows license
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef _WX_SCKIPC_H
 | |
| #define _WX_SCKIPC_H
 | |
| 
 | |
| #ifdef __GNUG__
 | |
| #pragma interface "sckipc.h"
 | |
| #endif
 | |
| 
 | |
| #include "wx/defs.h"
 | |
| 
 | |
| #if wxUSE_SOCKETS
 | |
| 
 | |
| #include "wx/ipcbase.h"
 | |
| #include "wx/socket.h"
 | |
| #include "wx/sckstrm.h"
 | |
| #include "wx/datstrm.h"
 | |
| 
 | |
| /*
 | |
|  * Mini-DDE implementation
 | |
| 
 | |
|    Most transactions involve a topic name and an item name (choose these
 | |
|    as befits your application).
 | |
| 
 | |
|    A client can:
 | |
| 
 | |
|    - ask the server to execute commands (data) associated with a topic
 | |
|    - request data from server by topic and item
 | |
|    - poke data into the server
 | |
|    - ask the server to start an advice loop on topic/item
 | |
|    - ask the server to stop an advice loop
 | |
| 
 | |
|    A server can:
 | |
| 
 | |
|    - respond to execute, request, poke and advice start/stop
 | |
|    - send advise data to client
 | |
| 
 | |
|    Note that this limits the server in the ways it can send data to the
 | |
|    client, i.e. it can't send unsolicited information.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| class WXDLLEXPORT wxTCPServer;
 | |
| class WXDLLEXPORT wxTCPClient;
 | |
| 
 | |
| class WXDLLEXPORT wxTCPConnection: public wxConnectionBase
 | |
| {
 | |
|   DECLARE_DYNAMIC_CLASS(wxTCPConnection)
 | |
| public:
 | |
|   wxTCPConnection(char *buffer, int size);
 | |
|   wxTCPConnection();
 | |
|   virtual ~wxTCPConnection();
 | |
| 
 | |
|   // Calls that CLIENT can make
 | |
|   virtual bool Execute(const wxChar *data, int size = -1, wxIPCFormat format = wxIPC_TEXT);
 | |
|   virtual char *Request(const wxString& item, int *size = NULL, wxIPCFormat format = wxIPC_TEXT);
 | |
|   virtual bool Poke(const wxString& item, wxChar *data, int size = -1, wxIPCFormat format = wxIPC_TEXT);
 | |
|   virtual bool StartAdvise(const wxString& item);
 | |
|   virtual bool StopAdvise(const wxString& item);
 | |
| 
 | |
|   // Calls that SERVER can make
 | |
|   virtual bool Advise(const wxString& item, wxChar *data, int size = -1, wxIPCFormat format = wxIPC_TEXT);
 | |
| 
 | |
|   // Calls that both can make
 | |
|   virtual bool Disconnect(void);
 | |
| 
 | |
|   // Default behaviour is to delete connection and return TRUE
 | |
|   virtual bool OnDisconnect(void) { delete this; return TRUE; }
 | |
| 
 | |
|   // To enable the compressor
 | |
|   void Compress(bool on);
 | |
| 
 | |
| protected:
 | |
|   wxSocketBase *m_sock;
 | |
|   wxSocketStream *m_sockstrm;
 | |
|   wxDataInputStream *m_codeci;
 | |
|   wxDataOutputStream *m_codeco;
 | |
|   wxString m_topic;
 | |
| 
 | |
|   friend class wxTCPServer;
 | |
|   friend class wxTCPClient;
 | |
|   friend void Client_OnRequest(wxSocketBase&,
 | |
|                                wxSocketNotify, char *);
 | |
|   friend void Server_OnRequest(wxSocketServer&,
 | |
|                                wxSocketNotify, char *);
 | |
| 
 | |
| private:
 | |
|   //
 | |
|   // We're hiding an Execute method in ConnectionBase
 | |
|   //s
 | |
|   virtual bool Execute(const wxString& str)
 | |
|   { return Execute(str, -1, wxIPC_TEXT); }
 | |
| };
 | |
| 
 | |
| class wxTCPServer: public wxServerBase
 | |
| {
 | |
|   DECLARE_DYNAMIC_CLASS(wxTCPServer)
 | |
| 
 | |
| public:
 | |
|   wxTCPConnection *topLevelConnection;
 | |
| 
 | |
|   wxTCPServer();
 | |
|   virtual ~wxTCPServer();
 | |
| 
 | |
|   // Returns FALSE if can't create server (e.g. port number is already in use)
 | |
|   virtual bool Create(const wxString& server_name);
 | |
|   virtual wxConnectionBase *OnAcceptConnection(const wxString& topic);
 | |
| };
 | |
| 
 | |
| class wxTCPClient: public wxClientBase
 | |
| {
 | |
|   DECLARE_DYNAMIC_CLASS(wxTCPClient)
 | |
| 
 | |
| public:
 | |
|   wxTCPClient();
 | |
|   virtual ~wxTCPClient();
 | |
| 
 | |
|   virtual bool ValidHost(const wxString& host);
 | |
|   // Call this to make a connection.
 | |
|   // Returns NULL if cannot.
 | |
|   virtual wxConnectionBase *MakeConnection(const wxString& host,
 | |
|                                            const wxString& server,
 | |
|                                            const wxString& topic);
 | |
| 
 | |
|   // Tailor this to return own connection.
 | |
|   virtual wxConnectionBase *OnMakeConnection();
 | |
| };
 | |
| 
 | |
| #endif // wxUSE_SOCKETS
 | |
| 
 | |
| #endif // ipcsock.h
 |