show the string received from client in test 2 correctly; use TestLogger just as in the client; use wxCharBuffer instead of manual new/delete
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@57724 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -81,6 +81,24 @@ private:
|
|||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// simple helper class to log start and end of each test
|
||||||
|
class TestLogger
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
TestLogger(const wxString& name) : m_name(name)
|
||||||
|
{
|
||||||
|
wxLogMessage("=== %s begins ===", m_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
~TestLogger()
|
||||||
|
{
|
||||||
|
wxLogMessage("=== %s ends ===", m_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
const wxString m_name;
|
||||||
|
};
|
||||||
|
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
// constants
|
// constants
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
@@ -169,6 +187,7 @@ MyFrame::MyFrame() : wxFrame((wxFrame *)NULL, wxID_ANY,
|
|||||||
_("Welcome to wxSocket demo: Server\n"),
|
_("Welcome to wxSocket demo: Server\n"),
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
wxTE_MULTILINE | wxTE_READONLY);
|
wxTE_MULTILINE | wxTE_READONLY);
|
||||||
|
delete wxLog::SetActiveTarget(new wxLogTextCtrl(m_text));
|
||||||
|
|
||||||
// Create the address - defaults to localhost:0 initially
|
// Create the address - defaults to localhost:0 initially
|
||||||
#if wxUSE_IPV6
|
#if wxUSE_IPV6
|
||||||
@@ -184,12 +203,12 @@ MyFrame::MyFrame() : wxFrame((wxFrame *)NULL, wxID_ANY,
|
|||||||
// We use Ok() here to see if the server is really listening
|
// We use Ok() here to see if the server is really listening
|
||||||
if (! m_server->Ok())
|
if (! m_server->Ok())
|
||||||
{
|
{
|
||||||
m_text->AppendText(_("Could not listen at the specified port !\n\n"));
|
wxLogMessage("Could not listen at the specified port !");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_text->AppendText(_("Server listening.\n\n"));
|
wxLogMessage("Server listening.");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Setup the event handler and subscribe to connection events
|
// Setup the event handler and subscribe to connection events
|
||||||
@@ -225,10 +244,7 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
|
|||||||
|
|
||||||
void MyFrame::Test1(wxSocketBase *sock)
|
void MyFrame::Test1(wxSocketBase *sock)
|
||||||
{
|
{
|
||||||
unsigned char len;
|
TestLogger logtest("Test 1");
|
||||||
char *buf;
|
|
||||||
|
|
||||||
m_text->AppendText(_("Test 1 begins\n"));
|
|
||||||
|
|
||||||
// Receive data from socket and send it back. We will first
|
// Receive data from socket and send it back. We will first
|
||||||
// get a byte with the buffer size, so we can specify the
|
// get a byte with the buffer size, so we can specify the
|
||||||
@@ -239,54 +255,45 @@ void MyFrame::Test1(wxSocketBase *sock)
|
|||||||
sock->SetFlags(wxSOCKET_WAITALL);
|
sock->SetFlags(wxSOCKET_WAITALL);
|
||||||
|
|
||||||
// Read the size
|
// Read the size
|
||||||
|
unsigned char len;
|
||||||
sock->Read(&len, 1);
|
sock->Read(&len, 1);
|
||||||
buf = new char[len];
|
wxCharBuffer buf(len);
|
||||||
|
|
||||||
// Read the data
|
// Read the data
|
||||||
sock->Read(buf, len);
|
sock->Read(buf.data(), len);
|
||||||
m_text->AppendText(_("Got the data, sending it back\n"));
|
wxLogMessage("Got the data, sending it back");
|
||||||
|
|
||||||
// Write it back
|
// Write it back
|
||||||
sock->Write(buf, len);
|
sock->Write(buf, len);
|
||||||
delete[] buf;
|
|
||||||
|
|
||||||
m_text->AppendText(_("Test 1 ends\n\n"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::Test2(wxSocketBase *sock)
|
void MyFrame::Test2(wxSocketBase *sock)
|
||||||
{
|
{
|
||||||
#define MAX_MSG_SIZE 10000
|
char buf[4096];
|
||||||
|
|
||||||
wxString s;
|
TestLogger logtest("Test 2");
|
||||||
wxChar *buf = new wxChar[MAX_MSG_SIZE];
|
|
||||||
wxUint32 len;
|
|
||||||
|
|
||||||
m_text->AppendText(_("Test 2 begins\n"));
|
|
||||||
|
|
||||||
// We don't need to set flags because ReadMsg and WriteMsg
|
// We don't need to set flags because ReadMsg and WriteMsg
|
||||||
// are not affected by them anyway.
|
// are not affected by them anyway.
|
||||||
|
|
||||||
// Read the message
|
// Read the message
|
||||||
len = sock->ReadMsg(buf, MAX_MSG_SIZE * sizeof(wxChar)).LastCount();
|
wxUint32 len = sock->ReadMsg(buf, sizeof(buf)).LastCount();
|
||||||
s.Printf(_("Client says: %s\n"), buf);
|
if ( !len )
|
||||||
m_text->AppendText(s);
|
{
|
||||||
m_text->AppendText(_("Sending the data back\n"));
|
wxLogError("Failed to read message.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxLogMessage("Got \"%s\" from client.", wxString::FromUTF8(buf, len));
|
||||||
|
wxLogMessage("Sending the data back");
|
||||||
|
|
||||||
// Write it back
|
// Write it back
|
||||||
sock->WriteMsg(buf, len);
|
sock->WriteMsg(buf, len);
|
||||||
delete[] buf;
|
|
||||||
|
|
||||||
m_text->AppendText(_("Test 2 ends\n\n"));
|
|
||||||
|
|
||||||
#undef MAX_MSG_SIZE
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::Test3(wxSocketBase *sock)
|
void MyFrame::Test3(wxSocketBase *sock)
|
||||||
{
|
{
|
||||||
unsigned char len;
|
TestLogger logtest("Test 3");
|
||||||
char *buf;
|
|
||||||
|
|
||||||
m_text->AppendText(_("Test 3 begins\n"));
|
|
||||||
|
|
||||||
// This test is similar to the first one, but the len is
|
// This test is similar to the first one, but the len is
|
||||||
// expressed in kbytes - this tests large data transfers.
|
// expressed in kbytes - this tests large data transfers.
|
||||||
@@ -294,18 +301,16 @@ void MyFrame::Test3(wxSocketBase *sock)
|
|||||||
sock->SetFlags(wxSOCKET_WAITALL);
|
sock->SetFlags(wxSOCKET_WAITALL);
|
||||||
|
|
||||||
// Read the size
|
// Read the size
|
||||||
|
unsigned char len;
|
||||||
sock->Read(&len, 1);
|
sock->Read(&len, 1);
|
||||||
buf = new char[len * 1024];
|
wxCharBuffer buf(len*1024);
|
||||||
|
|
||||||
// Read the data
|
// Read the data
|
||||||
sock->Read(buf, len * 1024);
|
sock->Read(buf.data(), len * 1024);
|
||||||
m_text->AppendText(_("Got the data, sending it back\n"));
|
wxLogMessage("Got the data, sending it back");
|
||||||
|
|
||||||
// Write it back
|
// Write it back
|
||||||
sock->Write(buf, len * 1024);
|
sock->Write(buf, len * 1024);
|
||||||
delete[] buf;
|
|
||||||
|
|
||||||
m_text->AppendText(_("Test 3 ends\n\n"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::OnServerEvent(wxSocketEvent& event)
|
void MyFrame::OnServerEvent(wxSocketEvent& event)
|
||||||
@@ -330,11 +335,11 @@ void MyFrame::OnServerEvent(wxSocketEvent& event)
|
|||||||
|
|
||||||
if (sock)
|
if (sock)
|
||||||
{
|
{
|
||||||
m_text->AppendText(_("New client connection accepted\n\n"));
|
wxLogMessage("New client connection accepted");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_text->AppendText(_("Error: couldn't accept a new connection\n\n"));
|
wxLogMessage("Error: couldn't accept a new connection");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -380,7 +385,7 @@ void MyFrame::OnSocketEvent(wxSocketEvent& event)
|
|||||||
case 0xCE: Test2(sock); break;
|
case 0xCE: Test2(sock); break;
|
||||||
case 0xDE: Test3(sock); break;
|
case 0xDE: Test3(sock); break;
|
||||||
default:
|
default:
|
||||||
m_text->AppendText(_("Unknown test id received from client\n\n"));
|
wxLogMessage("Unknown test id received from client");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Enable input events again.
|
// Enable input events again.
|
||||||
@@ -400,7 +405,7 @@ void MyFrame::OnSocketEvent(wxSocketEvent& event)
|
|||||||
// middle of a test or something. Destroy() takes care of all
|
// middle of a test or something. Destroy() takes care of all
|
||||||
// this for us.
|
// this for us.
|
||||||
|
|
||||||
m_text->AppendText(_("Deleting socket.\n\n"));
|
wxLogMessage("Deleting socket.");
|
||||||
sock->Destroy();
|
sock->Destroy();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user