Source code of Windows XP (NT5)
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

// 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;
}