/* * Message spying routines * * Copyright 1994, Bob Amstadt * 1995, Alex Korobka */ #include <stdlib.h> #include <string.h> #include <stdio.h> #include "windef.h" #include "wingdi.h" #include "wine/winuser16.h" #include "wine/winbase16.h" #include "win.h" #include "module.h" #include "options.h" #include "debugtools.h" #include "spy.h" #include "commctrl.h" DEFAULT_DEBUG_CHANNEL(message) #define SPY_MAX_MSGNUM WM_USER #define SPY_INDENT_UNIT 4 /* 4 spaces */ static const char * const MessageTypeNames[SPY_MAX_MSGNUM + 1] = { "wm_null", /* 0x00 */ "WM_CREATE", "WM_DESTROY", "WM_MOVE", "wm_sizewait", "WM_SIZE", "WM_ACTIVATE", "WM_SETFOCUS", "WM_KILLFOCUS", "WM_SETVISIBLE", "WM_ENABLE", "WM_SETREDRAW", "WM_SETTEXT", "WM_GETTEXT", "WM_GETTEXTLENGTH", "WM_PAINT", "WM_CLOSE", /* 0x10 */ "WM_QUERYENDSESSION", "WM_QUIT", "WM_QUERYOPEN", "WM_ERASEBKGND", "WM_SYSCOLORCHANGE", "WM_ENDSESSION", "wm_systemerror", "WM_SHOWWINDOW", "WM_CTLCOLOR", "WM_WININICHANGE", "WM_DEVMODECHANGE", "WM_ACTIVATEAPP", "WM_FONTCHANGE", "WM_TIMECHANGE", "WM_CANCELMODE", "WM_SETCURSOR", /* 0x20 */ "WM_MOUSEACTIVATE", "WM_CHILDACTIVATE", "WM_QUEUESYNC", "WM_GETMINMAXINFO", "wm_unused3", "wm_painticon", "WM_ICONERASEBKGND", "WM_NEXTDLGCTL", "wm_alttabactive", "WM_SPOOLERSTATUS", "WM_DRAWITEM", "WM_MEASUREITEM", "WM_DELETEITEM", "WM_VKEYTOITEM", "WM_CHARTOITEM", "WM_SETFONT", /* 0x30 */ "WM_GETFONT", "WM_SETHOTKEY", "WM_GETHOTKEY", "wm_filesyschange", "wm_isactiveicon", "wm_queryparkicon", "WM_QUERYDRAGICON", "wm_querysavestate", "WM_COMPAREITEM", "wm_testing", NULL, "wm_otherwindowcreated", "wm_otherwindowdestroyed", "wm_activateshellwindow", NULL, NULL, /* 0x40 */ "wm_compacting", NULL, NULL, "WM_COMMNOTIFY", NULL, "WM_WINDOWPOSCHANGING", /* 0x0046 */ "WM_WINDOWPOSCHANGED", /* 0x0047 */ "WM_POWER", NULL, "WM_COPYDATA", "WM_CANCELJOURNAL", NULL, NULL, "WM_NOTIFY", NULL, /* 0x0050 */ "WM_INPUTLANGCHANGEREQUEST", "WM_INPUTLANGCHANGE", "WM_TCARD", "WM_HELP", "WM_USERCHANGED", "WM_NOTIFYFORMAT", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0060 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0070 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_CONTEXTMENU", "WM_STYLECHANGING", "WM_STYLECHANGED", "WM_DISPLAYCHANGE", "WM_GETICON", "WM_SETICON", /* 0x0080 */ "WM_NCCREATE", /* 0x0081 */ "WM_NCDESTROY", /* 0x0082 */ "WM_NCCALCSIZE", /* 0x0083 */ "WM_NCHITTEST", /* 0x0084 */ "WM_NCPAINT", /* 0x0085 */ "WM_NCACTIVATE", /* 0x0086 */ "WM_GETDLGCODE", /* 0x0087 */ "WM_SYNCPAINT", "WM_SYNCTASK", NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0090 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x00A0 */ "WM_NCMOUSEMOVE", /* 0x00A0 */ "WM_NCLBUTTONDOWN", /* 0x00A1 */ "WM_NCLBUTTONUP", /* 0x00A2 */ "WM_NCLBUTTONDBLCLK", /* 0x00A3 */ "WM_NCRBUTTONDOWN", /* 0x00A4 */ "WM_NCRBUTTONUP", /* 0x00A5 */ "WM_NCRBUTTONDBLCLK", /* 0x00A6 */ "WM_NCMBUTTONDOWN", /* 0x00A7 */ "WM_NCMBUTTONUP", /* 0x00A8 */ "WM_NCMBUTTONDBLCLK", /* 0x00A9 */ NULL, NULL, NULL, NULL, NULL, NULL, /* 0x00B0 - Win32 Edit controls */ "EM_GETSEL32", /* 0x00b0 */ "EM_SETSEL32", /* 0x00b1 */ "EM_GETRECT32", /* 0x00b2 */ "EM_SETRECT32", /* 0x00b3 */ "EM_SETRECTNP32", /* 0x00b4 */ "EM_SCROLL32", /* 0x00b5 */ "EM_LINESCROLL32", /* 0x00b6 */ "EM_SCROLLCARET32", /* 0x00b7 */ "EM_GETMODIFY32", /* 0x00b8 */ "EM_SETMODIFY32", /* 0x00b9 */ "EM_GETLINECOUNT32", /* 0x00ba */ "EM_LINEINDEX32", /* 0x00bb */ "EM_SETHANDLE32", /* 0x00bc */ "EM_GETHANDLE32", /* 0x00bd */ "EM_GETTHUMB32", /* 0x00be */ NULL, /* 0x00bf */ NULL, /* 0x00c0 */ "EM_LINELENGTH32", /* 0x00c1 */ "EM_REPLACESEL32", /* 0x00c2 */ NULL, /* 0x00c3 */ "EM_GETLINE32", /* 0x00c4 */ "EM_LIMITTEXT32", /* 0x00c5 */ "EM_CANUNDO32", /* 0x00c6 */ "EM_UNDO32", /* 0x00c7 */ "EM_FMTLINES32", /* 0x00c8 */ "EM_LINEFROMCHAR32", /* 0x00c9 */ NULL, /* 0x00ca */ "EM_SETTABSTOPS32", /* 0x00cb */ "EM_SETPASSWORDCHAR32", /* 0x00cc */ "EM_EMPTYUNDOBUFFER32", /* 0x00cd */ "EM_GETFIRSTVISIBLELINE32", /* 0x00ce */ "EM_SETREADONLY32", /* 0x00cf */ "EM_SETWORDBREAKPROC32", /* 0x00d0 */ "EM_GETWORDBREAKPROC32", /* 0x00d1 */ "EM_GETPASSWORDCHAR32", /* 0x00d2 */ "EM_SETMARGINS32", /* 0x00d3 */ "EM_GETMARGINS32", /* 0x00d4 */ "EM_GETLIMITTEXT32", /* 0x00d5 */ "EM_POSFROMCHAR32", /* 0x00d6 */ "EM_CHARFROMPOS32", /* 0x00d7 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x00E0 - Win32 Scrollbars */ "SBM_SETPOS32", /* 0x00e0 */ "SBM_GETPOS32", /* 0x00e1 */ "SBM_SETRANGE32", /* 0x00e2 */ "SBM_GETRANGE32", /* 0x00e3 */ "SBM_ENABLE_ARROWS32", /* 0x00e4 */ NULL, "SBM_SETRANGEREDRAW32", /* 0x00e6 */ NULL, NULL, "SBM_SETSCROLLINFO32", /* 0x00e9 */ "SBM_GETSCROLLINFO32", /* 0x00ea */ NULL, NULL, NULL, NULL, NULL, /* 0x00F0 - Win32 Buttons */ "BM_GETCHECK32", /* 0x00f0 */ "BM_SETCHECK32", /* 0x00f1 */ "BM_GETSTATE32", /* 0x00f2 */ "BM_SETSTATE32", /* 0x00f3 */ "BM_SETSTYLE32", /* 0x00f4 */ "BM_CLICK32", /* 0x00f5 */ "BM_GETIMAGE32", /* 0x00f6 */ "BM_SETIMAGE32", /* 0x00f7 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_KEYDOWN", /* 0x0100 */ "WM_KEYUP", /* 0x0101 */ "WM_CHAR", /* 0x0102 */ "WM_DEADCHAR", /* 0x0103 */ "WM_SYSKEYDOWN", /* 0x0104 */ "WM_SYSKEYUP", /* 0x0105 */ "WM_SYSCHAR", /* 0x0106 */ "WM_SYSDEADCHAR", /* 0x0107 */ "WM_KEYLAST", /* 0x0108 */ NULL, "WM_CONVERTREQUEST", "WM_CONVERTRESULT", "WM_INTERIM", NULL, NULL, NULL, "WM_INITDIALOG", /* 0x0110 */ "WM_COMMAND", /* 0x0111 */ "WM_SYSCOMMAND", /* 0x0112 */ "WM_TIMER", /* 0x0113 */ "WM_HSCROLL", /* 0x0114 */ "WM_VSCROLL", /* 0x0115 */ "WM_INITMENU", /* 0x0116 */ "WM_INITMENUPOPUP", /* 0x0117 */ "WM_SYSTIMER", /* 0x0118 */ NULL, NULL, NULL, NULL, NULL, NULL, "WM_MENUSELECT", /* 0x011f */ "WM_MENUCHAR", /* 0x0120 */ "WM_ENTERIDLE", /* 0x0121 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0130 */ NULL, "WM_LBTRACKPOINT", /* 0x0131 */ "WM_CTLCOLORMSGBOX", /* 0x0132 */ "WM_CTLCOLOREDIT", /* 0x0133 */ "WM_CTLCOLORLISTBOX", /* 0x0134 */ "WM_CTLCOLORBTN", /* 0x0135 */ "WM_CTLCOLORDLG", /* 0x0136 */ "WM_CTLCOLORSCROLLBAR", /* 0x0137 */ "WM_CTLCOLORSTATIC", /* 0x0138 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0140 - Win32 Comboboxes */ "CB_GETEDITSEL32", /* 0x0140 */ "CB_LIMITTEXT32", /* 0x0141 */ "CB_SETEDITSEL32", /* 0x0142 */ "CB_ADDSTRING32", /* 0x0143 */ "CB_DELETESTRING32", /* 0x0144 */ "CB_DIR32", /* 0x0145 */ "CB_GETCOUNT32", /* 0x0146 */ "CB_GETCURSEL32", /* 0x0147 */ "CB_GETLBTEXT32", /* 0x0148 */ "CB_GETLBTEXTLEN32", /* 0x0149 */ "CB_INSERTSTRING32", /* 0x014a */ "CB_RESETCONTENT32", /* 0x014b */ "CB_FINDSTRING32", /* 0x014c */ "CB_SELECTSTRING32", /* 0x014d */ "CB_SETCURSEL32", /* 0x014e */ "CB_SHOWDROPDOWN32", /* 0x014f */ "CB_GETITEMDATA32", /* 0x0150 */ "CB_SETITEMDATA32", /* 0x0151 */ "CB_GETDROPPEDCONTROLRECT32",/* 0x0152 */ "CB_SETITEMHEIGHT32", /* 0x0153 */ "CB_GETITEMHEIGHT32", /* 0x0154 */ "CB_SETEXTENDEDUI32", /* 0x0155 */ "CB_GETEXTENDEDUI32", /* 0x0156 */ "CB_GETDROPPEDSTATE32", /* 0x0157 */ "CB_FINDSTRINGEXACT32", /* 0x0158 */ "CB_SETLOCALE32", /* 0x0159 */ "CB_GETLOCALE32", /* 0x015a */ "CB_GETTOPINDEX32", /* 0x015b */ "CB_SETTOPINDEX32", /* 0x015c */ "CB_GETHORIZONTALEXTENT32", /* 0x015d */ "CB_SETHORIZONTALEXTENT32", /* 0x015e */ "CB_GETDROPPEDWIDTH32", /* 0x015f */ "CB_SETDROPPEDWIDTH32", /* 0x0160 */ "CB_INITSTORAGE32", /* 0x0161 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0170 - Win32 Static controls */ "STM_SETICON32", /* 0x0170 */ "STM_GETICON32", /* 0x0171 */ "STM_SETIMAGE32", /* 0x0172 */ "STM_GETIMAGE32", /* 0x0173 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0180 - Win32 Listboxes */ "LB_ADDSTRING32", /* 0x0180 */ "LB_INSERTSTRING32", /* 0x0181 */ "LB_DELETESTRING32", /* 0x0182 */ "LB_SELITEMRANGEEX32", /* 0x0183 */ "LB_RESETCONTENT32", /* 0x0184 */ "LB_SETSEL32", /* 0x0185 */ "LB_SETCURSEL32", /* 0x0186 */ "LB_GETSEL32", /* 0x0187 */ "LB_GETCURSEL32", /* 0x0188 */ "LB_GETTEXT32", /* 0x0189 */ "LB_GETTEXTLEN32", /* 0x018a */ "LB_GETCOUNT32", /* 0x018b */ "LB_SELECTSTRING32", /* 0x018c */ "LB_DIR32", /* 0x018d */ "LB_GETTOPINDEX32", /* 0x018e */ "LB_FINDSTRING32", /* 0x018f */ "LB_GETSELCOUNT32", /* 0x0190 */ "LB_GETSELITEMS32", /* 0x0191 */ "LB_SETTABSTOPS32", /* 0x0192 */ "LB_GETHORIZONTALEXTENT32", /* 0x0193 */ "LB_SETHORIZONTALEXTENT32", /* 0x0194 */ "LB_SETCOLUMNWIDTH32", /* 0x0195 */ "LB_ADDFILE32", /* 0x0196 */ "LB_SETTOPINDEX32", /* 0x0197 */ "LB_GETITEMRECT32", /* 0x0198 */ "LB_GETITEMDATA32", /* 0x0199 */ "LB_SETITEMDATA32", /* 0x019a */ "LB_SELITEMRANGE32", /* 0x019b */ "LB_SETANCHORINDEX32", /* 0x019c */ "LB_GETANCHORINDEX32", /* 0x019d */ "LB_SETCARETINDEX32", /* 0x019e */ "LB_GETCARETINDEX32", /* 0x019f */ "LB_SETITEMHEIGHT32", /* 0x01a0 */ "LB_GETITEMHEIGHT32", /* 0x01a1 */ "LB_FINDSTRINGEXACT32", /* 0x01a2 */ "LB_CARETON32", /* 0x01a3 */ "LB_CARETOFF32", /* 0x01a4 */ "LB_SETLOCALE32", /* 0x01a5 */ "LB_GETLOCALE32", /* 0x01a6 */ "LB_SETCOUNT32", /* 0x01a7 */ "LB_INITSTORAGE32", /* 0x01a8 */ "LB_ITEMFROMPOINT32", /* 0x01a9 */ NULL, NULL, NULL, NULL, NULL, NULL, /* 0x01B0 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x01C0 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x01D0 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x01E0 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x01F0 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_MOUSEMOVE", /* 0x0200 */ "WM_LBUTTONDOWN", /* 0x0201 */ "WM_LBUTTONUP", /* 0x0202 */ "WM_LBUTTONDBLCLK", /* 0x0203 */ "WM_RBUTTONDOWN", /* 0x0204 */ "WM_RBUTTONUP", /* 0x0205 */ "WM_RBUTTONDBLCLK", /* 0x0206 */ "WM_MBUTTONDOWN", /* 0x0207 */ "WM_MBUTTONUP", /* 0x0208 */ "WM_MBUTTONDBLCLK", /* 0x0209 */ NULL, NULL, NULL, NULL, NULL, NULL, "WM_PARENTNOTIFY", /* 0x0210 */ "WM_ENTERMENULOOP", /* 0x0211 */ "WM_EXITMENULOOP", /* 0x0212 */ "WM_NEXTMENU", /* 0x0213 */ "WM_SIZING", "WM_CAPTURECHANGED", "WM_MOVING", NULL, "WM_POWERBROADCAST", "WM_DEVICECHANGE", NULL, NULL, NULL, NULL, NULL, NULL, "WM_MDICREATE", /* 0x0220 */ "WM_MDIDESTROY", /* 0x0221 */ "WM_MDIACTIVATE", /* 0x0222 */ "WM_MDIRESTORE", /* 0x0223 */ "WM_MDINEXT", /* 0x0224 */ "WM_MDIMAXIMIZE", /* 0x0225 */ "WM_MDITILE", /* 0x0226 */ "WM_MDICASCADE", /* 0x0227 */ "WM_MDIICONARRANGE", /* 0x0228 */ "WM_MDIGETACTIVE", /* 0x0229 */ "WM_DROPOBJECT", "WM_QUERYDROPOBJECT", "WM_BEGINDRAG", "WM_DRAGLOOP", "WM_DRAGSELECT", "WM_DRAGMOVE", /* 0x0230*/ "WM_MDISETMENU", /* 0x0230 */ "WM_ENTERSIZEMOVE", /* 0x0231 */ "WM_EXITSIZEMOVE", /* 0x0232 */ "WM_DROPFILES", /* 0x0233 */ "WM_MDIREFRESHMENU", NULL, NULL, NULL, /* 0x0238*/ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0240 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0250 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0260 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0280 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x02c0 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_CUT", /* 0x0300 */ "WM_COPY", "WM_PASTE", "WM_CLEAR", "WM_UNDO", "WM_RENDERFORMAT", "WM_RENDERALLFORMATS", "WM_DESTROYCLIPBOARD", "WM_DRAWCLIPBOARD", "WM_PAINTCLIPBOARD", "WM_VSCROLLCLIPBOARD", "WM_SIZECLIPBOARD", "WM_ASKCBFORMATNAME", "WM_CHANGECBCHAIN", "WM_HSCROLLCLIPBOARD", "WM_QUERYNEWPALETTE", /* 0x030f*/ "WM_PALETTEISCHANGING", "WM_PALETTECHANGED", "WM_HOTKEY", /* 0x0312 */ NULL, NULL, NULL, NULL, "WM_PRINT", "WM_PRINTCLIENT", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x0340 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_QUERYAFXWNDPROC", /* 0x0360 */ "WM_SIZEPARENT", /* 0x0361 */ "WM_SETMESSAGESTRING", /* 0x0362 */ "WM_IDLEUPDATECMDUI", /* 0x0363 */ "WM_INITIALUPDATE", /* 0x0364 */ "WM_COMMANDHELP", /* 0x0365 */ "WM_HELPHITTEST", /* 0x0366 */ "WM_EXITHELPMODE", /* 0x0367 */ "WM_RECALCPARENT", /* 0x0368 */ "WM_SIZECHILD", /* 0x0369 */ "WM_KICKIDLE", /* 0x036A */ "WM_QUERYCENTERWND", /* 0x036B */ "WM_DISABLEMODAL", /* 0x036C */ "WM_FLOATSTATUS", /* 0x036D */ "WM_ACTIVATETOPLEVEL", /* 0x036E */ "WM_QUERY3DCONTROLS", /* 0x036F */ NULL,NULL,NULL, "WM_SOCKET_NOTIFY", /* 0x0373 */ "WM_SOCKET_DEAD", /* 0x0374 */ "WM_POPMESSAGESTRING", /* 0x0375 */ "WM_OCC_LOADFROMSTREAM", /* 0x0376 */ "WM_OCC_LOADFROMSTORAGE", /* 0x0377 */ "WM_OCC_INITNEW", /* 0x0378 */ "WM_QUEUE_SENTINEL", /* 0x0379 */ "WM_OCC_LOADFROMSTREAM_EX", /* 0x037A */ "WM_OCC_LOADFROMSTORAGE_EX", /* 0x037B */ NULL,NULL,NULL,NULL, /* 0x0380 */ "WM_PENWINFIRST", "WM_RCRESULT", "WM_HOOKRCRESULT", "WM_GLOBALRCCHANGE", "WM_SKB", "WM_HEDITCTL", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_COALESCE_FIRST", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_COALESCE_LAST", /* 0x03a0 */ "MM_JOY1MOVE", "MM_JOY2MOVE", "MM_JOY1ZMOVE", "MM_JOY2ZMOVE", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x03b0 */ NULL, NULL, NULL, NULL, NULL, "MM_JOY1BUTTONDOWN", "MM_JOY2BUTTONDOWN", "MM_JOY1BUTTONUP", "MM_JOY2BUTTONUP", "MM_MCINOTIFY", NULL, "MM_WOM_OPEN", "MM_WOM_CLOSE", "MM_WOM_DONE", "MM_WIM_OPEN", "MM_WIM_CLOSE", /* 0x03c0 */ "MM_WIM_DATA", "MM_MIM_OPEN", "MM_MIM_CLOSE", "MM_MIM_DATA", "MM_MIM_LONGDATA", "MM_MIM_ERROR", "MM_MIM_LONGERROR", "MM_MOM_OPEN", "MM_MOM_CLOSE", "MM_MOM_DONE", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x03e0 */ "WM_DDE_INITIATE", /* 0x3E0 */ "WM_DDE_TERMINATE", /* 0x3E1 */ "WM_DDE_ADVISE", /* 0x3E2 */ "WM_DDE_UNADVISE", /* 0x3E3 */ "WM_DDE_ACK", /* 0x3E4 */ "WM_DDE_DATA", /* 0x3E5 */ "WM_DDE_REQUEST", /* 0x3E6 */ "WM_DDE_POKE", /* 0x3E7 */ "WM_DDE_EXECUTE", /* 0x3E8 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, /* 0x03f0 */ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "WM_USER" }; #define SPY_MAX_LVMMSGNUM 139 static const char * const LVMMessageTypeNames[SPY_MAX_LVMMSGNUM + 1] = { "LVM_GETBKCOLOR", /* 1000 */ "LVM_SETBKCOLOR", "LVM_GETIMAGELIST", "LVM_SETIMAGELIST", "LVM_GETITEMCOUNT", "LVM_GETITEMA", "LVM_SETITEMA", "LVM_INSERTITEMA", "LVM_DELETEITEM", "LVM_DELETEALLITEMS", "LVM_GETCALLBACKMASK", "LVM_SETCALLBACKMASK", "LVM_GETNEXTITEM", "LVM_FINDITEMA", "LVM_GETITEMRECT", "LVM_SETITEMPOSITION", "LVM_GETITEMPOSITION", "LVM_GETSTRINGWIDTHA", "LVM_HITTEST", "LVM_ENSUREVISIBLE", "LVM_SCROLL", "LVM_REDRAWITEMS", "LVM_ARRANGE", "LVM_EDITLABELA", "LVM_GETEDITCONTROL", "LVM_GETCOLUMNA", "LVM_SETCOLUMNA", "LVM_INSERTCOLUMNA", "LVM_DELETECOLUMN", "LVM_GETCOLUMNWIDTH", "LVM_SETCOLUMNWIDTH", "LVM_GETHEADER", "LVM_CREATEDRAGIMAGE", "LVM_GETVIEWRECT", "LVM_GETTEXTCOLOR", "LVM_SETTEXTCOLOR", "LVM_GETTEXTBKCOLOR", "LVM_SETTEXTBKCOLOR", "LVM_GETTOPINDEX", "LVM_GETCOUNTPERPAGE", "LVM_GETORIGIN", "LVM_UPDATE", "LVM_SETITEMSTATE", "LVM_GETITEMSTATE", "LVM_GETITEMTEXTA", "LVM_SETITEMTEXTA", "LVM_SETITEMCOUNT", "LVM_SORTITEMS", "LVM_SETITEMPOSITION32", "LVM_GETSELECTEDCOUNT", "LVM_GETITEMSPACING", "LVM_GETISEARCHSTRINGA", "LVM_SETICONSPACING", "LVM_SETEXTENDEDLISTVIEWSTYLE", "LVM_GETEXTENDEDLISTVIEWSTYLE", "LVM_GETSUBITEMRECT", "LVM_SUBITEMHITTEST", "LVM_SETCOLUMNORDERARRAY", "LVM_GETCOLUMNORDERARRAY", "LVM_SETHOTITEM", "LVM_GETHOTITEM", "LVM_SETHOTCURSOR", "LVM_GETHOTCURSOR", "LVM_APPROXIMATEVIEWRECT", "LVM_SETWORKAREAS", "LVM_GETSELECTIONMARK", "LVM_SETSELECTIONMARK", "LVM_SETBKIMAGEA", "LVM_GETBKIMAGEA", "LVM_GETWORKAREAS", "LVM_SETHOVERTIME", "LVM_GETHOVERTIME", "LVM_GETNUMBEROFWORKAREAS", "LVM_SETTOOLTIPS", "LVM_GETITEMW", "LVM_SETITEMW", "LVM_INSERTITEMW", "LVM_GETTOOLTIPS", NULL, NULL, NULL, NULL, "LVM_FINDITEMW", NULL, NULL, NULL, "LVM_GETSTRINGWIDTHW", NULL, NULL, NULL, NULL, NULL, NULL, NULL, "LVM_GETCOLUMNW", "LVM_SETCOLUMNW", "LVM_INSERTCOLUMNW", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "LVM_GETITEMTEXTW", "LVM_SETITEMTEXTW", "LVM_GETISEARCHSTRINGW", "LVM_EDITLABELW", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "LVM_SETBKIMAGEW", "LVM_GETBKIMAGEW" /* 0x108B */ }; #define SPY_MAX_CCMMSGNUM 6 static const char * const CCMMessageTypeNames[SPY_MAX_CCMMSGNUM + 1] = { NULL, /* 0x2000 */ "CCM_SETBKCOLOR", "CCM_SETCOLORSCHEME", "CCM_GETCOLORSCHEME", "CCM_GETDROPTARGET", "CCM_SETUNICODEFORMAT", "CCM_GETUNICODEFORMAT" }; static BOOL16 SPY_Exclude[SPY_MAX_MSGNUM+1]; static BOOL16 SPY_ExcludeDWP = 0; static int SPY_IndentLevel = 0; #define SPY_EXCLUDE(msg) \ (SPY_Exclude[(msg) > SPY_MAX_MSGNUM ? SPY_MAX_MSGNUM : (msg)]) /*********************************************************************** * SPY_GetMsgName */ const char *SPY_GetMsgName( UINT msg ) { static char msg_buffer[20]; if (msg <= SPY_MAX_MSGNUM) { if (!MessageTypeNames[msg]) return "???"; return MessageTypeNames[msg]; } if (msg >= LVM_FIRST && msg <= LVM_FIRST + SPY_MAX_LVMMSGNUM) { if (!LVMMessageTypeNames[msg-LVM_FIRST]) return "LVM_?"; return LVMMessageTypeNames[msg-LVM_FIRST]; } if (msg >= CCM_FIRST && msg <= CCM_FIRST + SPY_MAX_CCMMSGNUM) { if (!CCMMessageTypeNames[msg-CCM_FIRST]) return "???"; return CCMMessageTypeNames[msg-CCM_FIRST]; } sprintf( msg_buffer, "WM_USER+%04x", msg - WM_USER ); return msg_buffer; } /*********************************************************************** * SPY_GetWndName */ const char *SPY_GetWndName( HWND hwnd ) { static char wnd_buffer[16]; WND* pWnd = WIN_FindWndPtr( hwnd ); if( pWnd ) { INT n = sizeof(wnd_buffer) - 6; LPSTR p = wnd_buffer; LPSTR src; char postfix; if( pWnd->text && pWnd->text[0] != '\0' ) { src = pWnd->text; *(p++) = postfix = '\"'; while ((n-- > 1) && *src) *p++ = *src++; } else /* get class name */ { INT len; *(p++)='{'; GlobalGetAtomNameA((ATOM) GetClassWord(pWnd->hwndSelf, GCW_ATOM), p, n + 1); src = p += (len = lstrlenA(p)); if( len >= n ) src = wnd_buffer; /* something nonzero */ postfix = '}'; } if( *src ) for( n = 0; n < 3; n++ ) *(p++)='.'; *(p++) = postfix; *(p++) = '\0'; WIN_ReleaseWndPtr(pWnd); } else lstrcpyA( wnd_buffer, "\"NULL\"" ); return wnd_buffer; } /*********************************************************************** * SPY_DumpStructure */ void SPY_DumpStructure (UINT msg, LPARAM structure) { switch (msg) { case WM_DRAWITEM: { DRAWITEMSTRUCT *lpdis = (DRAWITEMSTRUCT*) structure; TRACE("DRAWITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n", lpdis->CtlType, lpdis->CtlID); TRACE("itemID=0x%08x itemAction=0x%08x itemState=0x%08x\n", lpdis->itemID, lpdis->itemAction, lpdis->itemState); TRACE("hWnd=0x%04x hDC=0x%04x (%d,%d)-(%d,%d) itemData=0x%08lx\n", lpdis->hwndItem, lpdis->hDC, lpdis->rcItem.left, lpdis->rcItem.top, lpdis->rcItem.right, lpdis->rcItem.bottom, lpdis->itemData); } break; case WM_MEASUREITEM: { MEASUREITEMSTRUCT *lpmis = (MEASUREITEMSTRUCT*) structure; TRACE("MEASUREITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n", lpmis->CtlType, lpmis->CtlID); TRACE("itemID=0x%08x itemWidth=0x%08x itemHeight=0x%08x\n", lpmis->itemID, lpmis->itemWidth, lpmis->itemHeight); TRACE("itemData=0x%08lx\n", lpmis->itemData); } break; case WM_NOTIFY: { NMHDR * pnmh = (NMHDR*) structure; TRACE("NMHDR hwndFrom=0x%08x idFrom=0x%08x code=0x%08x\n", pnmh->hwndFrom, pnmh->idFrom, pnmh->code); } default: break; } } /*********************************************************************** * SPY_EnterMessage */ void SPY_EnterMessage( INT iFlag, HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam ) { LPCSTR pname; if (!TRACE_ON(message) || SPY_EXCLUDE(msg)) return; /* each SPY_SENDMESSAGE must be complemented by call to SPY_ExitMessage */ switch(iFlag) { case SPY_DISPATCHMESSAGE16: pname = SPY_GetWndName(hWnd); TRACE("%*s(%04x) %-16s message [%04x] %s dispatched wp=%04x lp=%08lx\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ), wParam, lParam); break; case SPY_DISPATCHMESSAGE: pname = SPY_GetWndName(hWnd); TRACE("%*s(%08x) %-16s message [%04x] %s dispatched wp=%08x lp=%08lx\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ), wParam, lParam); break; case SPY_SENDMESSAGE16: case SPY_SENDMESSAGE: { char taskName[30]; HTASK16 hTask = GetWindowTask16(hWnd); if (hTask == GetCurrentTask()) strcpy( taskName, "self" ); else if (!hTask) strcpy( taskName, "Wine" ); else { sprintf( taskName, "task %04x ???", hTask ); GetModuleName16( hTask, taskName + 10, sizeof(taskName) - 10 ); } pname = SPY_GetWndName(hWnd); if (iFlag == SPY_SENDMESSAGE16) TRACE("%*s(%04x) %-16s message [%04x] %s sent from %s wp=%04x lp=%08lx\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ), taskName, wParam, lParam ); else { TRACE("%*s(%08x) %-16s message [%04x] %s sent from %s wp=%08x lp=%08lx\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ), taskName, wParam, lParam ); SPY_DumpStructure(msg, lParam); } } break; case SPY_DEFWNDPROC16: if( SPY_ExcludeDWP ) return; TRACE("%*s(%04x) DefWindowProc16: %s [%04x] wp=%04x lp=%08lx\n", SPY_IndentLevel, "", hWnd, SPY_GetMsgName( msg ), msg, wParam, lParam ); break; case SPY_DEFWNDPROC: if( SPY_ExcludeDWP ) return; TRACE("%*s(%08x) DefWindowProc32: %s [%04x] wp=%08x lp=%08lx\n", SPY_IndentLevel, "", hWnd, SPY_GetMsgName( msg ), msg, wParam, lParam ); break; } SPY_IndentLevel += SPY_INDENT_UNIT; } /*********************************************************************** * SPY_ExitMessage */ void SPY_ExitMessage( INT iFlag, HWND hWnd, UINT msg, LRESULT lReturn ) { LPCSTR pname; if (!TRACE_ON(message) || SPY_EXCLUDE(msg) || (SPY_ExcludeDWP && (iFlag == SPY_RESULT_DEFWND16 || iFlag == SPY_RESULT_DEFWND)) ) return; if (SPY_IndentLevel) SPY_IndentLevel -= SPY_INDENT_UNIT; switch(iFlag) { case SPY_RESULT_DEFWND16: TRACE(" %*s(%04x) DefWindowProc16: %s [%04x] returned %08lx\n", SPY_IndentLevel, "", hWnd, SPY_GetMsgName( msg ), msg, lReturn ); break; case SPY_RESULT_DEFWND: TRACE(" %*s(%08x) DefWindowProc32: %s [%04x] returned %08lx\n", SPY_IndentLevel, "", hWnd, SPY_GetMsgName( msg ), msg, lReturn ); break; case SPY_RESULT_OK16: pname = SPY_GetWndName(hWnd); TRACE(" %*s(%04x) %-16s message [%04x] %s returned %08lx\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ), lReturn ); break; case SPY_RESULT_OK: pname = SPY_GetWndName(hWnd); TRACE(" %*s(%08x) %-16s message [%04x] %s returned %08lx\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ), lReturn ); break; case SPY_RESULT_INVALIDHWND16: pname = SPY_GetWndName(hWnd); WARN(" %*s(%04x) %-16s message [%04x] %s HAS INVALID HWND\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ) ); break; case SPY_RESULT_INVALIDHWND: pname = SPY_GetWndName(hWnd); WARN(" %*s(%08x) %-16s message [%04x] %s HAS INVALID HWND\n", SPY_IndentLevel, "", hWnd, pname, msg, SPY_GetMsgName( msg ) ); break; } } /*********************************************************************** * SPY_Init */ int SPY_Init(void) { int i; char buffer[1024]; if (!TRACE_ON(message)) return TRUE; PROFILE_GetWineIniString( "Spy", "Include", "", buffer, sizeof(buffer) ); if (buffer[0] && strcmp( buffer, "INCLUDEALL" )) { TRACE("Include=%s\n", buffer ); for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = (MessageTypeNames[i] && !strstr(buffer,MessageTypeNames[i])); } PROFILE_GetWineIniString( "Spy", "Exclude", "", buffer, sizeof(buffer) ); if (buffer[0]) { TRACE("Exclude=%s\n", buffer ); if (!strcmp( buffer, "EXCLUDEALL" )) for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = TRUE; else for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = (MessageTypeNames[i] && strstr(buffer,MessageTypeNames[i])); } SPY_ExcludeDWP = PROFILE_GetWineIniInt( "Spy", "ExcludeDWP", 0 ); return 1; }