X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f6bcfd974ef26faf6f91a62cac09827e09463fd1..8a31648287be0ef976f133de2786b137f1e98340:/samples/ipc/server.h?ds=sidebyside diff --git a/samples/ipc/server.h b/samples/ipc/server.h index ac85cd4b0d..a81a4421cc 100644 --- a/samples/ipc/server.h +++ b/samples/ipc/server.h @@ -9,16 +9,28 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// +#include "connection.h" + +enum +{ + ID_START = 10000, + ID_DISCONNECT, + ID_ADVISE, + ID_SERVERNAME, +}; + // Define a new application class MyServer; +class MyFrame; + class MyApp : public wxApp { public: virtual bool OnInit(); - virtual int OnExit(); + MyFrame *GetFrame() { return m_frame; } -private: - MyServer *m_server; +protected: + MyFrame *m_frame; }; DECLARE_APP(MyApp) @@ -29,54 +41,64 @@ class MyFrame : public wxFrame public: MyFrame(wxFrame *frame, const wxString& title); - void OnListBoxClick(wxCommandEvent& event); - void OnExit(wxCommandEvent& event); + void OnClose(wxCloseEvent& event); -private: - wxPanel *panel; + void UpdateUI(); + void Disconnect(); - DECLARE_EVENT_TABLE() -}; +protected: + wxButton* GetStart() { return (wxButton*) FindWindow( ID_START ); } + wxChoice* GetServername() { return (wxChoice*) FindWindow( ID_SERVERNAME ); } + wxButton* GetDisconnect() { return (wxButton*) FindWindow( ID_DISCONNECT ); } + wxButton* GetAdvise() { return (wxButton*) FindWindow( ID_ADVISE ); } -class IPCDialogBox; -class MyConnection : public wxConnection -{ -public: - MyConnection(char *buf, int size); - ~MyConnection(); - bool OnExecute(const wxString& topic, char *data, int size, wxIPCFormat format); - char *OnRequest(const wxString& topic, const wxString& item, int *size, wxIPCFormat format); - bool OnPoke(const wxString& topic, const wxString& item, char *data, int size, wxIPCFormat format); - bool OnStartAdvise(const wxString& topic, const wxString& item); + MyServer *m_server; + + void OnStart( wxCommandEvent &event ); + void OnServerName( wxCommandEvent &event ); + void OnDisconnect( wxCommandEvent &event ); + void OnAdvise( wxCommandEvent &event ); -private: - IPCDialogBox *dialog; + DECLARE_EVENT_TABLE() }; -class MyServer: public wxServer +class MyConnection : public MyConnectionBase { public: - wxConnectionBase *OnAcceptConnection(const wxString& topic); + virtual bool OnExecute(const wxString& topic, const void *data, size_t size, wxIPCFormat format); + virtual const void *OnRequest(const wxString& topic, const wxString& item, size_t *size, wxIPCFormat format); + virtual bool OnPoke(const wxString& topic, const wxString& item, const void *data, size_t size, wxIPCFormat format); + virtual bool OnStartAdvise(const wxString& topic, const wxString& item); + virtual bool OnStopAdvise(const wxString& topic, const wxString& item); + virtual bool DoAdvise(const wxString& item, const void *data, size_t size, wxIPCFormat format); + virtual bool OnDisconnect(); + + // topic for which we advise the client or empty if none + wxString m_advise; + +protected: + // the data returned by last OnRequest(): we keep it in this buffer to + // ensure that the pointer we return from OnRequest() stays valid + wxCharBuffer m_requestData; }; -class IPCDialogBox: public wxDialog +class MyServer : public wxServer { public: - IPCDialogBox(wxWindow *parent, - const wxString& title, - const wxPoint& pos, - const wxSize& size, - MyConnection *the_connection); + MyServer(); + virtual ~MyServer(); - void OnQuit(wxCommandEvent& event); + void Disconnect(); + bool IsConnected() { return m_connection != NULL; } + MyConnection *GetConnection() { return m_connection; } -private: - MyConnection *m_connection; + void Advise(); + bool CanAdvise() { return m_connection && !m_connection->m_advise.empty(); } - DECLARE_EVENT_TABLE() + virtual wxConnectionBase *OnAcceptConnection(const wxString& topic); + +protected: + MyConnection *m_connection; }; -#define SERVER_EXIT wxID_EXIT -#define SERVER_LISTBOX 500 -#define SERVER_QUIT_BUTTON 501