Skip to content

Commit

Permalink
Fix microsoft#12 by modifying gitignore to include some debug folders
Browse files Browse the repository at this point in the history
  • Loading branch information
J M Rossy committed Aug 25, 2015
1 parent d619854 commit f18a140
Show file tree
Hide file tree
Showing 12 changed files with 665 additions and 2 deletions.
2 changes: 0 additions & 2 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,6 @@
[Dd]ebugPublic/
[Rr]elease/
[Rr]eleases/
x64/
x86/
build/
bld/
[Bb]in/
Expand Down
Binary file added network/wlan/ihvfrm/x64/rc4utils.dll
Binary file not shown.
Binary file added network/wlan/ihvfrm/x64/rc4utils.lib
Binary file not shown.
Binary file added network/wlan/ihvfrm/x86/rc4utils.dll
Binary file not shown.
Binary file added network/wlan/ihvfrm/x86/rc4utils.lib
Binary file not shown.
2 changes: 2 additions & 0 deletions print/XPSDrvSmpl/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
# Allow tracking debug folder for this sample
!debug/
189 changes: 189 additions & 0 deletions print/XPSDrvSmpl/src/debug/debug.cpp
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&)
{
}
}

186 changes: 186 additions & 0 deletions print/XPSDrvSmpl/src/debug/debug.h
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

Loading

0 comments on commit f18a140

Please sign in to comment.