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.
357 lines
8.5 KiB
357 lines
8.5 KiB
// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
|
|
// ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
|
|
// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
|
|
// PARTICULAR PURPOSE.
|
|
//
|
|
// Copyright 1996-2003 Microsoft Corporation. All Rights Reserved.
|
|
//
|
|
// FILE: Debug.cpp
|
|
//
|
|
//
|
|
// PURPOSE: Debug functions.
|
|
//
|
|
//
|
|
// Functions:
|
|
//
|
|
//
|
|
//
|
|
// PLATFORMS: Windows 2000, Windows XP, Windows Server 2003
|
|
//
|
|
//
|
|
|
|
#include "precomp.h"
|
|
#include "oem.h"
|
|
#include "debug.h"
|
|
#include <strsafe.h>
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////
|
|
// INTERNAL DEFINES
|
|
////////////////////////////////////////////////////////
|
|
|
|
#define DEBUG_BUFFER_SIZE 1024
|
|
#define PATH_SEPARATOR '\\'
|
|
|
|
|
|
|
|
// Determine what level of debugging messages to eject.
|
|
#ifdef VERBOSE_MSG
|
|
#define DEBUG_LEVEL DBG_VERBOSE
|
|
#elif TERSE_MSG
|
|
#define DEBUG_LEVEL DBG_TERSE
|
|
#elif WARNING_MSG
|
|
#define DEBUG_LEVEL DBG_WARNING
|
|
#elif ERROR_MSG
|
|
#define DEBUG_LEVEL DBG_ERROR
|
|
#elif RIP_MSG
|
|
#define DEBUG_LEVEL DBG_RIP
|
|
#elif NO_DBG_MSG
|
|
#define DEBUG_LEVEL DBG_NONE
|
|
#else
|
|
#define DEBUG_LEVEL DBG_WARNING
|
|
#endif
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////
|
|
// EXTERNAL GLOBALS
|
|
////////////////////////////////////////////////////////
|
|
|
|
INT giDebugLevel = DEBUG_LEVEL;
|
|
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////
|
|
// INTERNAL PROTOTYPES
|
|
////////////////////////////////////////////////////////
|
|
|
|
static BOOL DebugMessageV(LPCSTR lpszMessage, va_list arglist);
|
|
static BOOL DebugMessageV(DWORD dwSize, LPCWSTR lpszMessage, va_list arglist);
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
// Function: DebugMessageV
|
|
//
|
|
// Description: Outputs variable argument debug string.
|
|
//
|
|
//
|
|
// Parameters:
|
|
//
|
|
// dwSize Size of temp buffer to hold formated string.
|
|
//
|
|
// lpszMessage Format string.
|
|
//
|
|
// arglist Variable argument list..
|
|
//
|
|
//
|
|
// Returns:
|
|
//
|
|
//
|
|
// Comments:
|
|
//
|
|
//
|
|
// History:
|
|
// 12/18/96 APresley Created.
|
|
//
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
static BOOL DebugMessageV(LPCSTR lpszMessage, va_list arglist)
|
|
{
|
|
DWORD dwSize = DEBUG_BUFFER_SIZE;
|
|
LPSTR lpszMsgBuf = NULL;
|
|
HRESULT hr = S_FALSE;
|
|
|
|
|
|
// Parameter checking.
|
|
if( (NULL == lpszMessage)
|
|
||
|
|
(0 == dwSize)
|
|
)
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
do
|
|
{
|
|
// Allocate memory for message buffer.
|
|
if(NULL != lpszMsgBuf)
|
|
{
|
|
delete[] lpszMsgBuf;
|
|
dwSize *= 2;
|
|
}
|
|
|
|
//
|
|
// Just to make sure we dont go into infinite loop and allocate
|
|
// lots of memory, lets bail out if memory requirement becomes huge.
|
|
// Multiplying by 8, i.e. will loop at most 4 times.
|
|
//
|
|
if ( dwSize > 8*DEBUG_BUFFER_SIZE )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
lpszMsgBuf = new CHAR[dwSize + 1];
|
|
if(NULL == lpszMsgBuf)
|
|
return FALSE;
|
|
|
|
hr = StringCchVPrintfA ( lpszMsgBuf, dwSize, lpszMessage, arglist);
|
|
// Pass the variable parameters to wvsprintf to be formated.
|
|
} while (FAILED (hr) );
|
|
|
|
// Dump string to Debug output.
|
|
OutputDebugStringA(lpszMsgBuf);
|
|
|
|
// Cleanup.
|
|
delete[] lpszMsgBuf;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
// Function: DebugMessageV
|
|
//
|
|
// Description: Outputs variable argument debug string.
|
|
//
|
|
//
|
|
// Parameters:
|
|
//
|
|
// dwSize Size of temp buffer to hold formated string.
|
|
//
|
|
// lpszMessage Format string.
|
|
//
|
|
// arglist Variable argument list..
|
|
//
|
|
//
|
|
// Returns:
|
|
//
|
|
//
|
|
// Comments:
|
|
//
|
|
//
|
|
// History:
|
|
// 12/18/96 APresley Created.
|
|
//
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
static BOOL DebugMessageV(DWORD dwSize, LPCWSTR lpszMessage, va_list arglist)
|
|
{
|
|
LPWSTR lpszMsgBuf;
|
|
HRESULT hr = S_FALSE;
|
|
|
|
|
|
// Parameter checking.
|
|
if( (NULL == lpszMessage)
|
|
||
|
|
(0 == dwSize)
|
|
)
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
// Allocate memory for message buffer.
|
|
lpszMsgBuf = new WCHAR[dwSize + 1];
|
|
if(NULL == lpszMsgBuf)
|
|
return FALSE;
|
|
|
|
// Pass the variable parameters to wvsprintf to be formated.
|
|
hr = StringCchVPrintfW (lpszMsgBuf, dwSize, lpszMessage, arglist);
|
|
if ( SUCCEEDED (hr) )
|
|
{
|
|
// Dump string to debug output.
|
|
OutputDebugStringW(lpszMsgBuf);
|
|
}
|
|
|
|
// Clean up.
|
|
delete[] lpszMsgBuf;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
// Function: DebugMessage
|
|
//
|
|
// Description: Outputs variable argument debug string.
|
|
//
|
|
//
|
|
// Parameters:
|
|
//
|
|
// lpszMessage Format string.
|
|
//
|
|
//
|
|
// Returns:
|
|
//
|
|
//
|
|
// Comments:
|
|
//
|
|
//
|
|
// History:
|
|
// 12/18/96 APresley Created.
|
|
//
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
BOOL DebugMessage(LPCSTR lpszMessage, ...)
|
|
{
|
|
BOOL bResult;
|
|
va_list VAList;
|
|
|
|
|
|
// Pass the variable parameters to DebugMessageV for processing.
|
|
va_start(VAList, lpszMessage);
|
|
bResult = DebugMessageV(lpszMessage, VAList);
|
|
va_end(VAList);
|
|
|
|
return bResult;
|
|
}
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
// Function: DebugMessage
|
|
//
|
|
// Description: Outputs variable argument debug string.
|
|
//
|
|
//
|
|
// Parameters:
|
|
//
|
|
// lpszMessage Format string.
|
|
//
|
|
//
|
|
// Returns:
|
|
//
|
|
//
|
|
// Comments:
|
|
//
|
|
//
|
|
// History:
|
|
// 12/18/96 APresley Created.
|
|
//
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
BOOL DebugMessage(LPCWSTR lpszMessage, ...)
|
|
{
|
|
BOOL bResult;
|
|
va_list VAList;
|
|
|
|
|
|
// Pass the variable parameters to DebugMessageV to be processed.
|
|
va_start(VAList, lpszMessage);
|
|
bResult = DebugMessageV(MAX_PATH, lpszMessage, VAList);
|
|
va_end(VAList);
|
|
|
|
return bResult;
|
|
}
|
|
|
|
void Dump(PPUBLISHERINFO pPublisherInfo)
|
|
{
|
|
VERBOSE(__TEXT("pPublisherInfo:\r\n"));
|
|
VERBOSE(__TEXT("\tdwMode = %#x\r\n"), pPublisherInfo->dwMode);
|
|
VERBOSE(__TEXT("\twMinoutlinePPEM = %d\r\n"), pPublisherInfo->wMinoutlinePPEM);
|
|
VERBOSE(__TEXT("\twMaxbitmapPPEM = %d\r\n"), pPublisherInfo->wMaxbitmapPPEM);
|
|
}
|
|
|
|
void Dump(POEMDMPARAM pOemDMParam)
|
|
{
|
|
VERBOSE(__TEXT("pOemDMParam:\r\n"));
|
|
VERBOSE(__TEXT("\tcbSize = %d\r\n"), pOemDMParam->cbSize);
|
|
VERBOSE(__TEXT("\tpdriverobj = %#x\r\n"), pOemDMParam->pdriverobj);
|
|
VERBOSE(__TEXT("\thPrinter = %#x\r\n"), pOemDMParam->hPrinter);
|
|
VERBOSE(__TEXT("\thModule = %#x\r\n"), pOemDMParam->hModule);
|
|
VERBOSE(__TEXT("\tpPublicDMIn = %#x\r\n"), pOemDMParam->pPublicDMIn);
|
|
VERBOSE(__TEXT("\tpPublicDMOut = %#x\r\n"), pOemDMParam->pPublicDMOut);
|
|
VERBOSE(__TEXT("\tpOEMDMIn = %#x\r\n"), pOemDMParam->pOEMDMIn);
|
|
VERBOSE(__TEXT("\tpOEMDMOut = %#x\r\n"), pOemDMParam->pOEMDMOut);
|
|
VERBOSE(__TEXT("\tcbBufSize = %d\r\n"), pOemDMParam->cbBufSize);
|
|
}
|
|
|
|
void Dump(PPROPSHEETUI_INFO pPSUIInfo)
|
|
{
|
|
VERBOSE(__TEXT("pPSUIInfo:\r\n"));
|
|
VERBOSE(__TEXT("\tcbSize = %d\r\n"), pPSUIInfo->cbSize);
|
|
VERBOSE(__TEXT("\tVersion = %#x\r\n"), pPSUIInfo->Version);
|
|
VERBOSE(__TEXT("\tFlags = %#x\r\n"), pPSUIInfo->Flags);
|
|
VERBOSE(__TEXT("\tReason = %d\r\n"), pPSUIInfo->Reason);
|
|
VERBOSE(__TEXT("\thComPropSheet = %#x\r\n"), pPSUIInfo->hComPropSheet);
|
|
VERBOSE(__TEXT("\tpfnComPropSheet = %#x\r\n"), pPSUIInfo->pfnComPropSheet);
|
|
VERBOSE(__TEXT("\tlParamInit = %#x\r\n"), pPSUIInfo->lParamInit);
|
|
VERBOSE(__TEXT("\tUserData = %#x\r\n"), pPSUIInfo->UserData);
|
|
VERBOSE(__TEXT("\tResult = %#x\r\n"), pPSUIInfo->Result);
|
|
}
|
|
|
|
|
|
|
|
PCSTR
|
|
StripDirPrefixA(
|
|
IN PCSTR pstrFilename
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Strip the directory prefix off a filename (ANSI version)
|
|
|
|
Arguments:
|
|
|
|
pstrFilename - Pointer to filename string
|
|
|
|
Return Value:
|
|
|
|
Pointer to the last component of a filename (without directory prefix)
|
|
|
|
--*/
|
|
|
|
{
|
|
PCSTR pstr;
|
|
|
|
if (pstr = strrchr(pstrFilename, PATH_SEPARATOR))
|
|
return pstr + 1;
|
|
|
|
return pstrFilename;
|
|
}
|
|
|
|
|