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.
|
|
/*++
� 1998 Seagate Software, Inc. All rights reserved.
Module Name:
WsbTrc.h
Abstract:
This header file defines the part of the platform code that is responsible for function tracing.
Author:
Chuck Bardeen [cbardeen] 29-Oct-1996
Revision History:
Brian Dodd [brian] 09-May-1996 - Added event logging
--*/
#ifndef _WSBTRC_
#define _WSBTRC_
#include "wsb.h"
#include "resource.h"
//Registry strings for trace settings
#define WSB_TRACE_COUNT OLESTR("WsbTraceCount")
#define WSB_TRACE_TIMESTAMP OLESTR("WsbTraceTimestamp")
#define WSB_TRACE_THREADID OLESTR("WsbTraceThreadId")
#define WSB_TRACE_ON OLESTR("WsbTraceOn")
#define WSB_TRACE_TO_DEBUG OLESTR("WsbTraceToDebug")
#define WSB_TRACE_TO_STDOUT OLESTR("WsbTraceToStdOut")
#define WSB_TRACE_TO_FILE OLESTR("WsbTraceToFile")
#define WSB_TRACE_FILE_NAME OLESTR("WsbTraceFileName")
#define WSB_TRACE_FILE_MAX_SIZE OLESTR("WsbTraceFileMaxSize")
#define WSB_TRACE_FILE_COMMIT OLESTR("WsbTraceFileCommit")
#define WSB_TRACE_ENTRY_EXIT OLESTR("WsbTraceEntryExit")
#define WSB_TRACE_FILE_COPY_NAME OLESTR("WsbTraceFileCopyName")
#define WSB_LOG_LEVEL OLESTR("WsbLogLevel")
#define WSB_LOG_SNAP_SHOT_ON OLESTR("WsbLogSnapShotOn")
#define WSB_LOG_SNAP_SHOT_LEVEL OLESTR("WsbLogSnapShotLevel")
#define WSB_LOG_SNAP_SHOT_PATH OLESTR("WsbLogSnapShotPath")
#define WSB_LOG_SNAP_SHOT_RESET_TRACE OLESTR("WsbLogSnapShotResetTrace")
#define WSB_TRACE_DO_PLATFORM OLESTR("WsbTraceDoPlatform")
#define WSB_TRACE_DO_RMS OLESTR("WsbTraceDoRms")
#define WSB_TRACE_DO_SEG OLESTR("WsbTraceDoSeg")
#define WSB_TRACE_DO_META OLESTR("WsbTraceDoMeta")
#define WSB_TRACE_DO_HSMENG OLESTR("WsbTraceDoHsmEng")
#define WSB_TRACE_DO_JOB OLESTR("WsbTraceDoJob")
#define WSB_TRACE_DO_HSMTSKMGR OLESTR("WsbTraceDoHsmTskMgr")
#define WSB_TRACE_DO_FSA OLESTR("WsbTraceDoFsa")
#define WSB_TRACE_DO_DATAMIGRATER OLESTR("WsbTraceDoDatamigrater")
#define WSB_TRACE_DO_DATARECALLER OLESTR("WsbTraceDoDataRecaller")
#define WSB_TRACE_DO_DATAVERIFIER OLESTR("WsbTraceDoDataVerifier")
#define WSB_TRACE_DO_UI OLESTR("WsbTraceDoUI")
#define WSB_TRACE_DO_DATAMOVER OLESTR("WsbTraceDoDataMover")
#define WSB_TRACE_DO_HSMCONN OLESTR("WsbTraceDoHsmConn")
#define WSB_TRACE_DO_IDB OLESTR("WsbTraceDoIDB")
#define WSB_TRACE_DO_COPYMEDIA OLESTR("WsbTraceDoCopyMedia")
#define WSB_TRACE_DO_PERSISTENCE OLESTR("WsbTraceDoPersistence")
#define WSB_TRACE_DO_HSMSERV OLESTR("WsbTraceDoHsmServ")
class CWsbTrace : public IWsbTrace, public CComObjectRoot, public CComCoClass<CWsbTrace,&CLSID_CWsbTrace> {
public: CWsbTrace() {} BEGIN_COM_MAP( CWsbTrace ) COM_INTERFACE_ENTRY( IWsbTrace ) END_COM_MAP( )
DECLARE_REGISTRY_RESOURCEID( IDR_CWsbTrace )
HRESULT FinalConstruct( void ); void FinalRelease( void );
// IWsbTrace
public: STDMETHOD( StartTrace )( void ); STDMETHOD( StopTrace )( void ); STDMETHOD( SetTraceOn )( LONGLONG traceElement ); STDMETHOD( SetTraceOff )( LONGLONG traceElement ); STDMETHOD( GetTraceSettings )( LONGLONG *pTraceElements ); STDMETHOD( GetTraceSetting )( LONGLONG traceElement, BOOL *pOn ); STDMETHOD( SetTraceFileControls )( OLECHAR *pTraceFileName, BOOL commitEachEntry, LONGLONG maxTraceFileSize, OLECHAR *pTraceFileCopyName); STDMETHOD( GetTraceFileControls )( OLECHAR **ppTraceFileName, BOOL *pCommitEachEntry, LONGLONG *pMaxTraceFileSize, OLECHAR **ppTraceFileCopyName); STDMETHOD( DirectOutput )(ULONG output ); STDMETHOD( SetOutputFormat )( BOOL timeStamp, BOOL traceCount, BOOL threadId ); STDMETHOD( GetOutputFormat )( BOOL *pTimeStamp, BOOL *pTraceCount, BOOL *pThreadId ); STDMETHOD( SetTraceEntryExit )( BOOL traceEntryExit ); STDMETHOD( GetTraceEntryExit )( BOOL *pTraceEntryExit ); STDMETHOD( SetLogLevel )( WORD logLevel ); STDMETHOD( SetLogSnapShot)( BOOL on, WORD level, OLECHAR *snapShotPath, BOOL resetTrace); STDMETHOD( GetLogSnapShot)( BOOL *pOn, WORD *pLevel, OLECHAR **pSnapShotPath, BOOL *pResetTrace); STDMETHOD( GetLogLevel )( WORD *pLogLevel ); STDMETHOD( GetRegistryEntry )( OLECHAR **pTraceRegistrySetting ); STDMETHOD( SetRegistryEntry )( OLECHAR *traceRegistrySetting ); STDMETHOD( LoadFromRegistry )( void ); STDMETHOD( SetTraceSettings )( LONGLONG traceElements );
STDMETHOD( Print )(OLECHAR* traceString );
protected: // Helper functions
STDMETHOD( AdjustFileNames )( void ); STDMETHOD( WrapTraceFile )( void ); STDMETHOD( LoadFileSettings )( void ); STDMETHOD( LoadTraceSettings )( void ); STDMETHOD( LoadOutputDestinations )( void ); STDMETHOD( LoadFormat )( void ); STDMETHOD( LoadStart )( void ); STDMETHOD( Write )(OLECHAR* pString );
BOOL m_TraceOn; LONGLONG m_TraceSettings; CWsbStringPtr m_TraceFileName; ULONG m_TraceOutput; BOOL m_CommitEachEntry; BOOL m_TimeStamp; BOOL m_TraceCount; BOOL m_TraceThreadId; BOOL m_TraceEntryExit; WORD m_LogLevel; LONGLONG m_MaxTraceFileSize; HANDLE m_TraceFilePointer; BOOL m_WrapMode; CWsbStringPtr m_RegistrySetting; CWsbStringPtr m_TraceFileCopyName; CWsbStringPtr m_TraceMultipleFilePattern; // printf style pattern
ULONG m_TraceMultipleFileCount; // count inserted into pattern
CWsbStringPtr m_TraceFileDir; // directory for trace file
CWsbStringPtr m_TraceFileCopyDir; // directory for trace file copy
HANDLE m_TraceCountHandle; PLONG m_pTraceCountGlobal; }; #endif // _WSBTRC_
|