Click here to Skip to main content
15,886,077 members
Articles / Desktop Programming / MFC

Advanced Logging For All Kind of Applications

Rate me:
Please Sign up or sign in to vote.
4.72/5 (13 votes)
23 Feb 2002CPOL5 min read 167.6K   6.2K   116  
Simple to use classes for logging and tracing
/********************************************************************\
	created:		2001/03/22
	created:		22:3:2001   20:21
	filename: 	c:\my projects\dualmagic\controlappl\include\cwinlog.h
	file path:	c:\my projects\dualmagic\controlappl\include
	file base:	cwinlog
	file ext:		h
	author:			Alex Kucherenko
	
	purpose:	
\********************************************************************/

#ifndef _LOG_SYSTEM_WIN_LOG_H_
#define _LOG_SYSTEM_WIN_LOG_H_

#pragma warning( push, 3 )
#pragma warning( disable: 4786 4018 4100 4146 4663 4244 )
#pragma once

#include "CStoreLog.h"
#include "logsync.h"
#include <vector>

typedef std::vector<std::string> TStrArray;
typedef TStrArray::iterator TStrIter;

#define WINDOW_HEIGHT 400
#define WINDOW_LENGTH 600

#define WM_USERSENDMESSAGE WM_USER+1
#define DEF_WINDOW_CLASS_NAME "LoggerClass"

//////////////////////////////////////////////////////////////////////////
//  

class CWinLog : public IStoreLog
{
  public:
    CWinLog( long MaxLines = 1000 );
    virtual ~CWinLog(  );
  
    virtual int FlushData();
    virtual int WriteString( const std::string &Message );
    virtual int SetBufferLimit( long lSize );
  
  protected:
    inline  HWND    CreateLogWindow( void );
    static  LRESULT APIENTRY localWndProc( HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam );
  
  private:
    typedef LOGGER::CAutoCritic     CSyncSection;
    typedef LOGGER::CLogSimpleLock  CSyncLock;

    bool              m_bFirstString;
  
    ULONG             m_lMaxLines;
    TStrArray         m_CurrMessage;
    long              m_lBufferLimit;
    HWND              m_hEdit;
    HWND              m_hWindow;
    CSyncSection      m_CriticalSection;
};

#pragma warning( pop )

#endif /* _LOG_SYSTEM_WIN_LOG_H_ */

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
CEO ArtfulBits Inc.
Ukraine Ukraine
Name:Kucherenko Oleksandr

Born:September 20, 1979

Platforms: Win32, Linux; - well known and MS-DOS; Win16; OS/2 - old time not touched;

Hardware: IBM PC

Programming Languages: Assembler (for Intel 80386); Borland C/C++; Borland Pascal; Object Pascal; Borland C++Builder; Delphi; Perl; Java; Visual C++; Visual J++; UML; XML/XSL; C#; VB.NET; T-SQL; PL/SQL; and etc.

Development Environments: MS Visual Studio 2001-2008; MS Visual C++; Borland Delphi; Borland C++Builder; C/C++ any; Rational Rose; GDPro; Together and etc.

Libraries: STL, ATL, WTL, MFC, NuMega Driver Works, VCL; .NET 1.0, 1.1, 2.0, 3.5; and etc.

Technologies: Client/Server; COM; DirectX; DirectX Media; BDE; HTML/DHTML; ActiveX; Java Servlets; DCOM; COM+; ADO; CORBA; .NET; Windows Forms; GDI/GDI+; and etc.

Application Skills: Databases - design and maintain, support, programming; GUI Design; System Programming, Security; Business Software Development. Win/Web Services development and etc.

Comments and Discussions