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.
1713 lines
44 KiB
1713 lines
44 KiB
/*++
|
|
|
|
© 1998 Seagate Software, Inc. All rights reserved
|
|
|
|
Module Name:
|
|
|
|
wsbtrc.cpp
|
|
|
|
Abstract:
|
|
|
|
This component is a trace object.
|
|
|
|
Author:
|
|
|
|
Chuck Bardeen [cbardeen] 29-Oct-1996
|
|
|
|
Revision History:
|
|
|
|
Brian Dodd [brian] 09-May-1996 - Added event logging
|
|
|
|
--*/
|
|
|
|
#include "stdafx.h"
|
|
#include "time.h"
|
|
|
|
#undef WsbThrow
|
|
#define WsbThrow(hr) throw(hr)
|
|
#include "wsbtrc.h"
|
|
|
|
// Local data
|
|
static WCHAR message[1024]; // Space for formatting a message
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::FinalConstruct(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::FinalConstruct
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
try {
|
|
// Set up global values
|
|
g_pWsbTrace = 0;
|
|
g_WsbTraceModules = WSB_TRACE_BIT_NONE;
|
|
|
|
// Establish Base object
|
|
WsbAffirmHr(CComObjectRoot::FinalConstruct() );
|
|
|
|
// Initialize member data
|
|
m_TraceOn = FALSE;
|
|
m_TraceSettings = WSB_TRACE_BIT_NONE;
|
|
m_TraceFileName = OLESTR("");
|
|
m_TraceOutput = WSB_TRACE_OUT_NONE;
|
|
m_CommitEachEntry = FALSE;
|
|
m_TimeStamp = FALSE;
|
|
m_TraceCount = FALSE;
|
|
m_TraceThreadId = FALSE;
|
|
m_TraceFilePointer = INVALID_HANDLE_VALUE;
|
|
m_WrapMode = FALSE;
|
|
m_RegistrySetting = OLESTR("");
|
|
m_TraceEntryExit = g_WsbTraceEntryExit;
|
|
m_LogLevel = g_WsbLogLevel;
|
|
m_TraceFileCopyName = OLESTR("");
|
|
m_TraceMultipleFilePattern = OLESTR("");
|
|
m_TraceMultipleFileCount = 0;
|
|
m_TraceCountHandle = NULL;
|
|
m_pTraceCountGlobal = NULL;
|
|
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
void
|
|
CWsbTrace::FinalRelease(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::FinalRelease
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
// Stop Trace
|
|
StopTrace();
|
|
|
|
// Free base class
|
|
//
|
|
CComObjectRoot::FinalRelease( );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::StartTrace(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::StartTrace
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
|
|
if (g_pWsbTrace == 0) {
|
|
//
|
|
// Set global variable for quick checking
|
|
//
|
|
WsbAffirmHr(((IUnknown*)(IWsbTrace *)this)->QueryInterface(IID_IWsbTrace, (void**) &g_pWsbTrace));
|
|
//
|
|
// We don't want the reference count bumped for this global so release it here.
|
|
g_pWsbTrace->Release();
|
|
}
|
|
|
|
|
|
//
|
|
// Get hold of the trace count
|
|
//
|
|
if (m_pTraceCountGlobal == NULL) {
|
|
|
|
m_pTraceCountGlobal = &g_WsbTraceCount;
|
|
|
|
m_TraceCountHandle = CreateFileMapping(INVALID_HANDLE_VALUE,
|
|
NULL,
|
|
PAGE_READWRITE,
|
|
0,
|
|
sizeof(ULONG),
|
|
L"Global\\RemoteStorageTraceCountPrivate"
|
|
);
|
|
if (m_TraceCountHandle == NULL) {
|
|
if (GetLastError() == ERROR_ALREADY_EXISTS) {
|
|
//
|
|
// Already open, just get hold of the mapping
|
|
//
|
|
m_TraceCountHandle = OpenFileMapping(FILE_MAP_WRITE,
|
|
FALSE,
|
|
L"Global\\RemoteStorageTraceCountPrivate");
|
|
} else {
|
|
swprintf( message, OLESTR("CWsbTrace::StartTrace: CreateFileMapping failed %d\n"), GetLastError());
|
|
g_pWsbTrace->Print(message);
|
|
}
|
|
}
|
|
|
|
if (m_TraceCountHandle != NULL) {
|
|
m_pTraceCountGlobal = (PLONG) MapViewOfFile(m_TraceCountHandle,
|
|
FILE_MAP_WRITE,
|
|
0,
|
|
0,
|
|
sizeof(ULONG));
|
|
if (!m_pTraceCountGlobal) {
|
|
CloseHandle(m_TraceCountHandle);
|
|
m_pTraceCountGlobal = &g_WsbTraceCount;
|
|
m_TraceCountHandle = NULL;
|
|
swprintf( message, OLESTR("CWsbTrace::StartTrace: MapViewOfFile failed %d\n"), GetLastError());
|
|
g_pWsbTrace->Print(message);
|
|
}
|
|
}
|
|
}
|
|
|
|
//
|
|
// Set local variable to remember the state
|
|
//
|
|
m_TraceOn = TRUE;
|
|
|
|
//
|
|
// If there is a file name defined and file tracing is on
|
|
// Create/open the trace file.
|
|
//
|
|
try {
|
|
|
|
if ((m_TraceOutput & WSB_TRACE_OUT_FILE) &&
|
|
(wcslen(m_TraceFileName) != 0) ) {
|
|
DWORD attributes;
|
|
DWORD bytesReturned;
|
|
USHORT inBuffer = COMPRESSION_FORMAT_DEFAULT;
|
|
DWORD last_error = 0;
|
|
|
|
//
|
|
// If the main file is open, close it.
|
|
//
|
|
if (INVALID_HANDLE_VALUE != m_TraceFilePointer) {
|
|
CloseHandle(m_TraceFilePointer);
|
|
m_TraceFilePointer = INVALID_HANDLE_VALUE;
|
|
}
|
|
|
|
// Adjust the file name (for multiple trace files)
|
|
AdjustFileNames();
|
|
|
|
//
|
|
// If there is a copy file specified, copy to it
|
|
//
|
|
if (m_TraceOutput & WSB_TRACE_OUT_FILE_COPY) {
|
|
if (!MoveFileEx(m_TraceFileName, m_TraceFileCopyName,
|
|
(MOVEFILE_COPY_ALLOWED | MOVEFILE_REPLACE_EXISTING | MOVEFILE_WRITE_THROUGH))) {
|
|
|
|
// If copy fails, keep going
|
|
last_error = GetLastError();
|
|
swprintf( message, OLESTR("CWsbTrace::StartTrace: MoveFileEx failed:%ld\r\n"),
|
|
last_error);
|
|
g_pWsbTrace->Print(message);
|
|
}
|
|
}
|
|
|
|
// Open/create the trace file
|
|
if (m_CommitEachEntry) {
|
|
attributes = FILE_FLAG_WRITE_THROUGH;
|
|
} else {
|
|
attributes = FILE_ATTRIBUTE_NORMAL;
|
|
}
|
|
m_TraceFilePointer = CreateFile(m_TraceFileName,
|
|
GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ, NULL,
|
|
CREATE_ALWAYS, attributes, NULL);
|
|
if (INVALID_HANDLE_VALUE == m_TraceFilePointer) {
|
|
last_error = GetLastError();
|
|
swprintf( message, OLESTR("CWsbTrace::StartTrace: CreateFile failed:%ld\r\n"),
|
|
last_error);
|
|
g_pWsbTrace->Print(message);
|
|
WsbThrow(E_FAIL);
|
|
}
|
|
|
|
// Make the trace file compressed (if possible)
|
|
if (0 == DeviceIoControl(m_TraceFilePointer, FSCTL_SET_COMPRESSION,
|
|
&inBuffer, sizeof(inBuffer), 0, 0, &bytesReturned, 0)) {
|
|
// Failed to make file compressed -- not a fatal error
|
|
last_error = GetLastError();
|
|
swprintf( message,
|
|
OLESTR("CWsbTrace::StartTrace: DeviceIoControl(COMPRESSION) failed:%ld\r\n"),
|
|
last_error);
|
|
g_pWsbTrace->Print(message);
|
|
}
|
|
}
|
|
} WsbCatch( hr );
|
|
|
|
swprintf( message, OLESTR("Trace Started (%d-%ls)\r\n"),
|
|
VER_PRODUCTBUILD, RsBuildVersionAsString(RS_BUILD_VERSION));
|
|
WsbAffirmHr(g_pWsbTrace->Print(message));
|
|
|
|
} WsbCatch (hr);
|
|
|
|
|
|
return(hr);
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::StopTrace(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::StopTrace
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
|
|
//
|
|
// Set global variable for quick checking
|
|
//
|
|
if (g_pWsbTrace != 0) {
|
|
g_pWsbTrace->Print(OLESTR("Trace Stopped\r\n"));
|
|
//
|
|
// Don't release here.
|
|
//
|
|
//g_pWsbTrace->Release();
|
|
g_pWsbTrace = 0;
|
|
}
|
|
|
|
//
|
|
// Set local variable to remember the state
|
|
//
|
|
m_TraceOn = FALSE;
|
|
|
|
//
|
|
// Close the file handle
|
|
//
|
|
if (m_TraceFilePointer != INVALID_HANDLE_VALUE) {
|
|
CloseHandle(m_TraceFilePointer);
|
|
m_TraceFilePointer = INVALID_HANDLE_VALUE;
|
|
}
|
|
|
|
if (m_TraceCountHandle != NULL) {
|
|
BOOL b;
|
|
|
|
CloseHandle(m_TraceCountHandle);
|
|
m_TraceCountHandle = NULL;
|
|
//
|
|
// We should have a macro to assert without
|
|
// throwing HR's
|
|
// After one is added, a good assert here would be:
|
|
// ASSERT(m_pTraceCountGlobal != NULL);
|
|
//
|
|
b = UnmapViewOfFile(m_pTraceCountGlobal);
|
|
//
|
|
// And another here would be:
|
|
// ASSERT(b);
|
|
//
|
|
m_pTraceCountGlobal = NULL;
|
|
}
|
|
|
|
} WsbCatch (hr);
|
|
|
|
return(hr);
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::AdjustFileNames(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Make sure trace flags are set correctly and parse file names if we
|
|
haven't already. If we're doing multiple trace files (instead of
|
|
wrapping), adjust the trace and copy file names.
|
|
|
|
Arguments:
|
|
|
|
None.
|
|
|
|
Return Value:
|
|
|
|
S_OK - Success
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
// If we haven't yet, parse file names & set flags.
|
|
if (!(m_TraceOutput & WSB_TRACE_OUT_FLAGS_SET)) {
|
|
OLECHAR *pc_original;
|
|
OLECHAR *pc_bslash;
|
|
CWsbStringPtr str_temp(m_TraceFileName);
|
|
|
|
// Reset flags & file info
|
|
m_TraceOutput &= ~WSB_TRACE_OUT_MULTIPLE_FILES;
|
|
m_TraceOutput &= ~WSB_TRACE_OUT_FILE_COPY;
|
|
m_TraceFileDir = "";
|
|
m_TraceMultipleFilePattern = "";
|
|
m_TraceFileCopyDir = "";
|
|
|
|
// Parse the trace file name. One or more '*'s means we should
|
|
// do multiple trace files. The number of '*'s indicates
|
|
// how many digits to use for the file count. Separate the
|
|
// directory from the file name.
|
|
pc_bslash = wcsrchr(str_temp, OLECHAR('\\'));
|
|
|
|
if (pc_bslash) {
|
|
|
|
*pc_bslash = OLECHAR('\0');
|
|
|
|
// Get the trace directory
|
|
m_TraceFileDir = str_temp;
|
|
m_TraceFileDir.Append("\\");
|
|
|
|
// Point to the file name (which may contain a pattern)
|
|
pc_bslash++;
|
|
} else {
|
|
// No directory specified
|
|
pc_bslash = static_cast<OLECHAR *>(str_temp);
|
|
}
|
|
|
|
// Get the file name
|
|
m_TraceMultipleFilePattern = pc_bslash;
|
|
|
|
// Look for '*'s in the file name
|
|
pc_original = wcschr(pc_bslash, OLECHAR('*'));
|
|
|
|
// Convert a file pattern for use in sprintf
|
|
if (pc_original) {
|
|
OLECHAR format[16];
|
|
OLECHAR *pc_copy;
|
|
int star_count = 0;
|
|
|
|
// Count *'s
|
|
while (OLECHAR('*') == *pc_original) {
|
|
star_count++;
|
|
pc_original++;
|
|
}
|
|
|
|
// Create file name pattern: replace '*'s with printf
|
|
// type format specification (e.g. "%3.3d")
|
|
pc_copy = wcschr(m_TraceMultipleFilePattern, OLECHAR('*'));
|
|
WsbAffirm(pc_copy, E_FAIL);
|
|
*pc_copy = OLECHAR('\0');
|
|
|
|
swprintf(format, OLESTR("%%%d.%dd"), star_count, star_count);
|
|
m_TraceMultipleFilePattern.Append(format);
|
|
m_TraceMultipleFilePattern.Append(pc_original);
|
|
|
|
// Set multiple flag
|
|
m_TraceOutput |= WSB_TRACE_OUT_MULTIPLE_FILES;
|
|
}
|
|
|
|
// If we're doing file copies, set the flag.
|
|
if (wcslen(m_TraceFileCopyName)) {
|
|
m_TraceOutput |= WSB_TRACE_OUT_FILE_COPY;
|
|
|
|
// Get the copy directory
|
|
str_temp = m_TraceFileCopyName;
|
|
pc_bslash = wcsrchr(str_temp, OLECHAR('\\'));
|
|
if (pc_bslash) {
|
|
*pc_bslash = OLECHAR('\0');
|
|
m_TraceFileCopyDir = str_temp;
|
|
m_TraceFileCopyDir.Append("\\");
|
|
|
|
// Point to the copy file name
|
|
pc_bslash++;
|
|
} else {
|
|
pc_bslash = static_cast<OLECHAR *>(str_temp);
|
|
}
|
|
|
|
// If we're not doing multiple trace files, make sure
|
|
// we have a copy file name. (If we are doing multiple
|
|
// trace files, the copy file name is create below.)
|
|
if (!(m_TraceOutput & WSB_TRACE_OUT_MULTIPLE_FILES) &&
|
|
0 == wcslen(pc_bslash)) {
|
|
m_TraceFileCopyName = m_TraceFileCopyDir;
|
|
m_TraceFileCopyName.Append(m_TraceMultipleFilePattern);
|
|
}
|
|
}
|
|
|
|
// Increment file count and indicate flags are set
|
|
m_TraceMultipleFileCount++;
|
|
m_TraceOutput |= WSB_TRACE_OUT_FLAGS_SET;
|
|
}
|
|
|
|
// If we have a file pattern, create the new actual file names
|
|
if (m_TraceOutput & WSB_TRACE_OUT_MULTIPLE_FILES) {
|
|
OLECHAR newName[256];
|
|
|
|
// Create the file name from the pattern and the file count
|
|
wsprintf(newName, m_TraceMultipleFilePattern,
|
|
m_TraceMultipleFileCount);
|
|
|
|
// Combine trace directory and file name
|
|
m_TraceFileName = m_TraceFileDir;
|
|
m_TraceFileName.Append(newName);
|
|
|
|
// Create a new trace file copy name also
|
|
if (m_TraceOutput & WSB_TRACE_OUT_FILE_COPY) {
|
|
m_TraceFileCopyName = m_TraceFileCopyDir;
|
|
m_TraceFileCopyName.Append(newName);
|
|
}
|
|
}
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::SetTraceOn(
|
|
LONGLONG traceElement
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetTraceOn
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
//
|
|
// Turn on the global trace bits for easy checking
|
|
//
|
|
g_WsbTraceModules = g_WsbTraceModules | traceElement;
|
|
|
|
//
|
|
// Turn on the local trace bits
|
|
//
|
|
m_TraceSettings = g_WsbTraceModules;
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::SetTraceOff(
|
|
LONGLONG traceElement
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetTraceOff
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
//
|
|
// Turn off the global trace bits for easy checking
|
|
//
|
|
g_WsbTraceModules = g_WsbTraceModules & (~traceElement);
|
|
|
|
//
|
|
// Turn on the local trace bits
|
|
//
|
|
m_TraceSettings = g_WsbTraceModules;
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::GetTraceSettings(
|
|
LONGLONG *pTraceElements
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetTraceSettings
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try
|
|
{
|
|
WsbAffirm(pTraceElements != 0, E_POINTER);
|
|
*pTraceElements = g_WsbTraceModules;
|
|
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::GetTraceSetting(
|
|
LONGLONG traceElement,
|
|
BOOL *pOn )
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetTraceSetting
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
//
|
|
// Find the bit and return TRUE if it is set,
|
|
// otherwise return FALSE
|
|
//
|
|
try
|
|
{
|
|
WsbAffirm(pOn != 0, E_POINTER);
|
|
*pOn = FALSE;
|
|
if ((g_WsbTraceModules & traceElement) == traceElement) {
|
|
*pOn = TRUE;
|
|
}
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::DirectOutput(
|
|
ULONG output
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::DirectOutput
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
m_TraceOutput = output;
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::SetTraceFileControls(
|
|
OLECHAR *pTraceFileName,
|
|
BOOL commitEachEntry,
|
|
LONGLONG maxTraceFileSize,
|
|
OLECHAR *pTraceFileCopyName
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetTraceFileControls
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
try {
|
|
if (pTraceFileName) {
|
|
m_TraceFileName = pTraceFileName;
|
|
m_TraceOutput &= ~WSB_TRACE_OUT_FLAGS_SET;
|
|
}
|
|
m_CommitEachEntry = commitEachEntry;
|
|
m_MaxTraceFileSize = maxTraceFileSize;
|
|
if (pTraceFileCopyName) {
|
|
m_TraceFileCopyName = pTraceFileCopyName;
|
|
m_TraceOutput &= ~WSB_TRACE_OUT_FLAGS_SET;
|
|
}
|
|
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::GetTraceFileControls(
|
|
OLECHAR **ppTraceFileName,
|
|
BOOL *pCommitEachEntry,
|
|
LONGLONG *pMaxTraceFileSize,
|
|
OLECHAR **ppTraceFileCopyName
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetTraceFileControls
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
if (ppTraceFileName) {
|
|
CWsbStringPtr fileName;
|
|
|
|
fileName = m_TraceFileName;
|
|
fileName.GiveTo(ppTraceFileName);
|
|
}
|
|
|
|
if (pCommitEachEntry) {
|
|
*pCommitEachEntry = m_CommitEachEntry;
|
|
}
|
|
|
|
if (pMaxTraceFileSize) {
|
|
*pMaxTraceFileSize = m_MaxTraceFileSize;
|
|
}
|
|
|
|
if (ppTraceFileCopyName) {
|
|
CWsbStringPtr fileCopyName;
|
|
|
|
fileCopyName = m_TraceFileCopyName;
|
|
fileCopyName.GiveTo(ppTraceFileCopyName);
|
|
}
|
|
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::Print(
|
|
OLECHAR *traceString
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::Print
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
CWsbStringPtr outString;
|
|
DWORD threadId;
|
|
OLECHAR tmpString[50];
|
|
|
|
try {
|
|
//
|
|
// Add the timeStamp if it is requested
|
|
//
|
|
|
|
if (m_TimeStamp) {
|
|
SYSTEMTIME stime;
|
|
|
|
GetLocalTime(&stime);
|
|
swprintf(tmpString, OLESTR("%2.02u/%2.02u %2.2u:%2.2u:%2.2u.%3.3u "),
|
|
stime.wMonth, stime.wDay,
|
|
stime.wHour, stime.wMinute,
|
|
stime.wSecond, stime.wMilliseconds);
|
|
|
|
outString.Append(tmpString);
|
|
outString.Append(" ");
|
|
}
|
|
|
|
//
|
|
// Add the trace count if requested
|
|
//
|
|
if (m_TraceCount) {
|
|
OLECHAR tmpString[50];
|
|
|
|
swprintf(tmpString, OLESTR("%8.8lX"), *(m_pTraceCountGlobal));
|
|
outString.Append(tmpString);
|
|
InterlockedIncrement(m_pTraceCountGlobal);
|
|
outString.Append(" ");
|
|
}
|
|
|
|
//
|
|
// Add the thread ID if requested
|
|
//
|
|
if (m_TraceThreadId) {
|
|
threadId = GetCurrentThreadId();
|
|
if (threadId < 0x0000FFFF) {
|
|
swprintf(tmpString, OLESTR("%4.4lX"), threadId);
|
|
} else {
|
|
swprintf(tmpString, OLESTR("%8.8lX"), threadId);
|
|
}
|
|
|
|
outString.Append(tmpString);
|
|
outString.Append(" ");
|
|
}
|
|
|
|
outString.Append(traceString);
|
|
//
|
|
// Make sure no one else writes when we do
|
|
//
|
|
Lock();
|
|
try {
|
|
if ((m_TraceOutput & WSB_TRACE_OUT_DEBUG_SCREEN) == WSB_TRACE_OUT_DEBUG_SCREEN) {
|
|
//
|
|
// Write to debug console
|
|
//
|
|
OutputDebugString(outString);
|
|
}
|
|
if ((m_TraceOutput & WSB_TRACE_OUT_STDOUT) == WSB_TRACE_OUT_STDOUT) {
|
|
//
|
|
// Write the string to the local console
|
|
//
|
|
wprintf(L"%ls", (WCHAR *) outString);
|
|
}
|
|
if ((m_TraceOutput & WSB_TRACE_OUT_FILE) == WSB_TRACE_OUT_FILE) {
|
|
//
|
|
// Make sure the file exists, etc.
|
|
//
|
|
if (m_TraceFilePointer != INVALID_HANDLE_VALUE) {
|
|
//
|
|
// Write the string to the trace file
|
|
//
|
|
WsbAffirmHr(Write(outString));
|
|
|
|
//
|
|
// See if we have used our space
|
|
//
|
|
WsbAffirmHr(WrapTraceFile());
|
|
}
|
|
}
|
|
} WsbCatch( hr );
|
|
|
|
Unlock();
|
|
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::WrapTraceFile(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::WrapTraceFile
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
static BOOL stopping = FALSE;
|
|
|
|
try {
|
|
LARGE_INTEGER offset;
|
|
|
|
//
|
|
// Find out where we are writing to the file
|
|
//
|
|
offset.HighPart = 0;
|
|
offset.LowPart = SetFilePointer(m_TraceFilePointer, 0, &offset.HighPart, FILE_CURRENT);
|
|
WsbAffirm(0xFFFFFFFF != offset.LowPart || NO_ERROR == GetLastError(), E_FAIL);
|
|
|
|
//
|
|
// See if we are past the max size desired
|
|
//
|
|
if (!stopping && offset.QuadPart >= m_MaxTraceFileSize) {
|
|
|
|
// If we are doing multiple files, close this one and
|
|
// open a new one
|
|
if (m_TraceOutput & WSB_TRACE_OUT_MULTIPLE_FILES) {
|
|
|
|
// Close the current trace file
|
|
stopping = TRUE;
|
|
StopTrace();
|
|
|
|
// Increment the file count
|
|
m_TraceMultipleFileCount++;
|
|
|
|
// Create a new trace file
|
|
StartTrace();
|
|
stopping = FALSE;
|
|
|
|
// otherwise go into wrap mode
|
|
} else {
|
|
// We have gone too far so start back at the top and indicating we are wrapping.
|
|
offset.HighPart = 0;
|
|
offset.LowPart = SetFilePointer(m_TraceFilePointer, 0, &offset.HighPart, FILE_BEGIN);
|
|
WsbAffirm(0xFFFFFFFF != offset.LowPart || NO_ERROR == GetLastError(), E_FAIL);
|
|
m_WrapMode = TRUE;
|
|
}
|
|
}
|
|
|
|
if (m_WrapMode) {
|
|
// Save where we are in the file
|
|
offset.LowPart = SetFilePointer(m_TraceFilePointer, 0, &offset.HighPart, FILE_CURRENT);
|
|
WsbAffirm(0xFFFFFFFF != offset.LowPart || NO_ERROR == GetLastError(), E_FAIL);
|
|
|
|
// Write the wrap line
|
|
WsbAffirmHr(Write(OLESTR("!!! TRACE WRAPPED !!!\r\n")));
|
|
|
|
/* Go back to offset before wrap line saved */
|
|
offset.LowPart = SetFilePointer(m_TraceFilePointer, offset.LowPart,
|
|
&offset.HighPart, FILE_BEGIN);
|
|
WsbAffirm(0xFFFFFFFF != offset.LowPart || NO_ERROR == GetLastError(), E_FAIL);
|
|
|
|
}
|
|
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::SetOutputFormat(
|
|
BOOL timeStamp,
|
|
BOOL traceCount,
|
|
BOOL traceThreadId
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetOutputFormat
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
try {
|
|
m_TimeStamp = timeStamp;
|
|
m_TraceCount = traceCount;
|
|
m_TraceThreadId = traceThreadId;
|
|
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::GetOutputFormat(
|
|
BOOL *pTimeStamp,
|
|
BOOL *pTraceCount,
|
|
BOOL *pTraceThreadId
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetOutputFormat
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
try {
|
|
WsbAffirm(0 != pTimeStamp, E_POINTER);
|
|
WsbAffirm(0 != pTraceCount, E_POINTER);
|
|
WsbAffirm(0 != pTraceThreadId, E_POINTER);
|
|
*pTimeStamp = m_TimeStamp;
|
|
*pTraceCount = m_TraceCount;
|
|
*pTraceThreadId = m_TraceThreadId;
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::GetRegistryEntry(
|
|
OLECHAR **pRegistryEntry
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetRegistryEntry
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
WsbAffirm(0 != pRegistryEntry, E_POINTER);
|
|
|
|
CWsbStringPtr entry;
|
|
entry = m_RegistrySetting;
|
|
WsbAffirmHr(entry.GiveTo(pRegistryEntry));
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::SetRegistryEntry(
|
|
OLECHAR *registryEntry
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetRegistryEntry
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
m_RegistrySetting = registryEntry;
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::LoadFromRegistry(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::LoadFromRegistry
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
if (wcslen(m_RegistrySetting) > 0) {
|
|
WsbAffirmHr(WsbEnsureRegistryKeyExists (NULL, m_RegistrySetting));
|
|
WsbAffirmHr(LoadFileSettings());
|
|
WsbAffirmHr(LoadTraceSettings());
|
|
WsbAffirmHr(LoadOutputDestinations());
|
|
WsbAffirmHr(LoadFormat());
|
|
WsbAffirmHr(LoadStart());
|
|
} else {
|
|
hr = E_FAIL;
|
|
}
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::LoadFileSettings(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::LoadFileSettings
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
DWORD sizeGot;
|
|
OLECHAR dataString[512];
|
|
OLECHAR *stopString;
|
|
CWsbStringPtr l_TraceFileName=L"Trace";
|
|
LONGLONG l_TraceFileSize=0;
|
|
BOOL l_TraceCommit=FALSE;
|
|
CWsbStringPtr l_TraceFileCopyName;
|
|
|
|
//
|
|
// Get the values
|
|
//
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_FILE_NAME,
|
|
dataString, 512, &sizeGot);
|
|
if (hr == S_OK) {
|
|
l_TraceFileName = dataString;
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_FILE_MAX_SIZE,
|
|
dataString, 512, &sizeGot);
|
|
if (hr == S_OK) {
|
|
l_TraceFileSize = wcstoul( dataString, &stopString, 10 );
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_FILE_COMMIT,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
if (0 == wcstoul(dataString, &stopString, 10)) {
|
|
l_TraceCommit = FALSE;
|
|
} else {
|
|
l_TraceCommit = TRUE;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_FILE_COPY_NAME,
|
|
dataString, 512, &sizeGot);
|
|
if (hr == S_OK) {
|
|
l_TraceFileCopyName = dataString;
|
|
}
|
|
|
|
hr = S_OK;
|
|
WsbAffirmHr(SetTraceFileControls(l_TraceFileName, l_TraceCommit,
|
|
l_TraceFileSize, l_TraceFileCopyName));
|
|
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::LoadTraceSettings(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::LoadTraceSettings
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
DWORD sizeGot;
|
|
OLECHAR dataString[100];
|
|
OLECHAR *stopString;
|
|
BOOL value = FALSE;
|
|
LONG number = 0;
|
|
LONGLONG l_TraceSettings = WSB_TRACE_BIT_NONE;
|
|
BOOL l_TraceEntryExit = TRUE;
|
|
WORD w_LogLevel = WSB_LOG_LEVEL_DEFAULT;
|
|
BOOL b_SnapShotOn = FALSE;
|
|
WORD w_SnapShotLevel = 0;
|
|
CWsbStringPtr p_SnapShotPath = L"SnapShotPath";
|
|
BOOL b_SnapShotResetTrace = FALSE;
|
|
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_PLATFORM,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_PLATFORM;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_RMS,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_RMS;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_SEG,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_SEG;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_META,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_META;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_HSMENG,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_HSMENG;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_HSMSERV,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_HSMSERV;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_JOB,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_JOB;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_HSMTSKMGR,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_HSMTSKMGR;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_FSA,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_FSA;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_DATAMIGRATER,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_DATAMIGRATER;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_DATARECALLER,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_DATARECALLER;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_DATAVERIFIER,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_DATAVERIFIER;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_UI,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_UI;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_ENTRY_EXIT,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value == FALSE) {
|
|
l_TraceEntryExit = FALSE;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_DATAMOVER,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_DATAMOVER;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_HSMCONN,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_HSMCONN;
|
|
}
|
|
}
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_IDB,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_IDB;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_COPYMEDIA,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_COPYMEDIA;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_DO_PERSISTENCE,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceSettings |= WSB_TRACE_BIT_PERSISTENCE;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_LOG_LEVEL,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
w_LogLevel = (WORD)wcstoul( dataString, &stopString, 10 ); // No conversion returns zero!
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_LOG_SNAP_SHOT_ON,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
b_SnapShotOn = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_LOG_SNAP_SHOT_LEVEL,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
w_SnapShotLevel = (WORD) wcstoul( dataString, &stopString, 10 );
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_LOG_SNAP_SHOT_PATH,
|
|
dataString, 512, &sizeGot);
|
|
if (hr == S_OK) {
|
|
p_SnapShotPath = dataString;
|
|
}
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_LOG_SNAP_SHOT_RESET_TRACE,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
b_SnapShotResetTrace = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
}
|
|
hr = S_OK;
|
|
WsbAffirmHr(SetTraceSettings(l_TraceSettings));
|
|
WsbAffirmHr(SetTraceEntryExit(l_TraceEntryExit));
|
|
WsbAffirmHr(SetLogLevel(w_LogLevel));
|
|
WsbAffirmHr(SetLogSnapShot(b_SnapShotOn, w_SnapShotLevel,
|
|
p_SnapShotPath, b_SnapShotResetTrace ));
|
|
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::LoadOutputDestinations(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::LoadOutputDestinations
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
DWORD sizeGot;
|
|
OLECHAR dataString[100];
|
|
OLECHAR *stopString;
|
|
BOOL value = FALSE;
|
|
ULONG l_TraceOutput = WSB_TRACE_OUT_NONE;
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_TO_STDOUT,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceOutput = l_TraceOutput | WSB_TRACE_OUT_STDOUT;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_TO_DEBUG,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceOutput = l_TraceOutput | WSB_TRACE_OUT_DEBUG_SCREEN;
|
|
}
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_TO_FILE,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
l_TraceOutput = l_TraceOutput | WSB_TRACE_OUT_FILE;
|
|
}
|
|
|
|
}
|
|
|
|
hr = S_OK;
|
|
WsbAffirmHr(DirectOutput(l_TraceOutput));
|
|
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::LoadFormat(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::LoadFormat
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
DWORD sizeGot;
|
|
OLECHAR dataString[100];
|
|
OLECHAR *stopString;
|
|
BOOL countValue = FALSE;
|
|
BOOL timeValue = FALSE;
|
|
BOOL threadValue = FALSE;
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_COUNT,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
countValue = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_TIMESTAMP,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
timeValue = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
}
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_THREADID,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
threadValue = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
}
|
|
|
|
hr = S_OK;
|
|
WsbAffirmHr(SetOutputFormat(timeValue, countValue, threadValue));
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::SetTraceEntryExit(
|
|
BOOL traceEntryExit
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetTraceEntryExit
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
g_WsbTraceEntryExit = traceEntryExit;
|
|
m_TraceEntryExit = traceEntryExit;
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
HRESULT
|
|
CWsbTrace::GetTraceEntryExit(
|
|
BOOL *pTraceEntryExit
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetTraceEntryExit
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
WsbAssert(0 != pTraceEntryExit, E_POINTER);
|
|
*pTraceEntryExit = m_TraceEntryExit;
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::SetLogLevel(
|
|
WORD logLevel
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetLogLevel
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
g_WsbLogLevel = logLevel;
|
|
m_LogLevel = logLevel;
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::GetLogLevel(
|
|
WORD *pLogLevel
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetLogLevel
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
WsbAssert(0 != pLogLevel, E_POINTER);
|
|
*pLogLevel = m_LogLevel;
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::SetLogSnapShot(
|
|
BOOL on,
|
|
WORD level,
|
|
OLECHAR *snapShotPath,
|
|
BOOL resetTrace
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetLogSnapShot
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
g_WsbLogSnapShotOn = on;
|
|
g_WsbLogSnapShotLevel = level;
|
|
if (snapShotPath != 0) {
|
|
wcscpy(g_pWsbLogSnapShotPath, snapShotPath);
|
|
}
|
|
g_WsbLogSnapShotResetTrace = resetTrace;
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::GetLogSnapShot(
|
|
BOOL *pOn,
|
|
WORD *pLevel,
|
|
OLECHAR **pSnapShotPath,
|
|
BOOL *pResetTrace
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::GetLogSnapShot
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
WsbAssert(0 != pOn, E_POINTER);
|
|
WsbAssert(0 != pLevel, E_POINTER);
|
|
WsbAssert(0 != pSnapShotPath, E_POINTER);
|
|
WsbAssert(0 != pResetTrace, E_POINTER);
|
|
|
|
*pOn = g_WsbLogSnapShotOn;
|
|
|
|
CWsbStringPtr path;
|
|
path = g_pWsbLogSnapShotPath;
|
|
path.GiveTo(pSnapShotPath);
|
|
|
|
*pLevel = g_WsbLogSnapShotLevel;
|
|
*pResetTrace = g_WsbLogSnapShotResetTrace;
|
|
|
|
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::LoadStart(
|
|
void
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::LoadStart
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try {
|
|
DWORD sizeGot;
|
|
OLECHAR dataString[100];
|
|
OLECHAR *stopString;
|
|
BOOL value = FALSE;
|
|
|
|
hr = WsbGetRegistryValueString(NULL, m_RegistrySetting, WSB_TRACE_ON,
|
|
dataString, 100, &sizeGot);
|
|
if (hr == S_OK) {
|
|
value = (BOOL) wcstoul( dataString, &stopString, 10 );
|
|
if (value) {
|
|
StartTrace();
|
|
} else {
|
|
StopTrace();
|
|
}
|
|
}
|
|
|
|
hr = S_OK;
|
|
} WsbCatch( hr );
|
|
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
// Write - write a WCHAR string to the output file as multibyte chars.
|
|
HRESULT
|
|
CWsbTrace::Write(
|
|
OLECHAR *pString
|
|
)
|
|
{
|
|
HRESULT hr = S_OK;
|
|
const int safe_size = 1024;
|
|
static char buf[safe_size + 16];
|
|
|
|
try {
|
|
int nbytes;
|
|
int nchars_todo;
|
|
int nchars_remaining;
|
|
OLECHAR *pSource;
|
|
OLECHAR *pTest;
|
|
BOOL needToAddReturn = FALSE;
|
|
CWsbStringPtr endOfLine("\r\n");
|
|
|
|
// Get the total number of chars. in the string
|
|
pSource = pString;
|
|
nchars_remaining = wcslen(pSource);
|
|
pTest = (pString + nchars_remaining - 1);
|
|
//
|
|
// Make sure that if this is a terminating line
|
|
// that it is a \r\n termination not just a
|
|
// \n.
|
|
//
|
|
if (*pTest == '\n') {
|
|
pTest--;
|
|
if (*pTest != '\r') {
|
|
needToAddReturn = TRUE;
|
|
nchars_remaining--;
|
|
}
|
|
}
|
|
|
|
// Loop until all chars. are written
|
|
while (nchars_remaining) {
|
|
DWORD bytesWritten;
|
|
|
|
if (nchars_remaining * sizeof(OLECHAR) > safe_size) {
|
|
nchars_todo = safe_size / sizeof(OLECHAR);
|
|
} else {
|
|
nchars_todo = nchars_remaining;
|
|
}
|
|
|
|
// Convert characters from wide to narrow
|
|
do {
|
|
nbytes = wcstombs(buf, pSource, nchars_todo);
|
|
if (nbytes <= 0) {
|
|
|
|
// Hit a bad character; try fewer characters
|
|
nchars_todo /= 2;
|
|
if (0 == nchars_todo) {
|
|
|
|
// Skip the next character
|
|
nchars_todo = 1;
|
|
nbytes = 1;
|
|
buf[0] = '?';
|
|
}
|
|
}
|
|
} while (nbytes <= 0);
|
|
|
|
WsbAffirm(WriteFile(m_TraceFilePointer, buf, nbytes,
|
|
&bytesWritten, NULL), E_FAIL);
|
|
WsbAffirm(static_cast<int>(bytesWritten) == nbytes, E_FAIL);
|
|
nchars_remaining -= nchars_todo;
|
|
pSource += nchars_todo;
|
|
}
|
|
|
|
if (needToAddReturn) {
|
|
DWORD bytesWritten;
|
|
|
|
nbytes = wcstombs(buf, (OLECHAR *)endOfLine, 2);
|
|
WsbAffirm(nbytes > 0, E_FAIL);
|
|
WsbAffirm(WriteFile(m_TraceFilePointer, buf, nbytes,
|
|
&bytesWritten, NULL), E_FAIL);
|
|
WsbAffirm(static_cast<int>(bytesWritten) == nbytes, E_FAIL);
|
|
|
|
}
|
|
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CWsbTrace::SetTraceSettings(
|
|
LONGLONG traceElements
|
|
)
|
|
/*++
|
|
|
|
Implements:
|
|
|
|
IWsbTrace::SetTraceSettings
|
|
|
|
--*/
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
try
|
|
{
|
|
|
|
g_WsbTraceModules = traceElements;
|
|
m_TraceSettings = g_WsbTraceModules;
|
|
|
|
} WsbCatch( hr );
|
|
|
|
return( hr );
|
|
}
|