|
|
/*++
Copyright (c) 2001 Microsoft Corporation
Module Name:
VerifLog.h
Abstract:
Headers for the AppVerifier log file.
Revision History:
04/26/2001 dmunsil Created. 08/14/2001 robkenny Inserted inside the ShimLib namespace.
--*/
#pragma once
#include <stdio.h> #include "ShimCString.h" #include "shimdb.h" #include "avrfutil.h"
namespace ShimLib {
extern BOOL g_bVerifierLogEnabled; // enable/disable file logging
class CVerifierLog { public: CString m_strShimName; DWORD m_dwEntries; BOOL m_bHeaderDumped;
CVerifierLog(LPCSTR szShimName, DWORD dwEntries) { m_strShimName = szShimName; m_dwEntries = dwEntries; m_bHeaderDumped = FALSE; } void __cdecl VLog( VLOG_LEVEL eLevel, DWORD dwLogNum, LPCSTR pszFmt, ... );
void DumpLogEntry( DWORD dwLogNum, UINT unResTitle, UINT unResDescription, UINT unResURL );
void DumpShimHeader(void);
};
// // helper functions // BOOL InitVerifierLogSupport( void);
void ReleaseVerifierLogSupport( void);
void WriteToSessionLog( LPCSTR szLine );
void WriteToProcessLog( LPCSTR szLine );
int VLogLoadString( HMODULE hModule, UINT wID, LPWSTR lpBuffer, // Unicode buffer int cchBufferMax);
// // Goes at top of shim cpp file, or in shared header file for shim // #define BEGIN_DEFINE_VERIFIER_LOG(shim) enum {
#define VERIFIER_LOG_ENTRY(entry) entry,
#define END_DEFINE_VERIFIER_LOG(shim) VLOG_ENTRIES_##shim };
// // goes at top of shim file, after includes and above defines and before any code // #define INIT_VERIFIER_LOG(shim) static CVerifierLog g_VLog(#shim, VLOG_ENTRIES_##shim)
// // goes in shim init section // // once for each log entry #define DUMP_VERIFIER_LOG_ENTRY(entry, title, desc, url) \ if (fdwReason == DLL_PROCESS_ATTACH) { \ g_VLog.DumpLogEntry(entry, title, desc, url); \ } // // for each log entry required // #define VLOG g_VLog.VLog
#define VLOG_MAX_DESC 4096 #define VLOG_MAX_FRIENDLY_NAME 256
// // goes in each shim module // #define SHIM_INFO_BEGIN() \ BOOL \ QueryShimInfo(AVRF_INFO_ID eInfo, PVOID pInfo) \ {
#define SHIM_INFO_DESCRIPTION(res_desc) \ if (eInfo == AVRF_INFO_DESCRIPTION) { \ LPWSTR *pszTemp = (LPWSTR*)pInfo; \ *pszTemp = \ (LPWSTR)ShimMalloc(VLOG_MAX_DESC * sizeof(WCHAR)); \ if (*pszTemp) { \ VLogLoadString(g_hinstDll, \ res_desc, \ (LPWSTR)*pszTemp, \ VLOG_MAX_DESC); \ return TRUE; \ } \ } #define SHIM_INFO_FRIENDLY_NAME(res_name) \ if (eInfo == AVRF_INFO_FRIENDLY_NAME) { \ LPWSTR *pszTemp = (LPWSTR*)pInfo; \ *pszTemp = \ (LPWSTR)ShimMalloc(VLOG_MAX_FRIENDLY_NAME * sizeof(WCHAR)); \ if (*pszTemp) { \ VLogLoadString(g_hinstDll, \ res_name, \ (LPWSTR)*pszTemp, \ VLOG_MAX_FRIENDLY_NAME); \ return TRUE; \ } \ }
#define SHIM_INFO_FLAGS(flags) \ if (eInfo == AVRF_INFO_FLAGS) { \ *((DWORD*)pInfo) = flags; \ return TRUE; \ } #define SHIM_INFO_GROUPS(groups) \ if (eInfo == AVRF_INFO_GROUPS) { \ *((DWORD*)pInfo) = groups; \ return TRUE; \ } #define SHIM_INFO_VERSION(major, minor) \ if (eInfo == AVRF_INFO_VERSION) { \ *((DWORD*)pInfo) = (((DWORD)major) << 16) | minor; \ return TRUE; \ } #define SHIM_INFO_INCLUDE_EXCLUDE(string) \ if (eInfo == AVRF_INFO_INCLUDE_EXCLUDE) { \ *((LPWSTR*)pInfo) = L##string; \ return TRUE; \ } #define SHIM_INFO_OPTIONS_PAGE(res_template, dlgproc) \ if (eInfo == AVRF_INFO_OPTIONS_PAGE) { \ LPPROPSHEETPAGE lpSheet = (LPPROPSHEETPAGE)pInfo; \ \ lpSheet->hInstance = g_hinstDll; \ lpSheet->pszTemplate = (LPCWSTR)res_template; \ lpSheet->pfnDlgProc = (DLGPROC)dlgproc; \ \ return TRUE; \ }
#define SHIM_INFO_END() \ return FALSE; \ }
// // goes in Main.cpp // #define DECLARE_VERIFIER_SHIM(name) \ namespace NS_##name \ { \ extern BOOL QueryShimInfo(AVRF_INFO_ID eInfo, PVOID pInfo); \ };
// in multi-shim init #define INIT_VLOG_SUPPORT() \ if (fdwReason == DLL_PROCESS_ATTACH) { \ InitVerifierLogSupport(); \ }
#define DECLARE_VERIFIER_DLL() \ extern "C" DWORD \ GetVerifierMagic(void) \ { \ return VERIFIER_SHIMS_MAGIC; \ } \ /* \ * Cause a compile error if the prototype in shimdb.w is out of sync with call \ */ \ static _pfnGetVerifierMagic __TEST_GetVerifierMagic_PROTO = GetVerifierMagic;
#define ENUM_VERIFIER_SHIMS_BEGIN() \ extern "C" BOOL \ QueryShimInfo(LPCWSTR szName, AVRF_INFO_ID eInfo, PVOID pInfo) \ { \ DWORD dwCount = 0;
#define ENUM_VERIFIER_SHIMS_ENTRY(name) \ if (eInfo == AVRF_INFO_NUM_SHIMS) { \ dwCount++; \ } else if (eInfo == AVRF_INFO_SHIM_NAMES) { \ ((LPWSTR*)pInfo)[dwCount] = L#name; \ dwCount++; \ } else if (szName && _wcsicmp(szName, L#name) == 0) { \ return NS_##name::QueryShimInfo(eInfo, pInfo); \ }
#define ENUM_VERIFIER_SHIMS_END() \ if (eInfo == AVRF_INFO_NUM_SHIMS) { \ *((DWORD*)pInfo) = dwCount; \ return TRUE; \ } \ if (eInfo == AVRF_INFO_SHIM_NAMES) { \ return TRUE; \ } \ \ return FALSE; \ } \ /* \ * Cause a compile error if the prototype in shimdb.w is out of sync with call \ */ \ static _pfnQueryShimInfo __TEST_QueryShimInfo_PROTO = QueryShimInfo;
}; // end of namespace ShimLib
|