added wxProtocolLog class for logging network requests/responses (closes #7464)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@59404 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
55
include/wx/protocol/log.h
Normal file
55
include/wx/protocol/log.h
Normal file
@@ -0,0 +1,55 @@
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Name: wx/protocol/log.h
|
||||
// Purpose: wxProtocolLog class for logging network exchanges
|
||||
// Author: Troelsk, Vadim Zeitlin
|
||||
// Created: 2009-03-06
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2009 Vadim Zeitlin <vadim@wxwidgets.org>
|
||||
// Licence: wxWindows licence
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef _WX_PROTOCOL_LOG_H_
|
||||
#define _WX_PROTOCOL_LOG_H_
|
||||
|
||||
#include "wx/string.h"
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// wxProtocolLog: simple class for logging network requests and responses
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
class WXDLLIMPEXP_NET wxProtocolLog
|
||||
{
|
||||
public:
|
||||
// Create object doing the logging using wxLogTrace() with the specified
|
||||
// trace mask.
|
||||
wxProtocolLog(const wxString& traceMask)
|
||||
: m_traceMask(traceMask)
|
||||
{
|
||||
}
|
||||
|
||||
// Virtual dtor for the base class
|
||||
virtual ~wxProtocolLog() { }
|
||||
|
||||
// Called by wxProtocol-derived classes to actually log something
|
||||
virtual void LogRequest(const wxString& str)
|
||||
{
|
||||
DoLogString("==> " + str);
|
||||
}
|
||||
|
||||
virtual void LogResponse(const wxString& str)
|
||||
{
|
||||
DoLogString("<== " + str);
|
||||
}
|
||||
|
||||
protected:
|
||||
// Can be overridden by the derived classes.
|
||||
virtual void DoLogString(const wxString& str);
|
||||
|
||||
private:
|
||||
const wxString m_traceMask;
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxProtocolLog);
|
||||
};
|
||||
|
||||
#endif // _WX_PROTOCOL_LOG_H_
|
||||
|
@@ -24,6 +24,8 @@
|
||||
#include "wx/socket.h"
|
||||
#endif
|
||||
|
||||
class WXDLLIMPEXP_FWD_NET wxProtocolLog;
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// constants
|
||||
// ----------------------------------------------------------------------------
|
||||
@@ -55,6 +57,7 @@ class WXDLLIMPEXP_NET wxProtocol
|
||||
{
|
||||
public:
|
||||
wxProtocol();
|
||||
virtual ~wxProtocol();
|
||||
|
||||
#if wxUSE_SOCKETS
|
||||
bool Reconnect();
|
||||
@@ -89,6 +92,30 @@ public:
|
||||
{ SetDefaultTimeout(seconds); }
|
||||
|
||||
|
||||
// logging support: each wxProtocol object may have the associated logger
|
||||
// (by default there is none) which is used to log network requests and
|
||||
// responses
|
||||
|
||||
// set the logger, deleting the old one and taking ownership of this one
|
||||
void SetLog(wxProtocolLog *log);
|
||||
|
||||
// return the current logger, may be NULL
|
||||
wxProtocolLog *GetLog() const { return m_log; }
|
||||
|
||||
// detach the existing logger without deleting it, the caller is
|
||||
// responsible for deleting the returned pointer if it's non-NULL
|
||||
wxProtocolLog *DetachLog()
|
||||
{
|
||||
wxProtocolLog * const log = m_log;
|
||||
m_log = NULL;
|
||||
return log;
|
||||
}
|
||||
|
||||
// these functions forward to the same functions with the same names in
|
||||
// wxProtocolLog if we have a valid logger and do nothing otherwise
|
||||
void LogRequest(const wxString& str);
|
||||
void LogResponse(const wxString& str);
|
||||
|
||||
protected:
|
||||
// the timeout associated with the protocol:
|
||||
wxUint32 m_uiDefaultTimeout;
|
||||
@@ -100,6 +127,8 @@ protected:
|
||||
wxProtocolError m_lastError;
|
||||
|
||||
private:
|
||||
wxProtocolLog *m_log;
|
||||
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxProtocol)
|
||||
};
|
||||
|
||||
|
Reference in New Issue
Block a user