X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6a4cbac17af82fdf6b8220b309da74b735d616fb..e3d6cbb9aa8ba6fbd05066be093ee2b5f14fcea6:/src/common/protocol.cpp?ds=sidebyside diff --git a/src/common/protocol.cpp b/src/common/protocol.cpp index 75981c5bb3..1f508709eb 100644 --- a/src/common/protocol.cpp +++ b/src/common/protocol.cpp @@ -19,24 +19,20 @@ #if wxUSE_PROTOCOL #include "wx/protocol/protocol.h" +#include "wx/protocol/log.h" #ifndef WX_PRECOMP #include "wx/module.h" #endif #include "wx/url.h" +#include "wx/log.h" #include -///////////////////////////////////////////////////////////////// +// ---------------------------------------------------------------------------- // wxProtoInfo -///////////////////////////////////////////////////////////////// - -/* - * -------------------------------------------------------------- - * --------- wxProtoInfo CONSTRUCTOR ---------------------------- - * -------------------------------------------------------------- - */ +// ---------------------------------------------------------------------------- wxProtoInfo::wxProtoInfo(const wxChar *name, const wxChar *serv, const bool need_host1, wxClassInfo *info) @@ -53,9 +49,10 @@ wxProtoInfo::wxProtoInfo(const wxChar *name, const wxChar *serv, #endif } -///////////////////////////////////////////////////////////////// -// wxProtocol /////////////////////////////////////////////////// -///////////////////////////////////////////////////////////////// + +// ---------------------------------------------------------------------------- +// wxProtocol +// ---------------------------------------------------------------------------- #if wxUSE_SOCKETS IMPLEMENT_ABSTRACT_CLASS(wxProtocol, wxSocketClient) @@ -68,6 +65,9 @@ wxProtocol::wxProtocol() : wxSocketClient() #endif { + m_lastError = wxPROTO_NOERR; + m_log = NULL; + SetDefaultTimeout(60); // default timeout is 60 seconds } #if wxUSE_SOCKETS @@ -90,6 +90,19 @@ bool wxProtocol::Reconnect() return true; } +void wxProtocol::SetDefaultTimeout(wxUint32 Value) +{ + m_uiDefaultTimeout = Value; +#if wxUSE_SOCKETS + wxSocketBase::SetTimeout(Value); // sets it for this socket +#endif +} + +wxProtocol::~wxProtocol() +{ + delete m_log; +} + // ---------------------------------------------------------------------------- // Read a line from socket // ---------------------------------------------------------------------------- @@ -173,4 +186,32 @@ wxProtocolError wxProtocol::ReadLine(wxString& result) #endif // wxUSE_SOCKETS +// ---------------------------------------------------------------------------- +// logging +// ---------------------------------------------------------------------------- + +void wxProtocol::SetLog(wxProtocolLog *log) +{ + delete m_log; + m_log = log; +} + +void wxProtocol::LogRequest(const wxString& str) +{ + if ( m_log ) + m_log->LogRequest(str); +} + +void wxProtocol::LogResponse(const wxString& str) +{ + if ( m_log ) + m_log->LogResponse(str); +} + +void wxProtocolLog::DoLogString(const wxString& str) +{ + wxUnusedVar(str); // unused if wxLogTrace() is disabled + wxLogTrace(m_traceMask, "%s", str); +} + #endif // wxUSE_PROTOCOL