forked from microsoft/Windows-driver-samples
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix microsoft#12 by modifying gitignore to include some debug folders
- Loading branch information
J M Rossy
committed
Aug 25, 2015
1 parent
d619854
commit f18a140
Showing
12 changed files
with
665 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -15,8 +15,6 @@ | |
[Dd]ebugPublic/ | ||
[Rr]elease/ | ||
[Rr]eleases/ | ||
x64/ | ||
x86/ | ||
build/ | ||
bld/ | ||
[Bb]in/ | ||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
# Allow tracking debug folder for this sample | ||
!debug/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,189 @@ | ||
/*++ | ||
Copyright (c) 2005 Microsoft Corporation | ||
All rights reserved. | ||
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. | ||
File Name: | ||
debug.cpp | ||
Abstract: | ||
Debug implementations. | ||
--*/ | ||
|
||
#include "precomp.h" | ||
#include "debug.h" | ||
#include "xdstring.h" | ||
|
||
/*++ | ||
Routine Name: | ||
RealDebugMessage | ||
Routine Description: | ||
This routine takes a debug message and va_list and outputs the message via OutputDebugString | ||
Arguments: | ||
dwSize - Maximum size of the debug message in number of characters | ||
pszMessage - The debug message string | ||
arglist - The arg list for the debug message string | ||
Return Value: | ||
BOOL | ||
TRUE - On success | ||
FALSE - On error | ||
--*/ | ||
BOOL | ||
RealDebugMessage( | ||
_In_ DWORD dwSize, | ||
_In_ PCSTR pszMessage, | ||
va_list arglist | ||
) | ||
{ | ||
HRESULT hr = S_OK; | ||
PSTR pszMsgBuf; | ||
|
||
if (NULL == pszMessage || | ||
0 == dwSize) | ||
{ | ||
hr = E_INVALIDARG; | ||
} | ||
|
||
if (SUCCEEDED(hr)) | ||
{ | ||
// | ||
// Allocate memory for message buffer. | ||
// | ||
pszMsgBuf = new(std::nothrow) CHAR[dwSize + 1]; | ||
|
||
if (NULL != pszMsgBuf) | ||
{ | ||
// | ||
// Pass the variable parameters to wvsprintf to be formated. | ||
// | ||
hr = StringCbVPrintfA(pszMsgBuf, (dwSize + 1) * sizeof(CHAR), pszMessage, arglist); | ||
|
||
// | ||
// Dump string to debug output. | ||
// | ||
OutputDebugStringA(pszMsgBuf); | ||
|
||
// | ||
// Clean up. | ||
// | ||
delete[] pszMsgBuf; | ||
pszMsgBuf = NULL; | ||
} | ||
else | ||
{ | ||
hr = E_OUTOFMEMORY; | ||
} | ||
} | ||
|
||
return SUCCEEDED(hr); | ||
} | ||
|
||
/*++ | ||
Routine Name: | ||
DbgPrint | ||
Routine Description: | ||
This routine takes a format string and arguments and outputs as a debug string | ||
Arguments: | ||
pszFormatString - Format string for the debug message | ||
... - argument list | ||
Return Value: | ||
BOOL | ||
TRUE - On success | ||
FALSE - On error | ||
--*/ | ||
BOOL | ||
DbgPrint( | ||
_In_ PCSTR pszFormatString, | ||
... | ||
) | ||
{ | ||
BOOL bResult; | ||
va_list VAList; | ||
|
||
// | ||
// Pass the variable parameters to RealDebugMessage to be processed. | ||
// | ||
va_start(VAList, pszFormatString); | ||
bResult = RealDebugMessage(0x8000, pszFormatString, VAList); | ||
va_end(VAList); | ||
|
||
return bResult; | ||
} | ||
|
||
/*++ | ||
Routine Name: | ||
DbgDOMDoc | ||
Routine Description: | ||
This routine outputs an XML DOM document to the debug output stream | ||
Arguments: | ||
pszMessage - Debug message | ||
pDomDoc - DOM document to be output | ||
Return Value: | ||
None. | ||
--*/ | ||
VOID | ||
DbgDOMDoc( | ||
_In_ PCSTR pszMessage, | ||
_In_ IXMLDOMDocument2* pDomDoc | ||
) | ||
{ | ||
try | ||
{ | ||
CComBSTR xml; | ||
|
||
if (pDomDoc != NULL && | ||
SUCCEEDED(pDomDoc->get_xml(&xml))) | ||
{ | ||
CStringXDA ansi(xml); | ||
|
||
if (pszMessage != NULL) | ||
{ | ||
DbgPrint("%s%s\n", pszMessage, ansi.GetBuffer()); | ||
} | ||
else | ||
{ | ||
DbgPrint("%s\n", ansi.GetBuffer()); | ||
} | ||
} | ||
} | ||
catch (CXDException&) | ||
{ | ||
} | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,186 @@ | ||
/*++ | ||
Copyright (c) 2005 Microsoft Corporation | ||
All rights reserved. | ||
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. | ||
File Name: | ||
xdsdbg.h | ||
Abstract: | ||
Debug definitions. | ||
--*/ | ||
|
||
#pragma once | ||
|
||
// | ||
// These macros are used for debugging purposes. They expand | ||
// to white spaces on a free build. Here is a brief description | ||
// of what they do and how they are used: | ||
// | ||
// giDebugLevel | ||
// Global variable which set the current debug level to control | ||
// the amount of debug messages emitted. | ||
// | ||
// VERBOSE(msg) | ||
// Display a message if the current debug level is <= DBG_VERBOSE. | ||
// | ||
// TERSE(msg) | ||
// Display a message if the current debug level is <= DBG_TERSE. | ||
// | ||
// WARNING(msg) | ||
// Display a message if the current debug level is <= DBG_WARNING. | ||
// The message format is: WRN filename (linenumber): message | ||
// | ||
// ERR(msg) | ||
// Similiar to WARNING macro above - displays a message | ||
// if the current debug level is <= DBG_ERROR. | ||
// | ||
// ASSERT(cond) | ||
// Verify a condition is true. If not, force a breakpoint. | ||
// | ||
// ASSERTMSG(cond, msg) | ||
// Verify a condition is true. If not, display a message and | ||
// force a breakpoint. | ||
// | ||
// RIP(msg) | ||
// Display a message and force a breakpoint. | ||
// | ||
// Usage: | ||
// These macros require extra parantheses for the msg argument | ||
// example, ASSERTMSG(x > 0, ("x is less than 0\n")); | ||
// WARNING(("App passed NULL pointer, ignoring...\n")); | ||
// | ||
|
||
#pragma once | ||
|
||
#define DBG_VERBOSE 1 | ||
#define DBG_TERSE 2 | ||
#define DBG_WARNING 3 | ||
#define DBG_ERROR 4 | ||
#define DBG_RIP 5 | ||
|
||
BOOL | ||
RealDebugMessage( | ||
_In_ DWORD dwSize, | ||
_In_ PCSTR pszMessage, | ||
va_list arglist | ||
); | ||
|
||
BOOL | ||
DbgPrint( | ||
_In_ PCSTR pszFormatString, | ||
... | ||
); | ||
|
||
VOID | ||
DbgDOMDoc( | ||
_In_ PCSTR pszMessage, | ||
_In_ IXMLDOMDocument2* pDomDoc | ||
); | ||
|
||
#if DBG | ||
|
||
#ifndef MAX_DEBUG_LEVEL | ||
#define MAX_DEBUG_LEVEL DBG_VERBOSE | ||
#endif | ||
|
||
#define DBGMSG(level, prefix, msg) { \ | ||
INT dbgLevel = level; \ | ||
if (MAX_DEBUG_LEVEL <= (dbgLevel)) { \ | ||
DbgPrint("%s %s (%d): ", prefix, __FILE__, __LINE__); \ | ||
DbgPrint(msg); \ | ||
} \ | ||
} | ||
|
||
#define DBGMSG_ON_HR(level, prefix, hr) { \ | ||
INT dbgLevel = level; \ | ||
HRESULT hres = hr; \ | ||
if (MAX_DEBUG_LEVEL <= (dbgLevel) && FAILED(hres)) { \ | ||
DbgPrint("%s %s (%d): Call failed with HRESULT = 0x%x\n", prefix, __FILE__, __LINE__, hr); \ | ||
} \ | ||
} | ||
|
||
#define DBGMSG_ON_HR_EXC(level, prefix, hr, hr_exc) { \ | ||
INT dbgLevel = level; \ | ||
HRESULT hres = hr; \ | ||
if (MAX_DEBUG_LEVEL <= (dbgLevel) && FAILED(hres) && hres != hr_exc) { \ | ||
DbgPrint("%s %s (%d): Call failed with HRESULT = 0x%x\n", prefix, __FILE__, __LINE__, hr); \ | ||
} \ | ||
} | ||
|
||
#define DBGPRINT(level, msg) { \ | ||
INT dbgLevel = level; \ | ||
if (MAX_DEBUG_LEVEL <= (dbgLevel)) { \ | ||
DbgPrint(msg); \ | ||
} \ | ||
} | ||
|
||
#define DBGXML(msg, pDomDoc) { \ | ||
INT dbgLevel = DBG_VERBOSE; \ | ||
if (MAX_DEBUG_LEVEL <= dbgLevel) { \ | ||
DbgDOMDoc(msg, pDomDoc); \ | ||
} \ | ||
} | ||
|
||
#define VERBOSE(msg) DBGPRINT(DBG_VERBOSE, msg) | ||
#define TERSE(msg) DBGPRINT(DBG_TERSE, msg) | ||
#define WARNING(msg) DBGMSG(DBG_WARNING, "WRN", msg) | ||
#define ERR(msg) DBGMSG(DBG_ERROR, "ERR", msg) | ||
#define ERR_ON_HR(hr) DBGMSG_ON_HR(DBG_ERROR, "ERR", hr) | ||
#define ERR_ON_HR_EXC(hr, hr_exc) DBGMSG_ON_HR_EXC(DBG_ERROR, "ERR", hr, hr_exc) | ||
|
||
#define ASSERT(cond) { \ | ||
if (! (cond)) { \ | ||
RIP(("\n")); \ | ||
} \ | ||
} | ||
|
||
#define ASSERTMSG(cond, msg) { \ | ||
if (!(cond)) { \ | ||
RIP(msg); \ | ||
} \ | ||
} | ||
|
||
#define RIP(msg) { \ | ||
DBGMSG(DBG_RIP, "RIP", msg); \ | ||
DebugBreak(); \ | ||
} | ||
|
||
#define DBG_ONLY(p) p | ||
|
||
#else // !DBG | ||
|
||
#define VERBOSE(msg) | ||
#define TERSE(msg) | ||
#define WARNING(msg) | ||
#define ERR(msg) | ||
#define ERR_ON_HR(hr) | ||
#define ERR_ON_HR_EXC(hr, hr_exc) | ||
|
||
#define ASSERT(cond) | ||
|
||
#define ASSERTMSG(cond, msg) | ||
|
||
#define RIP(msg) | ||
|
||
#define DBG_ONLY(p) | ||
|
||
#define DBGMSG(level, prefix, msg) | ||
|
||
#define DBGMSG_ON_HR(level, prefix, hr) | ||
|
||
#define DBGPRINT(level, msg) | ||
|
||
#define DBGXML(msg, pDomDoc) | ||
|
||
#endif | ||
|
Oops, something went wrong.