mirror of https://github.com/tongzx/nt5src
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.
425 lines
13 KiB
425 lines
13 KiB
////////////////////////////////////////////////////////////////
|
|
//
|
|
// General purpose debugging utilities
|
|
//
|
|
#include "StdAfx.h"
|
|
#include "Debug.h"
|
|
#include <afxpriv.h> // for MFC WM_ messages
|
|
|
|
#ifdef _DEBUG
|
|
#define new DEBUG_NEW
|
|
#undef THIS_FILE
|
|
static char THIS_FILE[] = __FILE__;
|
|
|
|
int CTraceEx::nIndent=-1; // current indent level
|
|
|
|
#define _countof(array) (sizeof(array)/sizeof(array[0]))
|
|
|
|
////////////////
|
|
// These functions are copied from dumpout.cpp in the MFC source,
|
|
// with my modification to do indented TRACEing
|
|
//
|
|
void AFXAPI AfxDump(const CObject* pOb)
|
|
{
|
|
afxDump << pOb;
|
|
}
|
|
|
|
void AFX_CDECL AfxTrace(LPCTSTR lpszFormat, ...)
|
|
{
|
|
#ifdef _DEBUG // all AfxTrace output is controlled by afxTraceEnabled
|
|
if (!afxTraceEnabled)
|
|
return;
|
|
#endif
|
|
|
|
va_list args;
|
|
va_start(args, lpszFormat);
|
|
|
|
int nBuf;
|
|
TCHAR szBuffer[512];
|
|
|
|
nBuf = _vstprintf(szBuffer, lpszFormat, args);
|
|
ASSERT(nBuf < _countof(szBuffer));
|
|
|
|
// PD: Here are my added lines to do the indenting. Search
|
|
// for newlines and insert prefix before each one. Yawn.
|
|
//
|
|
static BOOL bStartNewLine = TRUE;
|
|
TCHAR* nextline;
|
|
for (TCHAR* start = szBuffer; *start; start=nextline+1)
|
|
{
|
|
if (bStartNewLine)
|
|
{
|
|
if ((afxTraceFlags & traceMultiApp) && (AfxGetApp() != NULL))
|
|
{
|
|
afxDump << AfxGetApp()->m_pszExeName << _T(": ");
|
|
}
|
|
afxDump << CString(_T(' '),CTraceEx::nIndent*2);
|
|
bStartNewLine = FALSE;
|
|
}
|
|
nextline = _tcschr(start, _T('\n'));
|
|
if (nextline)
|
|
{
|
|
*nextline = 0; // terminate string at newline
|
|
bStartNewLine = TRUE;
|
|
}
|
|
afxDump << start;
|
|
if (!nextline)
|
|
break;
|
|
afxDump << _T("\n"); // the one I terminated
|
|
}
|
|
|
|
va_end(args);
|
|
}
|
|
|
|
//////////////////
|
|
// Get window name in the form classname[HWND,title]
|
|
// Searches all the parents for a window with a title.
|
|
//
|
|
CString sDbgName(CWnd* pWnd)
|
|
{
|
|
CString sTitle;
|
|
HWND hwnd = pWnd->GetSafeHwnd();
|
|
if (hwnd==NULL)
|
|
{
|
|
sTitle = _T("NULL");
|
|
}
|
|
else if (!::IsWindow(hwnd))
|
|
{
|
|
sTitle = _T("[bad window]");
|
|
}
|
|
else
|
|
{
|
|
sTitle = _T("[no title]");
|
|
for (CWnd* pw = pWnd; pw; pw = pw->GetParent())
|
|
{
|
|
if (pw->GetWindowTextLength() > 0)
|
|
{
|
|
pw->GetWindowText(sTitle);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
CString s;
|
|
CString s2;
|
|
USES_CONVERSION;
|
|
s2 = pWnd ? A2T(pWnd->GetRuntimeClass()->m_lpszClassName) : _T("NULL");
|
|
|
|
s.Format(_T("%s[0x%04x,\"%s\"]"), s2, hwnd, (LPCTSTR)sTitle);
|
|
return s;
|
|
}
|
|
|
|
struct {
|
|
UINT msg;
|
|
LPCTSTR name;
|
|
} MsgData[] = {
|
|
{ WM_CREATE,_T("WM_CREATE") },
|
|
{ WM_DESTROY,_T("WM_DESTROY") },
|
|
{ WM_MOVE,_T("WM_MOVE") },
|
|
{ WM_SIZE,_T("WM_SIZE") },
|
|
{ WM_ACTIVATE,_T("WM_ACTIVATE") },
|
|
{ WM_SETFOCUS,_T("WM_SETFOCUS") },
|
|
{ WM_KILLFOCUS,_T("WM_KILLFOCUS") },
|
|
{ WM_ENABLE,_T("WM_ENABLE") },
|
|
{ WM_SETREDRAW,_T("WM_SETREDRAW") },
|
|
{ WM_SETTEXT,_T("WM_SETTEXT") },
|
|
{ WM_GETTEXT,_T("WM_GETTEXT") },
|
|
{ WM_GETTEXTLENGTH,_T("WM_GETTEXTLENGTH") },
|
|
{ WM_PAINT,_T("WM_PAINT") },
|
|
{ WM_CLOSE,_T("WM_CLOSE") },
|
|
{ WM_QUERYENDSESSION,_T("WM_QUERYENDSESSION") },
|
|
{ WM_QUIT,_T("WM_QUIT") },
|
|
{ WM_QUERYOPEN,_T("WM_QUERYOPEN") },
|
|
{ WM_ERASEBKGND,_T("WM_ERASEBKGND") },
|
|
{ WM_SYSCOLORCHANGE,_T("WM_SYSCOLORCHANGE") },
|
|
{ WM_ENDSESSION,_T("WM_ENDSESSION") },
|
|
{ WM_SHOWWINDOW,_T("WM_SHOWWINDOW") },
|
|
{ WM_WININICHANGE,_T("WM_WININICHANGE") },
|
|
{ WM_SETTINGCHANGE,_T("WM_SETTINGCHANGE") },
|
|
{ WM_DEVMODECHANGE,_T("WM_DEVMODECHANGE") },
|
|
{ WM_ACTIVATEAPP,_T("WM_ACTIVATEAPP") },
|
|
{ WM_FONTCHANGE,_T("WM_FONTCHANGE") },
|
|
{ WM_TIMECHANGE,_T("WM_TIMECHANGE") },
|
|
{ WM_CANCELMODE,_T("WM_CANCELMODE") },
|
|
{ WM_SETCURSOR,_T("WM_SETCURSOR") },
|
|
{ WM_MOUSEACTIVATE,_T("WM_MOUSEACTIVATE") },
|
|
{ WM_CHILDACTIVATE,_T("WM_CHILDACTIVATE") },
|
|
{ WM_QUEUESYNC,_T("WM_QUEUESYNC") },
|
|
{ WM_GETMINMAXINFO,_T("WM_GETMINMAXINFO") },
|
|
{ WM_PAINTICON,_T("WM_PAINTICON") },
|
|
{ WM_ICONERASEBKGND,_T("WM_ICONERASEBKGND") },
|
|
{ WM_NEXTDLGCTL,_T("WM_NEXTDLGCTL") },
|
|
{ WM_SPOOLERSTATUS,_T("WM_SPOOLERSTATUS") },
|
|
{ WM_DRAWITEM,_T("WM_DRAWITEM") },
|
|
{ WM_MEASUREITEM,_T("WM_MEASUREITEM") },
|
|
{ WM_DELETEITEM,_T("WM_DELETEITEM") },
|
|
{ WM_VKEYTOITEM,_T("WM_VKEYTOITEM") },
|
|
{ WM_CHARTOITEM,_T("WM_CHARTOITEM") },
|
|
{ WM_SETFONT,_T("WM_SETFONT") },
|
|
{ WM_GETFONT,_T("WM_GETFONT") },
|
|
{ WM_SETHOTKEY,_T("WM_SETHOTKEY") },
|
|
{ WM_GETHOTKEY,_T("WM_GETHOTKEY") },
|
|
{ WM_QUERYDRAGICON,_T("WM_QUERYDRAGICON") },
|
|
{ WM_COMPAREITEM,_T("WM_COMPAREITEM") },
|
|
{ WM_COMPACTING,_T("WM_COMPACTING") },
|
|
{ WM_COMMNOTIFY,_T("WM_COMMNOTIFY") },
|
|
{ WM_WINDOWPOSCHANGING,_T("WM_WINDOWPOSCHANGING") },
|
|
{ WM_WINDOWPOSCHANGED,_T("WM_WINDOWPOSCHANGED") },
|
|
{ WM_POWER,_T("WM_POWER") },
|
|
{ WM_COPYDATA,_T("WM_COPYDATA") },
|
|
{ WM_CANCELJOURNAL,_T("WM_CANCELJOURNAL") },
|
|
#if(WINVER >= 0x0400)
|
|
{ WM_NOTIFY,_T("WM_NOTIFY") },
|
|
{ WM_INPUTLANGCHANGEREQUEST,_T("WM_INPUTLANGCHANGEREQUEST") },
|
|
{ WM_INPUTLANGCHANGE,_T("WM_INPUTLANGCHANGE") },
|
|
{ WM_TCARD,_T("WM_TCARD") },
|
|
{ WM_HELP,_T("WM_HELP") },
|
|
{ WM_USERCHANGED,_T("WM_USERCHANGED") },
|
|
{ WM_NOTIFYFORMAT,_T("WM_NOTIFYFORMAT") },
|
|
{ WM_CONTEXTMENU,_T("WM_CONTEXTMENU") },
|
|
{ WM_STYLECHANGING,_T("WM_STYLECHANGING") },
|
|
{ WM_STYLECHANGED,_T("WM_STYLECHANGED") },
|
|
{ WM_DISPLAYCHANGE,_T("WM_DISPLAYCHANGE") },
|
|
{ WM_GETICON,_T("WM_GETICON") },
|
|
{ WM_SETICON,_T("WM_SETICON") },
|
|
#endif /* WINVER >= 0x0400 */
|
|
{ WM_NCCREATE,_T("WM_NCCREATE") },
|
|
{ WM_NCDESTROY,_T("WM_NCDESTROY") },
|
|
{ WM_NCCALCSIZE,_T("WM_NCCALCSIZE") },
|
|
{ WM_NCHITTEST,_T("WM_NCHITTEST") },
|
|
{ WM_NCPAINT,_T("WM_NCPAINT") },
|
|
{ WM_NCACTIVATE,_T("WM_NCACTIVATE") },
|
|
{ WM_GETDLGCODE,_T("WM_GETDLGCODE") },
|
|
{ WM_NCMOUSEMOVE,_T("WM_NCMOUSEMOVE") },
|
|
{ WM_NCLBUTTONDOWN,_T("WM_NCLBUTTONDOWN") },
|
|
{ WM_NCLBUTTONUP,_T("WM_NCLBUTTONUP") },
|
|
{ WM_NCLBUTTONDBLCLK,_T("WM_NCLBUTTONDBLCLK") },
|
|
{ WM_NCRBUTTONDOWN,_T("WM_NCRBUTTONDOWN") },
|
|
{ WM_NCRBUTTONUP,_T("WM_NCRBUTTONUP") },
|
|
{ WM_NCRBUTTONDBLCLK,_T("WM_NCRBUTTONDBLCLK") },
|
|
{ WM_NCMBUTTONDOWN,_T("WM_NCMBUTTONDOWN") },
|
|
{ WM_NCMBUTTONUP,_T("WM_NCMBUTTONUP") },
|
|
{ WM_NCMBUTTONDBLCLK,_T("WM_NCMBUTTONDBLCLK") },
|
|
{ WM_KEYDOWN,_T("WM_KEYDOWN") },
|
|
{ WM_KEYUP,_T("WM_KEYUP") },
|
|
{ WM_CHAR,_T("WM_CHAR") },
|
|
{ WM_DEADCHAR,_T("WM_DEADCHAR") },
|
|
{ WM_SYSKEYDOWN,_T("WM_SYSKEYDOWN") },
|
|
{ WM_SYSKEYUP,_T("WM_SYSKEYUP") },
|
|
{ WM_SYSCHAR,_T("WM_SYSCHAR") },
|
|
{ WM_SYSDEADCHAR,_T("WM_SYSDEADCHAR") },
|
|
{ WM_KEYDOWN,_T("WM_KEYDOWN") },
|
|
{ WM_KEYUP,_T("WM_KEYUP") },
|
|
{ WM_CHAR,_T("WM_CHAR") },
|
|
{ WM_DEADCHAR,_T("WM_DEADCHAR") },
|
|
{ WM_SYSKEYDOWN,_T("WM_SYSKEYDOWN") },
|
|
{ WM_SYSKEYUP,_T("WM_SYSKEYUP") },
|
|
{ WM_SYSCHAR,_T("WM_SYSCHAR") },
|
|
{ WM_SYSDEADCHAR,_T("WM_SYSDEADCHAR") },
|
|
#if(WINVER >= 0x0400)
|
|
{ WM_IME_STARTCOMPOSITION,_T("WM_IME_STARTCOMPOSITION") },
|
|
{ WM_IME_ENDCOMPOSITION,_T("WM_IME_ENDCOMPOSITION") },
|
|
{ WM_IME_COMPOSITION,_T("WM_IME_COMPOSITION") },
|
|
{ WM_IME_KEYLAST,_T("WM_IME_KEYLAST") },
|
|
#endif
|
|
{ WM_INITDIALOG,_T("WM_INITDIALOG") },
|
|
{ WM_COMMAND,_T("WM_COMMAND") },
|
|
{ WM_SYSCOMMAND,_T("WM_SYSCOMMAND") },
|
|
{ WM_TIMER,_T("WM_TIMER") },
|
|
{ WM_HSCROLL,_T("WM_HSCROLL") },
|
|
{ WM_VSCROLL,_T("WM_VSCROLL") },
|
|
{ WM_INITMENU,_T("WM_INITMENU") },
|
|
{ WM_INITMENUPOPUP,_T("WM_INITMENUPOPUP") },
|
|
{ WM_MENUSELECT,_T("WM_MENUSELECT") },
|
|
{ WM_MENUCHAR,_T("WM_MENUCHAR") },
|
|
{ WM_ENTERIDLE,_T("WM_ENTERIDLE") },
|
|
{ WM_CTLCOLORMSGBOX,_T("WM_CTLCOLORMSGBOX") },
|
|
{ WM_CTLCOLOREDIT,_T("WM_CTLCOLOREDIT") },
|
|
{ WM_CTLCOLORLISTBOX,_T("WM_CTLCOLORLISTBOX") },
|
|
{ WM_CTLCOLORBTN,_T("WM_CTLCOLORBTN") },
|
|
{ WM_CTLCOLORDLG,_T("WM_CTLCOLORDLG") },
|
|
{ WM_CTLCOLORSCROLLBAR,_T("WM_CTLCOLORSCROLLBAR") },
|
|
{ WM_CTLCOLORSTATIC,_T("WM_CTLCOLORSTATIC") },
|
|
{ WM_MOUSEMOVE,_T("WM_MOUSEMOVE") },
|
|
{ WM_LBUTTONDOWN,_T("WM_LBUTTONDOWN") },
|
|
{ WM_LBUTTONUP,_T("WM_LBUTTONUP") },
|
|
{ WM_LBUTTONDBLCLK,_T("WM_LBUTTONDBLCLK") },
|
|
{ WM_RBUTTONDOWN,_T("WM_RBUTTONDOWN") },
|
|
{ WM_RBUTTONUP,_T("WM_RBUTTONUP") },
|
|
{ WM_RBUTTONDBLCLK,_T("WM_RBUTTONDBLCLK") },
|
|
{ WM_MBUTTONDOWN,_T("WM_MBUTTONDOWN") },
|
|
{ WM_MBUTTONUP,_T("WM_MBUTTONUP") },
|
|
{ WM_MBUTTONDBLCLK,_T("WM_MBUTTONDBLCLK") },
|
|
{ WM_MOUSEMOVE,_T("WM_MOUSEMOVE") },
|
|
{ WM_LBUTTONDOWN,_T("WM_LBUTTONDOWN") },
|
|
{ WM_LBUTTONUP,_T("WM_LBUTTONUP") },
|
|
{ WM_LBUTTONDBLCLK,_T("WM_LBUTTONDBLCLK") },
|
|
{ WM_RBUTTONDOWN,_T("WM_RBUTTONDOWN") },
|
|
{ WM_RBUTTONUP,_T("WM_RBUTTONUP") },
|
|
{ WM_RBUTTONDBLCLK,_T("WM_RBUTTONDBLCLK") },
|
|
{ WM_MBUTTONDOWN,_T("WM_MBUTTONDOWN") },
|
|
{ WM_MBUTTONUP,_T("WM_MBUTTONUP") },
|
|
{ WM_MBUTTONDBLCLK,_T("WM_MBUTTONDBLCLK") },
|
|
{ WM_PARENTNOTIFY,_T("WM_PARENTNOTIFY") },
|
|
{ WM_ENTERMENULOOP,_T("WM_ENTERMENULOOP") },
|
|
{ WM_EXITMENULOOP,_T("WM_EXITMENULOOP") },
|
|
#if(WINVER >= 0x0400)
|
|
{ WM_NEXTMENU,_T("WM_NEXTMENU") },
|
|
{ WM_SIZING,_T("WM_SIZING") },
|
|
{ WM_CAPTURECHANGED,_T("WM_CAPTURECHANGED") },
|
|
{ WM_MOVING,_T("WM_MOVING") },
|
|
{ WM_POWERBROADCAST,_T("WM_POWERBROADCAST") },
|
|
{ WM_DEVICECHANGE,_T("WM_DEVICECHANGE") },
|
|
{ WM_IME_SETCONTEXT,_T("WM_IME_SETCONTEXT") },
|
|
{ WM_IME_NOTIFY,_T("WM_IME_NOTIFY") },
|
|
{ WM_IME_CONTROL,_T("WM_IME_CONTROL") },
|
|
{ WM_IME_COMPOSITIONFULL,_T("WM_IME_COMPOSITIONFULL") },
|
|
{ WM_IME_SELECT,_T("WM_IME_SELECT") },
|
|
{ WM_IME_CHAR,_T("WM_IME_CHAR") },
|
|
{ WM_IME_KEYDOWN,_T("WM_IME_KEYDOWN") },
|
|
{ WM_IME_KEYUP,_T("WM_IME_KEYUP") },
|
|
#endif
|
|
{ WM_MDICREATE,_T("WM_MDICREATE") },
|
|
{ WM_MDIDESTROY,_T("WM_MDIDESTROY") },
|
|
{ WM_MDIACTIVATE,_T("WM_MDIACTIVATE") },
|
|
{ WM_MDIRESTORE,_T("WM_MDIRESTORE") },
|
|
{ WM_MDINEXT,_T("WM_MDINEXT") },
|
|
{ WM_MDIMAXIMIZE,_T("WM_MDIMAXIMIZE") },
|
|
{ WM_MDITILE,_T("WM_MDITILE") },
|
|
{ WM_MDICASCADE,_T("WM_MDICASCADE") },
|
|
{ WM_MDIICONARRANGE,_T("WM_MDIICONARRANGE") },
|
|
{ WM_MDIGETACTIVE,_T("WM_MDIGETACTIVE") },
|
|
{ WM_MDISETMENU,_T("WM_MDISETMENU") },
|
|
{ WM_ENTERSIZEMOVE,_T("WM_ENTERSIZEMOVE") },
|
|
{ WM_EXITSIZEMOVE,_T("WM_EXITSIZEMOVE") },
|
|
{ WM_DROPFILES,_T("WM_DROPFILES") },
|
|
{ WM_MDIREFRESHMENU,_T("WM_MDIREFRESHMENU") },
|
|
{ WM_CUT,_T("WM_CUT") },
|
|
{ WM_COPY,_T("WM_COPY") },
|
|
{ WM_PASTE,_T("WM_PASTE") },
|
|
{ WM_CLEAR,_T("WM_CLEAR") },
|
|
{ WM_UNDO,_T("WM_UNDO") },
|
|
{ WM_RENDERFORMAT,_T("WM_RENDERFORMAT") },
|
|
{ WM_RENDERALLFORMATS,_T("WM_RENDERALLFORMATS") },
|
|
{ WM_DESTROYCLIPBOARD,_T("WM_DESTROYCLIPBOARD") },
|
|
{ WM_DRAWCLIPBOARD,_T("WM_DRAWCLIPBOARD") },
|
|
{ WM_PAINTCLIPBOARD,_T("WM_PAINTCLIPBOARD") },
|
|
{ WM_VSCROLLCLIPBOARD,_T("WM_VSCROLLCLIPBOARD") },
|
|
{ WM_SIZECLIPBOARD,_T("WM_SIZECLIPBOARD") },
|
|
{ WM_ASKCBFORMATNAME,_T("WM_ASKCBFORMATNAME") },
|
|
{ WM_CHANGECBCHAIN,_T("WM_CHANGECBCHAIN") },
|
|
{ WM_HSCROLLCLIPBOARD,_T("WM_HSCROLLCLIPBOARD") },
|
|
{ WM_QUERYNEWPALETTE,_T("WM_QUERYNEWPALETTE") },
|
|
{ WM_PALETTEISCHANGING,_T("WM_PALETTEISCHANGING") },
|
|
{ WM_PALETTECHANGED,_T("WM_PALETTECHANGED") },
|
|
{ WM_HOTKEY,_T("WM_HOTKEY") },
|
|
#if(WINVER >= 0x0400)
|
|
{ WM_PRINT,_T("WM_PRINT") },
|
|
{ WM_PRINTCLIENT,_T("WM_PRINTCLIENT") },
|
|
#endif
|
|
// Below are MFC messages
|
|
{ WM_QUERYAFXWNDPROC,_T("*WM_QUERYAFXWNDPROC") },
|
|
{ WM_SIZEPARENT,_T("*WM_SIZEPARENT") },
|
|
{ WM_SETMESSAGESTRING,_T("*WM_SETMESSAGESTRING") },
|
|
{ WM_IDLEUPDATECMDUI,_T("*WM_IDLEUPDATECMDUI") },
|
|
{ WM_INITIALUPDATE,_T("*WM_INITIALUPDATE") },
|
|
{ WM_COMMANDHELP,_T("*WM_COMMANDHELP") },
|
|
{ WM_HELPHITTEST,_T("*WM_HELPHITTEST") },
|
|
{ WM_EXITHELPMODE,_T("*WM_EXITHELPMODE") },
|
|
{ WM_RECALCPARENT,_T("*WM_RECALCPARENT") },
|
|
{ WM_SIZECHILD,_T("*WM_SIZECHILD") },
|
|
{ WM_KICKIDLE,_T("*WM_KICKIDLE") },
|
|
{ WM_QUERYCENTERWND,_T("*WM_QUERYCENTERWND") },
|
|
{ WM_DISABLEMODAL,_T("*WM_DISABLEMODAL") },
|
|
{ WM_FLOATSTATUS,_T("*WM_FLOATSTATUS") },
|
|
{ WM_ACTIVATETOPLEVEL,_T("*WM_ACTIVATETOPLEVEL") },
|
|
{ WM_QUERY3DCONTROLS,_T("*WM_QUERY3DCONTROLS") },
|
|
{ WM_SOCKET_NOTIFY,_T("*WM_SOCKET_NOTIFY") },
|
|
{ WM_SOCKET_DEAD,_T("*WM_SOCKET_DEAD") },
|
|
{ WM_POPMESSAGESTRING,_T("*WM_POPMESSAGESTRING") },
|
|
{ WM_OCC_LOADFROMSTREAM,_T("*WM_OCC_LOADFROMSTREAM") },
|
|
{ WM_OCC_LOADFROMSTORAGE,_T("*WM_OCC_LOADFROMSTORAGE") },
|
|
{ WM_OCC_INITNEW,_T("*WM_OCC_INITNEW") },
|
|
{ WM_QUEUE_SENTINEL,_T("*WM_QUEUE_SENTINEL") },
|
|
{ 0,NULL }
|
|
};
|
|
|
|
////////////////
|
|
// This class is basically just an array of 1024 strings,
|
|
// the names of each WM_ message. Constructor initializes it.
|
|
//
|
|
class CWndMsgMap {
|
|
static LPCTSTR Names[]; // array of WM_ message names
|
|
public:
|
|
CWndMsgMap(); // constructor initializes them
|
|
CString GetMsgName(UINT msg); // get name of message
|
|
};
|
|
LPCTSTR CWndMsgMap::Names[WM_USER]; // name of each WM_ message
|
|
|
|
//////////////////
|
|
// Initialize array from sparse data
|
|
//
|
|
CWndMsgMap::CWndMsgMap()
|
|
{
|
|
// copy sparse MsgData into table
|
|
memset(Names, 0, sizeof(Names));
|
|
for (int i=0; MsgData[i].msg; i++)
|
|
Names[MsgData[i].msg] = MsgData[i].name;
|
|
}
|
|
|
|
////////////////
|
|
// Get the name of a WM_ message
|
|
//
|
|
CString CWndMsgMap::GetMsgName(UINT msg)
|
|
{
|
|
CString name;
|
|
if (msg>=WM_USER)
|
|
name.Format(_T("WM_USER+%d"), msg-WM_USER);
|
|
else if (Names[msg])
|
|
name = Names[msg];
|
|
else
|
|
name.Format(_T("0x%04x"), msg);
|
|
return name;
|
|
}
|
|
|
|
//////////////////
|
|
// Get name of WM_ message.
|
|
//
|
|
CString sDbgName(UINT uMsg)
|
|
{
|
|
static CWndMsgMap wndMsgMap; // instantiate 1st time called
|
|
return wndMsgMap.GetMsgName(uMsg);
|
|
}
|
|
|
|
#ifdef REFIID
|
|
|
|
// Most apps don't need to use DbgName(REFIID)
|
|
// Apps that do can set this static global to a table of
|
|
// DBGINTERFACENAME's it wants to TRACE with DbgName(REFIID)
|
|
//
|
|
DBGINTERFACENAME* _pDbgInterfaceNames = NULL;
|
|
|
|
//////////////////
|
|
// Get OLE interface name.
|
|
//
|
|
CString sDbgName(REFIID iid)
|
|
{
|
|
if (_pDbgInterfaceNames)
|
|
{
|
|
for (int i=0; _pDbgInterfaceNames[i].name; i++)
|
|
{
|
|
if (memcmp(_pDbgInterfaceNames[i].piid, &iid, sizeof(IID))==0)
|
|
return _pDbgInterfaceNames[i].name;
|
|
}
|
|
}
|
|
static CString s;
|
|
s.Format(_T("{%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x}"),
|
|
iid.Data1, iid.Data2, iid.Data3,
|
|
iid.Data4[0], iid.Data4[1], iid.Data4[2], iid.Data4[3],
|
|
iid.Data4[4], iid.Data4[5], iid.Data4[6], iid.Data4[7]);
|
|
return s;
|
|
}
|
|
|
|
#endif // REFIID
|
|
|
|
#endif // DEBUG
|
|
|