mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
155 lines
2.4 KiB
155 lines
2.4 KiB
// Logger.cpp: implementation of the CPersistor class.
|
|
//
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
#include "stdafx.h"
|
|
|
|
#include <string>
|
|
#include <iosfwd>
|
|
#include <iostream>
|
|
#include <fstream>
|
|
#include <ctime>
|
|
#include <list>
|
|
using namespace std;
|
|
|
|
#include <malloc.h>
|
|
#include <tchar.h>
|
|
#include <windows.h>
|
|
#ifdef NONNT5
|
|
typedef unsigned long ULONG_PTR;
|
|
#endif
|
|
#include <wmistr.h>
|
|
#include <guiddef.h>
|
|
#include <initguid.h>
|
|
#include <evntrace.h>
|
|
|
|
#include <WTYPES.H>
|
|
#include "t_string.h"
|
|
|
|
#include "Persistor.h"
|
|
|
|
#include "Utilities.h"
|
|
#include "StructureWrappers.h"
|
|
#include "StructureWapperHelpers.h"
|
|
|
|
#include "Logger.h"
|
|
|
|
|
|
#ifdef _UNICODE
|
|
static TCHAR g_tcBeginFile[] = {0xfeff,0x0d, 0x0a};
|
|
static TCHAR g_atcNL[] = {0x0d, 0x0a, 0x00};
|
|
#endif
|
|
|
|
CLogger::CLogger(LPCTSTR lpctstrFileName, bool bAppend)
|
|
{
|
|
#ifdef _UNICODE
|
|
m_sFileName = NewLPSTR((LPCWSTR) const_cast<LPTSTR>(lpctstrFileName));
|
|
#else
|
|
m_sFileName = NewTCHAR(lpctstrFileName);
|
|
#endif
|
|
|
|
m_pPersistor = new CPersistor(m_sFileName, ios::out, false);
|
|
m_hr = m_pPersistor -> OpenLog(bAppend);
|
|
}
|
|
|
|
CLogger::~CLogger()
|
|
{
|
|
free(m_sFileName);
|
|
delete m_pPersistor;
|
|
}
|
|
|
|
int CLogger::LogTCHAR(LPCTSTR lpctstrOut)
|
|
{
|
|
if (FAILED(m_hr))
|
|
{
|
|
return m_hr;
|
|
}
|
|
|
|
PutALine(m_pPersistor->Stream(), lpctstrOut, -1);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int CLogger::LogTime(time_t &Time)
|
|
{
|
|
if (FAILED(m_hr))
|
|
{
|
|
return m_hr;
|
|
}
|
|
|
|
TCHAR tcArray[26];
|
|
LPCTSTR lpctstrTime = t_ctime(&Time);
|
|
_tcscpy(tcArray,lpctstrTime);
|
|
tcArray[24] = _T('\0');
|
|
TCHAR *p = tcArray;
|
|
|
|
PutALine(m_pPersistor->Stream(), p, -1);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int CLogger::LogULONG(ULONG ul, bool bHex)
|
|
{
|
|
if (FAILED(m_hr))
|
|
{
|
|
return m_hr;
|
|
}
|
|
|
|
if (bHex)
|
|
{
|
|
PutALine(m_pPersistor->Stream(), _T("0x"), -1);
|
|
}
|
|
|
|
PutAULONGVar(m_pPersistor->Stream(), ul, bHex);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int CLogger::LogULONG64(ULONG64 ul, bool bHex)
|
|
{
|
|
if (FAILED(m_hr))
|
|
{
|
|
return m_hr;
|
|
}
|
|
|
|
if (bHex)
|
|
{
|
|
PutALine(m_pPersistor->Stream(), _T("0x"), -1);
|
|
}
|
|
|
|
PutAULONG64Var(m_pPersistor->Stream(), ul);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int CLogger::LogGUID(GUID Guid)
|
|
{
|
|
if (FAILED(m_hr))
|
|
{
|
|
return m_hr;
|
|
}
|
|
|
|
GUIDOut(m_pPersistor->Stream(), Guid);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int CLogger::LogEventTraceProperties(PEVENT_TRACE_PROPERTIES pProps)
|
|
{
|
|
if (FAILED(m_hr))
|
|
{
|
|
return m_hr;
|
|
}
|
|
|
|
if (pProps == NULL)
|
|
{
|
|
PutALine(m_pPersistor->Stream(),_T("_EVENT_TRACE_PROPERTIES Instance NULL\n"),-1);
|
|
return 0;
|
|
}
|
|
|
|
CEventTraceProperties Props(pProps);
|
|
|
|
m_pPersistor->Stream() << Props;
|
|
|
|
return 0;
|
|
}
|