2 * Message spying routines
4 * Copyright 1994, Bob Amstadt
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
28 #include "wine/winuser16.h"
29 #include "wine/winbase16.h"
30 #include "wine/unicode.h"
32 #include "wine/debug.h"
36 WINE_DEFAULT_DEBUG_CHANNEL(message);
38 #define SPY_MAX_MSGNUM WM_USER
39 #define SPY_INDENT_UNIT 4 /* 4 spaces */
41 static const char * const MessageTypeNames[SPY_MAX_MSGNUM + 1] =
59 "WM_CLOSE", /* 0x10 */
75 "WM_SETCURSOR", /* 0x20 */
91 "WM_SETFONT", /* 0x30 */
103 "wm_otherwindowcreated",
104 "wm_otherwindowdestroyed",
105 "wm_activateshellwindow",
109 "wm_compacting", NULL, NULL,
110 "WM_COMMNOTIFY", NULL,
111 "WM_WINDOWPOSCHANGING", /* 0x0046 */
112 "WM_WINDOWPOSCHANGED", /* 0x0047 */
115 "WM_CANCELJOURNAL", NULL, NULL,
119 "WM_INPUTLANGCHANGEREQUEST",
120 "WM_INPUTLANGCHANGE",
124 "WM_NOTIFYFORMAT", NULL, NULL,
125 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
128 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
129 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
132 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
140 "WM_SETICON", /* 0x0080 */
141 "WM_NCCREATE", /* 0x0081 */
142 "WM_NCDESTROY", /* 0x0082 */
143 "WM_NCCALCSIZE", /* 0x0083 */
144 "WM_NCHITTEST", /* 0x0084 */
145 "WM_NCPAINT", /* 0x0085 */
146 "WM_NCACTIVATE", /* 0x0086 */
147 "WM_GETDLGCODE", /* 0x0087 */
149 "WM_SYNCTASK", NULL, NULL, NULL, NULL, NULL, NULL,
152 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
153 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
156 "WM_NCMOUSEMOVE", /* 0x00A0 */
157 "WM_NCLBUTTONDOWN", /* 0x00A1 */
158 "WM_NCLBUTTONUP", /* 0x00A2 */
159 "WM_NCLBUTTONDBLCLK", /* 0x00A3 */
160 "WM_NCRBUTTONDOWN", /* 0x00A4 */
161 "WM_NCRBUTTONUP", /* 0x00A5 */
162 "WM_NCRBUTTONDBLCLK", /* 0x00A6 */
163 "WM_NCMBUTTONDOWN", /* 0x00A7 */
164 "WM_NCMBUTTONUP", /* 0x00A8 */
165 "WM_NCMBUTTONDBLCLK", /* 0x00A9 */
166 NULL, NULL, NULL, NULL, NULL, NULL,
168 /* 0x00B0 - Win32 Edit controls */
169 "EM_GETSEL", /* 0x00b0 */
170 "EM_SETSEL", /* 0x00b1 */
171 "EM_GETRECT", /* 0x00b2 */
172 "EM_SETRECT", /* 0x00b3 */
173 "EM_SETRECTNP", /* 0x00b4 */
174 "EM_SCROLL", /* 0x00b5 */
175 "EM_LINESCROLL", /* 0x00b6 */
176 "EM_SCROLLCARET", /* 0x00b7 */
177 "EM_GETMODIFY", /* 0x00b8 */
178 "EM_SETMODIFY", /* 0x00b9 */
179 "EM_GETLINECOUNT", /* 0x00ba */
180 "EM_LINEINDEX", /* 0x00bb */
181 "EM_SETHANDLE", /* 0x00bc */
182 "EM_GETHANDLE", /* 0x00bd */
183 "EM_GETTHUMB", /* 0x00be */
187 "EM_LINELENGTH", /* 0x00c1 */
188 "EM_REPLACESEL", /* 0x00c2 */
190 "EM_GETLINE", /* 0x00c4 */
191 "EM_LIMITTEXT", /* 0x00c5 */
192 "EM_CANUNDO", /* 0x00c6 */
193 "EM_UNDO", /* 0x00c7 */
194 "EM_FMTLINES", /* 0x00c8 */
195 "EM_LINEFROMCHAR", /* 0x00c9 */
197 "EM_SETTABSTOPS", /* 0x00cb */
198 "EM_SETPASSWORDCHAR", /* 0x00cc */
199 "EM_EMPTYUNDOBUFFER", /* 0x00cd */
200 "EM_GETFIRSTVISIBLELINE", /* 0x00ce */
201 "EM_SETREADONLY", /* 0x00cf */
203 "EM_SETWORDBREAKPROC", /* 0x00d0 */
204 "EM_GETWORDBREAKPROC", /* 0x00d1 */
205 "EM_GETPASSWORDCHAR", /* 0x00d2 */
206 "EM_SETMARGINS", /* 0x00d3 */
207 "EM_GETMARGINS", /* 0x00d4 */
208 "EM_GETLIMITTEXT", /* 0x00d5 */
209 "EM_POSFROMCHAR", /* 0x00d6 */
210 "EM_CHARFROMPOS", /* 0x00d7 */
211 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
213 /* 0x00E0 - Win32 Scrollbars */
214 "SBM_SETPOS", /* 0x00e0 */
215 "SBM_GETPOS", /* 0x00e1 */
216 "SBM_SETRANGE", /* 0x00e2 */
217 "SBM_GETRANGE", /* 0x00e3 */
218 "SBM_ENABLE_ARROWS", /* 0x00e4 */
220 "SBM_SETRANGEREDRAW", /* 0x00e6 */
222 "SBM_SETSCROLLINFO", /* 0x00e9 */
223 "SBM_GETSCROLLINFO", /* 0x00ea */
224 NULL, NULL, NULL, NULL, NULL,
226 /* 0x00F0 - Win32 Buttons */
227 "BM_GETCHECK", /* 0x00f0 */
228 "BM_SETCHECK", /* 0x00f1 */
229 "BM_GETSTATE", /* 0x00f2 */
230 "BM_SETSTATE", /* 0x00f3 */
231 "BM_SETSTYLE", /* 0x00f4 */
232 "BM_CLICK", /* 0x00f5 */
233 "BM_GETIMAGE", /* 0x00f6 */
234 "BM_SETIMAGE", /* 0x00f7 */
235 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
237 "WM_KEYDOWN", /* 0x0100 */
238 "WM_KEYUP", /* 0x0101 */
239 "WM_CHAR", /* 0x0102 */
240 "WM_DEADCHAR", /* 0x0103 */
241 "WM_SYSKEYDOWN", /* 0x0104 */
242 "WM_SYSKEYUP", /* 0x0105 */
243 "WM_SYSCHAR", /* 0x0106 */
244 "WM_SYSDEADCHAR", /* 0x0107 */
245 "WM_KEYLAST", /* 0x0108 */
250 "WM_IME_STARTCOMPOSITION", /* 0x010d */
251 "WM_IME_ENDCOMPOSITION", /* 0x010e */
252 "WM_IME_COMPOSITION", /* 0x010f */
254 "WM_INITDIALOG", /* 0x0110 */
255 "WM_COMMAND", /* 0x0111 */
256 "WM_SYSCOMMAND", /* 0x0112 */
257 "WM_TIMER", /* 0x0113 */
258 "WM_HSCROLL", /* 0x0114 */
259 "WM_VSCROLL", /* 0x0115 */
260 "WM_INITMENU", /* 0x0116 */
261 "WM_INITMENUPOPUP", /* 0x0117 */
262 "WM_SYSTIMER", /* 0x0118 */
263 NULL, NULL, NULL, NULL, NULL, NULL,
264 "WM_MENUSELECT", /* 0x011f */
266 "WM_MENUCHAR", /* 0x0120 */
267 "WM_ENTERIDLE", /* 0x0121 */
269 "WM_MENURBUTTONUP", /* 0x0122 */
270 "WM_MENUDRAG", /* 0x0123 */
271 "WM_MENUGETOBJECT", /* 0x0124 */
272 "WM_UNINITMENUPOPUP", /* 0x0125 */
273 "WM_MENUCOMMAND", /* 0x0126 */
274 "WM_CHANGEUISTATE", /* 0x0127 */
275 "WM_UPDATEUISTATE", /* 0x0128 */
276 "WM_QUERYUISTATE", /* 0x0129 */
278 NULL, NULL, NULL, NULL, NULL, NULL,
282 "WM_LBTRACKPOINT", /* 0x0131 */
283 "WM_CTLCOLORMSGBOX", /* 0x0132 */
284 "WM_CTLCOLOREDIT", /* 0x0133 */
285 "WM_CTLCOLORLISTBOX", /* 0x0134 */
286 "WM_CTLCOLORBTN", /* 0x0135 */
287 "WM_CTLCOLORDLG", /* 0x0136 */
288 "WM_CTLCOLORSCROLLBAR", /* 0x0137 */
289 "WM_CTLCOLORSTATIC", /* 0x0138 */
290 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
292 /* 0x0140 - Win32 Comboboxes */
293 "CB_GETEDITSEL", /* 0x0140 */
294 "CB_LIMITTEXT", /* 0x0141 */
295 "CB_SETEDITSEL", /* 0x0142 */
296 "CB_ADDSTRING", /* 0x0143 */
297 "CB_DELETESTRING", /* 0x0144 */
298 "CB_DIR", /* 0x0145 */
299 "CB_GETCOUNT", /* 0x0146 */
300 "CB_GETCURSEL", /* 0x0147 */
301 "CB_GETLBTEXT", /* 0x0148 */
302 "CB_GETLBTEXTLEN", /* 0x0149 */
303 "CB_INSERTSTRING", /* 0x014a */
304 "CB_RESETCONTENT", /* 0x014b */
305 "CB_FINDSTRING", /* 0x014c */
306 "CB_SELECTSTRING", /* 0x014d */
307 "CB_SETCURSEL", /* 0x014e */
308 "CB_SHOWDROPDOWN", /* 0x014f */
310 "CB_GETITEMDATA", /* 0x0150 */
311 "CB_SETITEMDATA", /* 0x0151 */
312 "CB_GETDROPPEDCONTROLRECT", /* 0x0152 */
313 "CB_SETITEMHEIGHT", /* 0x0153 */
314 "CB_GETITEMHEIGHT", /* 0x0154 */
315 "CB_SETEXTENDEDUI", /* 0x0155 */
316 "CB_GETEXTENDEDUI", /* 0x0156 */
317 "CB_GETDROPPEDSTATE", /* 0x0157 */
318 "CB_FINDSTRINGEXACT", /* 0x0158 */
319 "CB_SETLOCALE", /* 0x0159 */
320 "CB_GETLOCALE", /* 0x015a */
321 "CB_GETTOPINDEX", /* 0x015b */
322 "CB_SETTOPINDEX", /* 0x015c */
323 "CB_GETHORIZONTALEXTENT", /* 0x015d */
324 "CB_SETHORIZONTALEXTENT", /* 0x015e */
325 "CB_GETDROPPEDWIDTH", /* 0x015f */
327 "CB_SETDROPPEDWIDTH", /* 0x0160 */
328 "CB_INITSTORAGE", /* 0x0161 */
329 NULL, NULL, NULL, NULL, NULL, NULL,
330 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
332 /* 0x0170 - Win32 Static controls */
333 "STM_SETICON", /* 0x0170 */
334 "STM_GETICON", /* 0x0171 */
335 "STM_SETIMAGE", /* 0x0172 */
336 "STM_GETIMAGE", /* 0x0173 */
337 NULL, NULL, NULL, NULL,
338 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
340 /* 0x0180 - Win32 Listboxes */
341 "LB_ADDSTRING", /* 0x0180 */
342 "LB_INSERTSTRING", /* 0x0181 */
343 "LB_DELETESTRING", /* 0x0182 */
344 "LB_SELITEMRANGEEX", /* 0x0183 */
345 "LB_RESETCONTENT", /* 0x0184 */
346 "LB_SETSEL", /* 0x0185 */
347 "LB_SETCURSEL", /* 0x0186 */
348 "LB_GETSEL", /* 0x0187 */
349 "LB_GETCURSEL", /* 0x0188 */
350 "LB_GETTEXT", /* 0x0189 */
351 "LB_GETTEXTLEN", /* 0x018a */
352 "LB_GETCOUNT", /* 0x018b */
353 "LB_SELECTSTRING", /* 0x018c */
354 "LB_DIR", /* 0x018d */
355 "LB_GETTOPINDEX", /* 0x018e */
356 "LB_FINDSTRING", /* 0x018f */
358 "LB_GETSELCOUNT", /* 0x0190 */
359 "LB_GETSELITEMS", /* 0x0191 */
360 "LB_SETTABSTOPS", /* 0x0192 */
361 "LB_GETHORIZONTALEXTENT", /* 0x0193 */
362 "LB_SETHORIZONTALEXTENT", /* 0x0194 */
363 "LB_SETCOLUMNWIDTH", /* 0x0195 */
364 "LB_ADDFILE", /* 0x0196 */
365 "LB_SETTOPINDEX", /* 0x0197 */
366 "LB_GETITEMRECT", /* 0x0198 */
367 "LB_GETITEMDATA", /* 0x0199 */
368 "LB_SETITEMDATA", /* 0x019a */
369 "LB_SELITEMRANGE", /* 0x019b */
370 "LB_SETANCHORINDEX", /* 0x019c */
371 "LB_GETANCHORINDEX", /* 0x019d */
372 "LB_SETCARETINDEX", /* 0x019e */
373 "LB_GETCARETINDEX", /* 0x019f */
375 "LB_SETITEMHEIGHT", /* 0x01a0 */
376 "LB_GETITEMHEIGHT", /* 0x01a1 */
377 "LB_FINDSTRINGEXACT", /* 0x01a2 */
378 "LB_CARETON", /* 0x01a3 */
379 "LB_CARETOFF", /* 0x01a4 */
380 "LB_SETLOCALE", /* 0x01a5 */
381 "LB_GETLOCALE", /* 0x01a6 */
382 "LB_SETCOUNT", /* 0x01a7 */
383 "LB_INITSTORAGE", /* 0x01a8 */
384 "LB_ITEMFROMPOINT", /* 0x01a9 */
385 NULL, NULL, NULL, NULL, NULL, NULL,
388 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
389 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
392 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
393 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
396 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
397 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
400 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
401 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
404 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
405 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
407 "WM_MOUSEMOVE", /* 0x0200 */
408 "WM_LBUTTONDOWN", /* 0x0201 */
409 "WM_LBUTTONUP", /* 0x0202 */
410 "WM_LBUTTONDBLCLK", /* 0x0203 */
411 "WM_RBUTTONDOWN", /* 0x0204 */
412 "WM_RBUTTONUP", /* 0x0205 */
413 "WM_RBUTTONDBLCLK", /* 0x0206 */
414 "WM_MBUTTONDOWN", /* 0x0207 */
415 "WM_MBUTTONUP", /* 0x0208 */
416 "WM_MBUTTONDBLCLK", /* 0x0209 */
417 "WM_MOUSEWHEEL", /* 0x020A */
418 NULL, NULL, NULL, NULL, NULL,
420 "WM_PARENTNOTIFY", /* 0x0210 */
421 "WM_ENTERMENULOOP", /* 0x0211 */
422 "WM_EXITMENULOOP", /* 0x0212 */
423 "WM_NEXTMENU", /* 0x0213 */
428 "WM_DEVICECHANGE", NULL, NULL, NULL, NULL, NULL, NULL,
430 "WM_MDICREATE", /* 0x0220 */
431 "WM_MDIDESTROY", /* 0x0221 */
432 "WM_MDIACTIVATE", /* 0x0222 */
433 "WM_MDIRESTORE", /* 0x0223 */
434 "WM_MDINEXT", /* 0x0224 */
435 "WM_MDIMAXIMIZE", /* 0x0225 */
436 "WM_MDITILE", /* 0x0226 */
437 "WM_MDICASCADE", /* 0x0227 */
438 "WM_MDIICONARRANGE", /* 0x0228 */
439 "WM_MDIGETACTIVE", /* 0x0229 */
442 "WM_QUERYDROPOBJECT",
449 "WM_MDISETMENU", /* 0x0230 */
450 "WM_ENTERSIZEMOVE", /* 0x0231 */
451 "WM_EXITSIZEMOVE", /* 0x0232 */
452 "WM_DROPFILES", /* 0x0233 */
453 "WM_MDIREFRESHMENU", NULL, NULL, NULL,
455 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
458 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
459 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
462 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
463 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
466 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
467 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
468 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
469 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
472 NULL, "WM_IME_SETCONTEXT", "WM_IME_NOTIFY", "WM_IME_CONTROL", "WM_IME_COMPOSITIONFULL", "WM_IME_SELECT", "WM_IME_CHAR", NULL,
473 "WM_IME_REQUEST", NULL, NULL, NULL, NULL, NULL, NULL, NULL,
474 "WM_IME_KEYDOWN", "WM_IME_KEYUP", NULL, NULL, NULL, NULL, NULL, NULL,
475 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
478 NULL, "WM_MOUSEHOVER", NULL, "WM_MOUSELEAVE", NULL, NULL, NULL, NULL,
479 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
480 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
481 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
484 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
485 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
486 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
487 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
489 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
490 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
491 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
492 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
494 "WM_CUT", /* 0x0300 */
500 "WM_RENDERALLFORMATS",
501 "WM_DESTROYCLIPBOARD",
504 "WM_VSCROLLCLIPBOARD",
506 "WM_ASKCBFORMATNAME",
508 "WM_HSCROLLCLIPBOARD",
509 "WM_QUERYNEWPALETTE", /* 0x030f*/
511 "WM_PALETTEISCHANGING",
513 "WM_HOTKEY", /* 0x0312 */
514 NULL, NULL, NULL, NULL,
517 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
519 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
520 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
521 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
522 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
525 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
526 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
527 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
528 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
530 "WM_QUERYAFXWNDPROC", /* 0x0360 */
531 "WM_SIZEPARENT", /* 0x0361 */
532 "WM_SETMESSAGESTRING", /* 0x0362 */
533 "WM_IDLEUPDATECMDUI", /* 0x0363 */
534 "WM_INITIALUPDATE", /* 0x0364 */
535 "WM_COMMANDHELP", /* 0x0365 */
536 "WM_HELPHITTEST", /* 0x0366 */
537 "WM_EXITHELPMODE", /* 0x0367 */
538 "WM_RECALCPARENT", /* 0x0368 */
539 "WM_SIZECHILD", /* 0x0369 */
540 "WM_KICKIDLE", /* 0x036A */
541 "WM_QUERYCENTERWND", /* 0x036B */
542 "WM_DISABLEMODAL", /* 0x036C */
543 "WM_FLOATSTATUS", /* 0x036D */
544 "WM_ACTIVATETOPLEVEL", /* 0x036E */
545 "WM_QUERY3DCONTROLS", /* 0x036F */
547 "WM_SOCKET_NOTIFY", /* 0x0373 */
548 "WM_SOCKET_DEAD", /* 0x0374 */
549 "WM_POPMESSAGESTRING", /* 0x0375 */
550 "WM_OCC_LOADFROMSTREAM", /* 0x0376 */
551 "WM_OCC_LOADFROMSTORAGE", /* 0x0377 */
552 "WM_OCC_INITNEW", /* 0x0378 */
553 "WM_QUEUE_SENTINEL", /* 0x0379 */
554 "WM_OCC_LOADFROMSTREAM_EX", /* 0x037A */
555 "WM_OCC_LOADFROMSTORAGE_EX", /* 0x037B */
559 "WM_PENWINFIRST", /* 0x0380 */
560 "WM_RCRESULT", /* 0x0381 */
561 "WM_HOOKRCRESULT", /* 0x0382 */
562 "WM_GLOBALRCCHANGE", /* 0x0383 */
563 "WM_SKB", /* 0x0384 */
564 "WM_HEDITCTL", /* 0x0385 */
566 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
567 "WM_PENWINLAST", /* 0x038F */
569 "WM_COALESCE_FIRST", /* 0x0390 */
570 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
571 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
572 "WM_COALESCE_LAST", /* 0x039F */
579 NULL, NULL, NULL, NULL,
580 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
583 NULL, NULL, NULL, NULL, NULL,
607 NULL, NULL, NULL, NULL, NULL, NULL,
608 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
609 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
612 "WM_DDE_INITIATE", /* 0x3E0 */
613 "WM_DDE_TERMINATE", /* 0x3E1 */
614 "WM_DDE_ADVISE", /* 0x3E2 */
615 "WM_DDE_UNADVISE", /* 0x3E3 */
616 "WM_DDE_ACK", /* 0x3E4 */
617 "WM_DDE_DATA", /* 0x3E5 */
618 "WM_DDE_REQUEST", /* 0x3E6 */
619 "WM_DDE_POKE", /* 0x3E7 */
620 "WM_DDE_EXECUTE", /* 0x3E8 */
621 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
625 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
626 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
628 "WM_USER" /* 0x0400 */
632 #define SPY_MAX_LVMMSGNUM 140
633 static const char * const LVMMessageTypeNames[SPY_MAX_LVMMSGNUM + 1] =
635 "LVM_GETBKCOLOR", /* 1000 */
644 "LVM_DELETEALLITEMS",
645 "LVM_GETCALLBACKMASK",
646 "LVM_SETCALLBACKMASK",
650 "LVM_SETITEMPOSITION",
651 "LVM_GETITEMPOSITION",
652 "LVM_GETSTRINGWIDTHA",
659 "LVM_GETEDITCONTROL",
664 "LVM_GETCOLUMNWIDTH",
665 "LVM_SETCOLUMNWIDTH",
668 "LVM_CREATEDRAGIMAGE",
672 "LVM_GETTEXTBKCOLOR",
673 "LVM_SETTEXTBKCOLOR",
675 "LVM_GETCOUNTPERPAGE",
684 "LVM_SETITEMPOSITION32",
685 "LVM_GETSELECTEDCOUNT",
686 "LVM_GETITEMSPACING",
687 "LVM_GETISEARCHSTRINGA",
688 "LVM_SETICONSPACING",
689 "LVM_SETEXTENDEDLISTVIEWSTYLE",
690 "LVM_GETEXTENDEDLISTVIEWSTYLE",
691 "LVM_GETSUBITEMRECT",
692 "LVM_SUBITEMHITTEST",
693 "LVM_SETCOLUMNORDERARRAY",
694 "LVM_GETCOLUMNORDERARRAY",
699 "LVM_APPROXIMATEVIEWRECT",
701 "LVM_GETSELECTIONMARK",
702 "LVM_SETSELECTIONMARK",
708 "LVM_GETNUMBEROFWORKAREAS",
722 "LVM_GETSTRINGWIDTHW",
752 "LVM_GETISEARCHSTRINGW",
775 "LVM_GETBKIMAGEW" /* 0x108B */
779 #define SPY_MAX_TVMSGNUM 65
780 static const char * const TVMessageTypeNames[SPY_MAX_TVMSGNUM + 1] =
782 "TVM_INSERTITEMA", /* 1100 */
797 "TVM_GETEDITCONTROL",
798 "TVM_GETVISIBLECOUNT",
800 "TVM_CREATEDRAGIMAGE",
803 "TVM_SORTCHILDRENCB",
804 "TVM_ENDEDITLABELNOW",
805 "TVM_GETISEARCHSTRINGA",
819 "TVM_SETINSERTMARKCOLOR",
820 "TVM_GETINSERTMARKCOLOR",
846 "TVM_GETISEARCHSTRINGW",
851 #define SPY_MAX_HDMMSGNUM 19
852 static const char * const HDMMessageTypeNames[SPY_MAX_HDMMSGNUM + 1] =
854 "HDM_GETITEMCOUNT", /* 1200 */
870 "HDM_CREATEDRAGIMAGE",
871 "GETORDERARRAYINDEX",
872 "SETORDERARRAYINDEX",
877 #define SPY_MAX_TCMMSGNUM 62
878 static const char * const TCMMessageTypeNames[SPY_MAX_TCMMSGNUM + 1] =
889 "TCM_DELETEALLITEMS",
929 "TCM_SETMINTABWIDTH",
932 "TCM_SETEXTENDEDSTYLE",
933 "TCM_GETEXTENDEDSTYLE",
945 #define SPY_MAX_PGMMSGNUM 13
946 static const char * const PGMMessageTypeNames[SPY_MAX_PGMMSGNUM + 1] =
960 "PGM_GETBUTTONSTATE",
965 #define SPY_MAX_CCMMSGNUM 9
966 static const char * const CCMMessageTypeNames[SPY_MAX_CCMMSGNUM + 1] =
970 "CCM_SETCOLORSCHEME",
971 "CCM_GETCOLORSCHEME",
973 "CCM_SETUNICODEFORMAT",
974 "CCM_GETUNICODEFORMAT",
977 "CCM_SETNOTIFYWINDOW"
980 #define SPY_MAX_WINEMSGNUM 6
981 static const char * const WINEMessageTypeNames[SPY_MAX_WINEMSGNUM + 1] =
983 "WM_WINE_DESTROYWINDOW",
984 "WM_WINE_SETWINDOWPOS",
985 "WM_WINE_SHOWWINDOW",
987 "WM_WINE_SETWINDOWLONG",
988 "WM_WINE_ENABLEWINDOW"
991 /* Virtual key names */
992 #define SPY_MAX_VKKEYSNUM 255
993 static const char * const VK_KeyNames[SPY_MAX_VKKEYSNUM + 1] =
996 "VK_LBUTTON", /* 0x01 */
997 "VK_RBUTTON", /* 0x02 */
998 "VK_CANCEL", /* 0x03 */
999 "VK_MBUTTON", /* 0x04 */
1003 "VK_BACK", /* 0x08 */
1004 "VK_TAB", /* 0x09 */
1007 "VK_CLEAR", /* 0x0C */
1008 "VK_RETURN", /* 0x0D */
1011 "VK_SHIFT", /* 0x10 */
1012 "VK_CONTROL", /* 0x11 */
1013 "VK_MENU", /* 0x12 */
1014 "VK_PAUSE", /* 0x13 */
1015 "VK_CAPITAL", /* 0x14 */
1022 "VK_ESCAPE", /* 0x1B */
1027 "VK_SPACE", /* 0x20 */
1028 "VK_PRIOR", /* 0x21 */
1029 "VK_NEXT", /* 0x22 */
1030 "VK_END", /* 0x23 */
1031 "VK_HOME", /* 0x24 */
1032 "VK_LEFT", /* 0x25 */
1034 "VK_RIGHT", /* 0x27 */
1035 "VK_DOWN", /* 0x28 */
1036 "VK_SELECT", /* 0x29 */
1037 "VK_PRINT", /* 0x2A */
1038 "VK_EXECUTE", /* 0x2B */
1039 "VK_SNAPSHOT", /* 0x2C */
1040 "VK_INSERT", /* 0x2D */
1041 "VK_DELETE", /* 0x2E */
1042 "VK_HELP", /* 0x2F */
1086 "VK_LWIN", /* 0x5B */
1087 "VK_RWIN", /* 0x5C */
1088 "VK_APPS", /* 0x5D */
1091 "VK_NUMPAD0", /* 0x60 */
1092 "VK_NUMPAD1", /* 0x61 */
1093 "VK_NUMPAD2", /* 0x62 */
1094 "VK_NUMPAD3", /* 0x63 */
1095 "VK_NUMPAD4", /* 0x64 */
1096 "VK_NUMPAD5", /* 0x65 */
1097 "VK_NUMPAD6", /* 0x66 */
1098 "VK_NUMPAD7", /* 0x67 */
1099 "VK_NUMPAD8", /* 0x68 */
1100 "VK_NUMPAD9", /* 0x69 */
1101 "VK_MULTIPLY", /* 0x6A */
1102 "VK_ADD", /* 0x6B */
1103 "VK_SEPARATOR", /* 0x6C */
1104 "VK_SUBTRACT", /* 0x6D */
1105 "VK_DECIMAL", /* 0x6E */
1106 "VK_DIVIDE", /* 0x6F */
1116 "VK_F10", /* 0x79 */
1117 "VK_F11", /* 0x7A */
1118 "VK_F12", /* 0x7B */
1119 "VK_F13", /* 0x7C */
1120 "VK_F14", /* 0x7D */
1121 "VK_F15", /* 0x7E */
1122 "VK_F16", /* 0x7F */
1123 "VK_F17", /* 0x80 */
1124 "VK_F18", /* 0x81 */
1125 "VK_F19", /* 0x82 */
1126 "VK_F20", /* 0x83 */
1127 "VK_F21", /* 0x84 */
1128 "VK_F22", /* 0x85 */
1129 "VK_F23", /* 0x86 */
1130 "VK_F24", /* 0x87 */
1139 "VK_NUMLOCK", /* 0x90 */
1140 "VK_SCROLL", /* 0x91 */
1155 "VK_LSHIFT", /* 0xA0 */
1156 "VK_RSHIFT", /* 0xA1 */
1157 "VK_LCONTROL", /* 0xA2 */
1158 "VK_RCONTROL", /* 0xA3 */
1159 "VK_LMENU", /* 0xA4 */
1160 "VK_RMENU", /* 0xA5 */
1181 "VK_OEM_1", /* 0xBA */
1182 "VK_OEM_PLUS", /* 0xBB */
1183 "VK_OEM_COMMA", /* 0xBC */
1184 "VK_OEM_MINUS", /* 0xBD */
1185 "VK_OEM_PERIOD", /* 0xBE */
1186 "VK_OEM_2", /* 0xBF */
1187 "VK_OEM_3", /* 0xC0 */
1214 "VK_OEM_4", /* 0xDB */
1215 "VK_OEM_5", /* 0xDC */
1216 "VK_OEM_6", /* 0xDD */
1217 "VK_OEM_7", /* 0xDE */
1218 "VK_OEM_8", /* 0xDF */
1220 "VK_OEM_AX", /* 0xE1 */
1221 "VK_OEM_102", /* 0xE2 */
1222 "VK_ICO_HELP", /* 0xE3 */
1223 "VK_ICO_00", /* 0xE4 */
1224 "VK_PROCESSKEY", /* 0xE5 */
1241 "VK_ATTN", /* 0xF6 */
1242 "VK_CRSEL", /* 0xF7 */
1243 "VK_EXSEL", /* 0xF8 */
1244 "VK_EREOF", /* 0xF9 */
1245 "VK_PLAY", /* 0xFA */
1246 "VK_ZOOM", /* 0xFB */
1247 "VK_NONAME", /* 0xFC */
1248 "VK_PA1", /* 0xFD */
1249 "VK_OEM_CLEAR", /* 0xFE */
1254 /************************************************************************/
1257 /* WM_USER+n message values for "common controls" */
1261 const char *name; /* name of control message */
1262 UINT value; /* message number (0x0401-0x0fff */
1263 UINT len; /* length of space at lParam to dump */
1269 const WCHAR *classname; /* class name to match */
1270 const USER_MSG *classmsg; /* pointer to first USER_MSG for class */
1271 USER_MSG *lastmsg; /* pointer to last USER_MSG for class */
1274 #define USM(a,b) { #a ,a,b}
1275 #define SZOF(a) sizeof(a)
1277 /* To dump memory at the lParam for any of these messages, */
1278 /* replace the "0" with a "SZOF(structure)", or with a */
1279 /* number. (First method prefered.) */
1281 static const USER_MSG rebar_array[] = {
1282 USM(RB_INSERTBANDA, 0),
1283 USM(RB_DELETEBAND, 0),
1284 USM(RB_GETBARINFO, 0),
1285 USM(RB_SETBARINFO, 0),
1286 USM(RB_GETBANDINFO, 0),
1287 USM(RB_SETBANDINFOA, 0),
1288 USM(RB_SETPARENT, 0),
1291 USM(RB_INSERTBANDW, 0),
1292 USM(RB_SETBANDINFOW, 0),
1293 USM(RB_GETBANDCOUNT, 0),
1294 USM(RB_GETROWCOUNT, 0),
1295 USM(RB_GETROWHEIGHT, 0),
1296 USM(RB_IDTOINDEX, 0),
1297 USM(RB_GETTOOLTIPS, 0),
1298 USM(RB_SETTOOLTIPS, 0),
1299 USM(RB_SETBKCOLOR, 0),
1300 USM(RB_GETBKCOLOR, 0),
1301 USM(RB_SETTEXTCOLOR, 0),
1302 USM(RB_GETTEXTCOLOR, 0),
1303 USM(RB_SIZETORECT, 0),
1304 USM(RB_BEGINDRAG, 0),
1306 USM(RB_DRAGMOVE, 0),
1307 USM(RB_GETBARHEIGHT, 0),
1308 USM(RB_GETBANDINFOW, 0),
1309 USM(RB_GETBANDINFOA, 0),
1310 USM(RB_MINIMIZEBAND, 0),
1311 USM(RB_MAXIMIZEBAND, 0),
1312 USM(RB_GETBANDBORDERS, 0),
1313 USM(RB_SHOWBAND, 0),
1314 USM(RB_SETPALETTE, 0),
1315 USM(RB_GETPALETTE, 0),
1316 USM(RB_MOVEBAND, 0),
1319 static const USER_MSG toolbar_array[] = {
1320 USM(TB_ENABLEBUTTON ,0),
1321 USM(TB_CHECKBUTTON ,0),
1322 USM(TB_PRESSBUTTON ,0),
1323 USM(TB_HIDEBUTTON ,0),
1324 USM(TB_INDETERMINATE ,0),
1325 USM(TB_MARKBUTTON ,0),
1326 USM(TB_ISBUTTONENABLED ,0),
1327 USM(TB_ISBUTTONCHECKED ,0),
1328 USM(TB_ISBUTTONPRESSED ,0),
1329 USM(TB_ISBUTTONHIDDEN ,0),
1330 USM(TB_ISBUTTONINDETERMINATE ,0),
1331 USM(TB_ISBUTTONHIGHLIGHTED ,0),
1332 USM(TB_SETSTATE ,0),
1333 USM(TB_GETSTATE ,0),
1334 USM(TB_ADDBITMAP ,0),
1335 USM(TB_ADDBUTTONSA ,0),
1336 USM(TB_INSERTBUTTONA ,0),
1337 USM(TB_DELETEBUTTON ,0),
1338 USM(TB_GETBUTTON ,0),
1339 USM(TB_BUTTONCOUNT ,0),
1340 USM(TB_COMMANDTOINDEX ,0),
1341 USM(TB_SAVERESTOREA ,0),
1342 USM(TB_CUSTOMIZE ,0),
1343 USM(TB_ADDSTRINGA ,0),
1344 USM(TB_GETITEMRECT ,0),
1345 USM(TB_BUTTONSTRUCTSIZE ,0),
1346 USM(TB_SETBUTTONSIZE ,0),
1347 USM(TB_SETBITMAPSIZE ,0),
1348 USM(TB_AUTOSIZE ,0),
1349 USM(TB_GETTOOLTIPS ,0),
1350 USM(TB_SETTOOLTIPS ,0),
1351 USM(TB_SETPARENT ,0),
1354 USM(TB_GETBITMAPFLAGS ,0),
1355 USM(TB_SETCMDID ,0),
1356 USM(TB_CHANGEBITMAP ,0),
1357 USM(TB_GETBITMAP ,0),
1358 USM(TB_GETBUTTONTEXTA ,0),
1359 USM(TB_REPLACEBITMAP ,0),
1360 USM(TB_SETINDENT ,0),
1361 USM(TB_SETIMAGELIST ,0),
1362 USM(TB_GETIMAGELIST ,0),
1363 USM(TB_LOADIMAGES ,0),
1365 USM(TB_SETHOTIMAGELIST ,0),
1366 USM(TB_GETHOTIMAGELIST ,0),
1367 USM(TB_SETDISABLEDIMAGELIST ,0),
1368 USM(TB_GETDISABLEDIMAGELIST ,0),
1369 USM(TB_SETSTYLE ,0),
1370 USM(TB_GETSTYLE ,0),
1371 USM(TB_GETBUTTONSIZE ,0),
1372 USM(TB_SETBUTTONWIDTH ,0),
1373 USM(TB_SETMAXTEXTROWS ,0),
1374 USM(TB_GETTEXTROWS ,0),
1375 USM(TB_GETOBJECT ,0),
1376 USM(TB_GETBUTTONINFOW ,0),
1377 USM(TB_SETBUTTONINFOW ,0),
1378 USM(TB_GETBUTTONINFOA ,0),
1379 USM(TB_SETBUTTONINFOA ,0),
1380 USM(TB_INSERTBUTTONW ,0),
1381 USM(TB_ADDBUTTONSW ,0),
1383 USM(TB_SETDRAWTEXTFLAGS ,0),
1384 USM(TB_GETHOTITEM ,0),
1385 USM(TB_SETHOTITEM ,0),
1386 USM(TB_SETANCHORHIGHLIGHT ,0),
1387 USM(TB_GETANCHORHIGHLIGHT ,0),
1388 USM(TB_GETBUTTONTEXTW ,0),
1389 USM(TB_SAVERESTOREW ,0),
1390 USM(TB_ADDSTRINGW ,0),
1391 USM(TB_MAPACCELERATORA ,0),
1392 USM(TB_GETINSERTMARK ,0),
1393 USM(TB_SETINSERTMARK ,0),
1394 USM(TB_INSERTMARKHITTEST ,0),
1395 USM(TB_MOVEBUTTON ,0),
1396 USM(TB_GETMAXSIZE ,0),
1397 USM(TB_SETEXTENDEDSTYLE ,0),
1398 USM(TB_GETEXTENDEDSTYLE ,0),
1399 USM(TB_GETPADDING ,0),
1400 USM(TB_SETPADDING ,0),
1401 USM(TB_SETINSERTMARKCOLOR ,0),
1402 USM(TB_GETINSERTMARKCOLOR ,0),
1403 USM(TB_MAPACCELERATORW ,0),
1404 USM(TB_GETSTRINGW ,0),
1405 USM(TB_GETSTRINGA ,0),
1406 USM(TB_UNKWN45D ,8),
1407 USM(TB_UNKWN45E ,0),
1408 USM(TB_UNKWN460 ,0),
1409 USM(TB_UNKWN463 ,8),
1410 USM(TB_UNKWN464 ,0),
1413 static const USER_MSG comboex_array[] = {
1414 USM(CBEM_INSERTITEMA ,0),
1415 USM(CBEM_SETIMAGELIST ,0),
1416 USM(CBEM_GETIMAGELIST ,0),
1417 USM(CBEM_GETITEMA ,0),
1418 USM(CBEM_SETITEMA ,0),
1419 USM(CBEM_GETCOMBOCONTROL ,0),
1420 USM(CBEM_GETEDITCONTROL ,0),
1421 USM(CBEM_SETEXSTYLE ,0),
1422 USM(CBEM_GETEXTENDEDSTYLE ,0),
1423 USM(CBEM_HASEDITCHANGED ,0),
1424 USM(CBEM_INSERTITEMW ,0),
1425 USM(CBEM_SETITEMW ,0),
1426 USM(CBEM_GETITEMW ,0),
1427 USM(CBEM_SETEXTENDEDSTYLE ,0),
1430 static const USER_MSG propsht_array[] = {
1431 USM(PSM_SETCURSEL ,0),
1432 USM(PSM_REMOVEPAGE ,0),
1433 USM(PSM_ADDPAGE ,0),
1434 USM(PSM_CHANGED ,0),
1435 USM(PSM_RESTARTWINDOWS ,0),
1436 USM(PSM_REBOOTSYSTEM ,0),
1437 USM(PSM_CANCELTOCLOSE ,0),
1438 USM(PSM_QUERYSIBLINGS ,0),
1439 USM(PSM_UNCHANGED ,0),
1441 USM(PSM_SETTITLEA ,0),
1442 USM(PSM_SETWIZBUTTONS ,0),
1443 USM(PSM_PRESSBUTTON ,0),
1444 USM(PSM_SETCURSELID ,0),
1445 USM(PSM_SETFINISHTEXTA ,0),
1446 USM(PSM_GETTABCONTROL ,0),
1447 USM(PSM_ISDIALOGMESSAGE ,0),
1448 USM(PSM_GETCURRENTPAGEHWND ,0),
1449 USM(PSM_SETTITLEW ,0),
1450 USM(PSM_SETFINISHTEXTW ,0),
1456 static CONTROL_CLASS cc_array[] = {
1457 {WC_COMBOBOXEXW, comboex_array, 0},
1458 {REBARCLASSNAMEW, rebar_array, 0},
1459 {TOOLBARCLASSNAMEW, toolbar_array, 0},
1460 {WC_PROPSHEETW, propsht_array, 0},
1464 /************************************************************************/
1467 /* WM_NOTIFY function codes display */
1471 const char *name; /* name of notify message */
1472 UINT value; /* notify code value */
1473 UINT len; /* length of extra space to dump */
1476 #define SPNFY(a,b) { #a ,a,sizeof(b)-sizeof(NMHDR)}
1478 /* Array MUST be in descending order by the 'value' field */
1479 /* (since value is UNSIGNED, 0xffffffff is largest and */
1480 /* 0xfffffffe is smaller). A binary search is used to */
1481 /* locate the correct 'value'. */
1482 static const SPY_NOTIFY spnfy_array[] = {
1483 /* common 0U to 0U-99U */
1484 SPNFY(NM_OUTOFMEMORY, NMHDR),
1485 SPNFY(NM_CLICK, NMHDR),
1486 SPNFY(NM_DBLCLK, NMHDR),
1487 SPNFY(NM_RETURN, NMHDR),
1488 SPNFY(NM_RCLICK, NMHDR),
1489 SPNFY(NM_RDBLCLK, NMHDR),
1490 SPNFY(NM_SETFOCUS, NMHDR),
1491 SPNFY(NM_KILLFOCUS, NMHDR),
1492 SPNFY(NM_CUSTOMDRAW, NMCUSTOMDRAW),
1493 SPNFY(NM_HOVER, NMHDR),
1494 SPNFY(NM_NCHITTEST, NMMOUSE),
1495 SPNFY(NM_KEYDOWN, NMKEY),
1496 SPNFY(NM_RELEASEDCAPTURE, NMHDR),
1497 SPNFY(NM_SETCURSOR, NMMOUSE),
1498 SPNFY(NM_CHAR, NMCHAR),
1499 SPNFY(NM_TOOLTIPSCREATED, NMTOOLTIPSCREATED),
1500 /* Listview 0U-100U to 0U-199U */
1501 SPNFY(LVN_ITEMCHANGING, NMLISTVIEW),
1502 SPNFY(LVN_ITEMCHANGED, NMLISTVIEW),
1503 SPNFY(LVN_INSERTITEM, NMLISTVIEW),
1504 SPNFY(LVN_DELETEITEM, NMLISTVIEW),
1505 SPNFY(LVN_DELETEALLITEMS, NMLISTVIEW),
1506 SPNFY(LVN_BEGINLABELEDITA, NMLVDISPINFOA),
1507 SPNFY(LVN_ENDLABELEDITA, NMLVDISPINFOA),
1508 SPNFY(LVN_COLUMNCLICK, NMLISTVIEW),
1509 SPNFY(LVN_BEGINDRAG, NMLISTVIEW),
1510 SPNFY(LVN_BEGINRDRAG, NMLISTVIEW),
1511 SPNFY(LVN_ODCACHEHINT, NMLVCACHEHINT),
1512 SPNFY(LVN_ITEMACTIVATE, NMITEMACTIVATE),
1513 SPNFY(LVN_ODSTATECHANGED, NMLVODSTATECHANGE),
1514 SPNFY(LVN_HOTTRACK, NMLISTVIEW),
1515 SPNFY(LVN_GETDISPINFOA, NMLVDISPINFOA),
1516 SPNFY(LVN_SETDISPINFOA, NMLVDISPINFOA),
1517 SPNFY(LVN_ODFINDITEMA, NMLVFINDITEMA),
1518 SPNFY(LVN_KEYDOWN, NMLVKEYDOWN),
1519 SPNFY(LVN_MARQUEEBEGIN, NMLISTVIEW),
1520 SPNFY(LVN_GETINFOTIPA, NMLVGETINFOTIPA),
1521 SPNFY(LVN_GETINFOTIPW, NMLVGETINFOTIPW),
1522 SPNFY(LVN_BEGINLABELEDITW, NMLVDISPINFOW),
1523 SPNFY(LVN_ENDLABELEDITW, NMLVDISPINFOW),
1524 SPNFY(LVN_GETDISPINFOW, NMLVDISPINFOW),
1525 SPNFY(LVN_SETDISPINFOW, NMLVDISPINFOW),
1526 SPNFY(LVN_ODFINDITEMW, NMLVFINDITEMW),
1527 /* PropertySheet 0U-200U to 0U-299U */
1528 SPNFY(PSN_SETACTIVE, PSHNOTIFY),
1529 SPNFY(PSN_KILLACTIVE, PSHNOTIFY),
1530 SPNFY(PSN_APPLY, PSHNOTIFY),
1531 SPNFY(PSN_RESET, PSHNOTIFY),
1532 SPNFY(PSN_HELP, PSHNOTIFY),
1533 SPNFY(PSN_WIZBACK, PSHNOTIFY),
1534 SPNFY(PSN_WIZNEXT, PSHNOTIFY),
1535 SPNFY(PSN_WIZFINISH, PSHNOTIFY),
1536 SPNFY(PSN_QUERYCANCEL, PSHNOTIFY),
1537 SPNFY(PSN_GETOBJECT, NMOBJECTNOTIFY),
1538 /* SPNFY(PSN_QUERYINITIALFOCUS, .PSHNOTIFY), NIY */
1539 /* SPNFY(PSN_TRANSLATEACCELERATOR, .PSHNOTIFY), NIY */
1540 /* Header 0U-300U to 0U-399U */
1541 SPNFY(HDN_ITEMCHANGINGA, NMHDR),
1542 SPNFY(HDN_ITEMCHANGEDA, NMHDR),
1543 SPNFY(HDN_ITEMCLICKA, NMHDR),
1544 SPNFY(HDN_ITEMDBLCLICKA, NMHDR),
1545 SPNFY(HDN_DIVIDERDBLCLICKA, NMHDR),
1546 SPNFY(HDN_BEGINTRACKA, NMHDR),
1547 SPNFY(HDN_ENDTRACKA, NMHDR),
1548 SPNFY(HDN_GETDISPINFOA, NMHDR),
1549 SPNFY(HDN_BEGINDRAG, NMHDR),
1550 SPNFY(HDN_ENDDRAG, NMHDR),
1551 SPNFY(HDN_ITEMCHANGINGW, NMHDR),
1552 SPNFY(HDN_ITEMCHANGEDW, NMHDR),
1553 SPNFY(HDN_ITEMCLICKW, NMHDR),
1554 SPNFY(HDN_ITEMDBLCLICKW, NMHDR),
1555 SPNFY(HDN_DIVIDERDBLCLICKW, NMHDR),
1556 SPNFY(HDN_BEGINTRACKW, NMHDR),
1557 SPNFY(HDN_ENDTRACKW, NMHDR),
1558 SPNFY(HDN_GETDISPINFOW, NMHDR),
1559 /* Treeview 0U-400U to 0U-499U */
1560 SPNFY(TVN_SELCHANGINGA, NMHDR),
1561 SPNFY(TVN_SELCHANGEDA, NMHDR),
1562 SPNFY(TVN_GETDISPINFOA, NMHDR),
1563 SPNFY(TVN_SETDISPINFOA, NMHDR),
1564 SPNFY(TVN_ITEMEXPANDINGA, NMHDR),
1565 SPNFY(TVN_ITEMEXPANDEDA, NMHDR),
1566 SPNFY(TVN_BEGINDRAGA, NMHDR),
1567 SPNFY(TVN_BEGINRDRAGA, NMHDR),
1568 SPNFY(TVN_DELETEITEMA, NMHDR),
1569 SPNFY(TVN_BEGINLABELEDITA, NMHDR),
1570 SPNFY(TVN_ENDLABELEDITA, NMHDR),
1571 SPNFY(TVN_KEYDOWN, NMHDR),
1572 SPNFY(TVN_SELCHANGINGW, NMHDR),
1573 SPNFY(TVN_SELCHANGEDW, NMHDR),
1574 SPNFY(TVN_GETDISPINFOW, NMHDR),
1575 SPNFY(TVN_SETDISPINFOW, NMHDR),
1576 SPNFY(TVN_ITEMEXPANDINGW, NMHDR),
1577 SPNFY(TVN_ITEMEXPANDEDW, NMHDR),
1578 SPNFY(TVN_BEGINDRAGW, NMHDR),
1579 SPNFY(TVN_BEGINRDRAGW, NMHDR),
1580 SPNFY(TVN_DELETEITEMW, NMHDR),
1581 SPNFY(TVN_BEGINLABELEDITW, NMHDR),
1582 SPNFY(TVN_ENDLABELEDITW, NMHDR),
1583 /* Tooltips 0U-520U to 0U-549U */
1584 SPNFY(TTN_GETDISPINFOA, NMHDR),
1585 SPNFY(TTN_SHOW, NMHDR),
1586 SPNFY(TTN_POP, NMHDR),
1587 SPNFY(TTN_GETDISPINFOW, NMHDR),
1588 /* Tab 0U-550U to 0U-580U */
1589 SPNFY(TCN_KEYDOWN, NMHDR),
1590 SPNFY(TCN_SELCHANGE, NMHDR),
1591 SPNFY(TCN_SELCHANGING, NMHDR),
1592 SPNFY(TCN_GETOBJECT, NMHDR),
1593 /* Common Dialog 0U-601U to 0U-699U */
1594 /* Toolbar 0U-700U to 0U-720U */
1595 SPNFY(TBN_GETBUTTONINFOA, NMTOOLBARA),
1596 SPNFY(TBN_BEGINDRAG, NMTOOLBARA),
1597 SPNFY(TBN_ENDDRAG, NMTOOLBARA),
1598 SPNFY(TBN_BEGINADJUST, NMHDR),
1599 SPNFY(TBN_ENDADJUST, NMHDR),
1600 SPNFY(TBN_RESET, NMHDR),
1601 SPNFY(TBN_QUERYINSERT, NMTOOLBARA),
1602 SPNFY(TBN_QUERYDELETE, NMTOOLBARA),
1603 SPNFY(TBN_TOOLBARCHANGE, NMHDR),
1604 SPNFY(TBN_CUSTHELP, NMHDR),
1605 SPNFY(TBN_DROPDOWN, NMTOOLBARA),
1606 SPNFY(TBN_GETOBJECT, NMOBJECTNOTIFY),
1607 SPNFY(TBN_HOTITEMCHANGE, NMTBHOTITEM),
1608 SPNFY(TBN_DRAGOUT, NMTOOLBARA),
1609 SPNFY(TBN_DELETINGBUTTON, NMTOOLBARA),
1610 SPNFY(TBN_GETDISPINFOA, NMTBDISPINFOA),
1611 SPNFY(TBN_GETDISPINFOW, NMTBDISPINFOW),
1612 SPNFY(TBN_GETINFOTIPA, NMTBGETINFOTIPA),
1613 SPNFY(TBN_GETINFOTIPW, NMTBGETINFOTIPW),
1614 SPNFY(TBN_GETBUTTONINFOW, NMTOOLBARW),
1615 /* Up/Down 0U-721U to 0U-740U */
1616 SPNFY(UDN_DELTAPOS, NMHDR),
1617 /* Month Calendar 0U-750U to 0U-759U */
1618 /* ******************* WARNING ***************************** */
1619 /* The following appear backwards but needs to be this way. */
1620 /* The reason is that MS (and us) define the MCNs as */
1622 /* instead of the way ALL other notifications are */
1624 /* The only place that this is important is in this list */
1626 /* Also since the same error was made with the DTN_ items, */
1627 /* they overlay the MCN_ and need to be inserted in the */
1628 /* other section of the table so that it is in order for */
1629 /* the binary search. */
1631 /* Thank you MS for your obvious quality control!! */
1632 /* ******************* WARNING ***************************** */
1633 /* Date/Time 0U-760U to 0U-799U */
1634 /* SPNFY(MCN_SELECT, NMHDR), */
1635 /* SPNFY(MCN_GETDAYSTATE, NMHDR), */
1636 /* SPNFY(MCN_SELCHANGE, NMHDR), */
1637 /* ******************* WARNING ***************************** */
1638 /* The following appear backwards but needs to be this way. */
1639 /* The reason is that MS (and us) define the MCNs as */
1641 /* instead of the way ALL other notifications are */
1643 /* The only place that this is important is in this list */
1644 /* ******************* WARNING ***************************** */
1645 SPNFY(DTN_FORMATQUERYW, NMHDR),
1646 SPNFY(DTN_FORMATW, NMHDR),
1647 SPNFY(DTN_WMKEYDOWNW, NMHDR),
1648 SPNFY(DTN_USERSTRINGW, NMHDR),
1649 SPNFY(MCN_SELECT, NMHDR),
1650 SPNFY(MCN_GETDAYSTATE, NMHDR),
1651 SPNFY(MCN_SELCHANGE, NMHDR),
1652 SPNFY(DTN_CLOSEUP, NMHDR),
1653 SPNFY(DTN_DROPDOWN, NMHDR),
1654 SPNFY(DTN_FORMATQUERYA, NMHDR),
1655 SPNFY(DTN_FORMATA, NMHDR),
1656 SPNFY(DTN_WMKEYDOWNA, NMHDR),
1657 SPNFY(DTN_USERSTRINGA, NMHDR),
1658 SPNFY(DTN_DATETIMECHANGE, NMHDR),
1659 /* ComboBoxEx 0U-800U to 0U-830U */
1660 SPNFY(CBEN_GETDISPINFOA, NMCOMBOBOXEXA),
1661 SPNFY(CBEN_INSERTITEM, NMCOMBOBOXEXA),
1662 SPNFY(CBEN_DELETEITEM, NMCOMBOBOXEXA),
1663 SPNFY(CBEN_BEGINEDIT, NMHDR),
1664 SPNFY(CBEN_ENDEDITA, NMCBEENDEDITA),
1665 SPNFY(CBEN_ENDEDITW, NMCBEENDEDITW),
1666 SPNFY(CBEN_GETDISPINFOW, NMCOMBOBOXEXW),
1667 SPNFY(CBEN_DRAGBEGINA, NMCBEDRAGBEGINA),
1668 SPNFY(CBEN_DRAGBEGINW, NMCBEDRAGBEGINW),
1669 /* Rebar 0U-831U to 0U-859U */
1670 SPNFY(RBN_HEIGHTCHANGE, NMHDR),
1671 SPNFY(RBN_GETOBJECT, NMOBJECTNOTIFY),
1672 SPNFY(RBN_LAYOUTCHANGED, NMHDR),
1673 SPNFY(RBN_AUTOSIZE, NMRBAUTOSIZE),
1674 SPNFY(RBN_BEGINDRAG, NMREBAR),
1675 SPNFY(RBN_ENDDRAG, NMREBAR),
1676 SPNFY(RBN_DELETINGBAND, NMREBAR),
1677 SPNFY(RBN_DELETEDBAND, NMREBAR),
1678 SPNFY(RBN_CHILDSIZE, NMREBARCHILDSIZE),
1679 /* IP Adderss 0U-860U to 0U-879U */
1680 SPNFY(IPN_FIELDCHANGED, NMHDR),
1681 /* Status bar 0U-880U to 0U-899U */
1682 SPNFY(SBN_SIMPLEMODECHANGE, NMHDR),
1683 /* Pager 0U-900U to 0U-950U */
1684 SPNFY(PGN_SCROLL, NMPGSCROLL),
1685 SPNFY(PGN_CALCSIZE, NMPGCALCSIZE),
1687 static const SPY_NOTIFY *end_spnfy_array; /* ptr to last good entry in array */
1691 static BOOL16 SPY_Exclude[SPY_MAX_MSGNUM+1];
1692 static BOOL16 SPY_ExcludeDWP = 0;
1694 #define SPY_EXCLUDE(msg) \
1695 (SPY_Exclude[(msg) > SPY_MAX_MSGNUM ? SPY_MAX_MSGNUM : (msg)])
1700 UINT msgnum; /* message number */
1701 HWND msg_hwnd; /* window handle for message */
1702 WPARAM wParam; /* message parameter */
1703 LPARAM lParam; /* message parameter */
1704 INT data_len; /* length of data to dump */
1705 char msg_name[60]; /* message name (see SPY_GetMsgName) */
1706 WCHAR wnd_class[60]; /* window class name (full) */
1707 WCHAR wnd_name[16]; /* window name for message */
1710 /* This is defined so that the external entry point can return the addr */
1711 static SPY_INSTANCE ext_sp_e;
1713 static int indent_tls_index;
1715 /***********************************************************************
1718 inline static int get_indent_level(void)
1720 return (int)TlsGetValue( indent_tls_index );
1724 /***********************************************************************
1727 inline static void set_indent_level( int level )
1729 TlsSetValue( indent_tls_index, (void *)level );
1733 /***********************************************************************
1734 * SPY_GetMsgInternal
1736 static const char *SPY_GetMsgInternal( UINT msg )
1738 static char msg_buffer[20];
1740 if (msg <= SPY_MAX_MSGNUM)
1742 if (!MessageTypeNames[msg]) return "???";
1743 return MessageTypeNames[msg];
1746 if (msg >= LVM_FIRST && msg <= LVM_FIRST + SPY_MAX_LVMMSGNUM)
1748 if (!LVMMessageTypeNames[msg-LVM_FIRST]) return "LVM_?";
1749 return LVMMessageTypeNames[msg-LVM_FIRST];
1752 if (msg >= TV_FIRST && msg <= TV_FIRST + SPY_MAX_TVMSGNUM)
1754 if (!TVMessageTypeNames[msg-TV_FIRST]) return "TV_?";
1755 return TVMessageTypeNames[msg-TV_FIRST];
1758 if (msg >= HDM_FIRST && msg <= HDM_FIRST + SPY_MAX_HDMMSGNUM)
1760 if (!HDMMessageTypeNames[msg-HDM_FIRST]) return "HDM_?";
1761 return HDMMessageTypeNames[msg-HDM_FIRST];
1764 if (msg >= TCM_FIRST && msg <= TCM_FIRST + SPY_MAX_TCMMSGNUM)
1766 if (!TCMMessageTypeNames[msg-TCM_FIRST]) return "TCM_?";
1767 return TCMMessageTypeNames[msg-TCM_FIRST];
1770 if (msg >= PGM_FIRST && msg <= PGM_FIRST + SPY_MAX_PGMMSGNUM)
1772 if (!PGMMessageTypeNames[msg-PGM_FIRST]) return "PGM_?";
1773 return PGMMessageTypeNames[msg-PGM_FIRST];
1776 if (msg >= CCM_FIRST && msg <= CCM_FIRST + SPY_MAX_CCMMSGNUM)
1778 if (!CCMMessageTypeNames[msg-CCM_FIRST]) return "???";
1779 return CCMMessageTypeNames[msg-CCM_FIRST];
1782 if (msg >= WM_WINE_DESTROYWINDOW && msg <= WM_WINE_DESTROYWINDOW + SPY_MAX_WINEMSGNUM)
1784 if (!WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW]) return "???";
1785 return WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW];
1788 sprintf( msg_buffer, "WM_USER+%04x", msg - WM_USER );
1792 /***********************************************************************
1795 const USER_MSG *SPY_Bsearch_Msg( const USER_MSG *first, const USER_MSG *last, UINT code)
1798 const USER_MSG *test;
1800 while (last >= first) {
1801 count = 1 + last - first;
1803 /* TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
1804 code, first->value, first->name, last->value, last->name, last->len); */
1805 if (first->value == code) return first;
1806 if (last->value == code) return last;
1810 test = first + count;
1811 /* TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
1812 first, last, test, test->value, code, count); */
1813 if (test->value == code) return test;
1814 if (test->value > code)
1822 /***********************************************************************
1825 * Get message name and other information for dumping
1827 static void SPY_GetMsgStuff( SPY_INSTANCE *sp_e )
1831 sp_e->msg_name[sizeof(sp_e->msg_name)-1] = 0;
1832 strncpy (sp_e->msg_name, SPY_GetMsgInternal( sp_e->msgnum ),
1833 sizeof(sp_e->msg_name)-1);
1836 if (strncmp(sp_e->msg_name, "WM_USER+", 8) == 0) {
1839 /* TRACE("looking class %s\n", sp_e->wnd_class); */
1841 while (cc_array[i].classname &&
1842 strcmpW(cc_array[i].classname, sp_e->wnd_class) !=0) i++;
1844 if (!cc_array[i].classname) return;
1845 /* TRACE("process class %s, first %p, last %p\n",
1846 debugstr_w(cc_array[i].classname), cc_array[i].classmsg,
1847 cc_array[i].lastmsg); */
1848 p = SPY_Bsearch_Msg (cc_array[i].classmsg, cc_array[i].lastmsg,
1851 strncpy (sp_e->msg_name, p->name, sizeof(sp_e->msg_name)-1);
1852 sp_e->data_len = p->len;
1857 /***********************************************************************
1860 * Sets the value of "wnd_name" and "wnd_class" members of the
1861 * instance structure.
1864 void SPY_GetWndName( SPY_INSTANCE *sp_e )
1869 /* save and restore error code over the next call */
1870 save_error = GetLastError();
1871 GetClassNameW(sp_e->msg_hwnd, sp_e->wnd_class, sizeof(sp_e->wnd_class)/sizeof(WCHAR));
1872 SetLastError(save_error);
1874 len = InternalGetWindowText(sp_e->msg_hwnd, sp_e->wnd_name, sizeof(sp_e->wnd_name)/sizeof(WCHAR));
1875 if(!len) /* get class name */
1877 LPWSTR dst = sp_e->wnd_name;
1878 LPWSTR src = sp_e->wnd_class;
1879 int n = sizeof(sp_e->wnd_name)/sizeof(WCHAR) - 3;
1881 while ((n-- > 0) && *src) *dst++ = *src++;
1887 /***********************************************************************
1890 * **** External function ****
1894 const char *SPY_GetMsgName( UINT msg, HWND hWnd )
1896 ext_sp_e.msgnum = msg;
1897 ext_sp_e.msg_hwnd = hWnd;
1898 ext_sp_e.lParam = 0;
1899 ext_sp_e.wParam = 0;
1900 SPY_GetWndName(&ext_sp_e);
1901 SPY_GetMsgStuff(&ext_sp_e);
1902 return ext_sp_e.msg_name;
1905 /***********************************************************************
1908 const char *SPY_GetVKeyName(WPARAM wParam)
1910 const char *vk_key_name;
1912 if(wParam <= SPY_MAX_VKKEYSNUM && VK_KeyNames[wParam])
1913 vk_key_name = VK_KeyNames[wParam];
1915 vk_key_name = "VK_???";
1920 /***********************************************************************
1921 * SPY_Bsearch_Notify
1923 const SPY_NOTIFY *SPY_Bsearch_Notify( const SPY_NOTIFY *first, const SPY_NOTIFY *last, UINT code)
1926 const SPY_NOTIFY *test;
1928 while (last >= first) {
1929 count = 1 + last - first;
1931 /* TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
1932 code, first->value, first->name, last->value, last->name, last->len); */
1933 if (first->value == code) return first;
1934 if (last->value == code) return last;
1938 test = first + count;
1939 /* TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
1940 first, last, test, test->value, code, count); */
1941 if (test->value == code) return test;
1942 if (test->value < code)
1950 /***********************************************************************
1953 void SPY_DumpMem (LPSTR header, UINT *q, INT len)
1957 for(i=0; i<len-12; i+=16) {
1958 TRACE("%s [%04x] %08x %08x %08x %08x\n",
1959 header, i, *q, *(q+1), *(q+2), *(q+3));
1962 switch ((len - i + 3) & (~3)) {
1964 TRACE("%s [%04x] %08x %08x %08x %08x\n",
1965 header, i, *q, *(q+1), *(q+2), *(q+3));
1968 TRACE("%s [%04x] %08x %08x %08x\n",
1969 header, i, *q, *(q+1), *(q+2));
1972 TRACE("%s [%04x] %08x %08x\n",
1973 header, i, *q, *(q+1));
1976 TRACE("%s [%04x] %08x\n",
1984 /***********************************************************************
1987 void SPY_DumpStructure (SPY_INSTANCE *sp_e, BOOL enter)
1989 switch (sp_e->msgnum)
1991 case LVM_INSERTITEMW:
1992 case LVM_INSERTITEMA:
2000 LPLVITEMA item = (LPLVITEMA) sp_e->lParam;
2002 SPY_DumpMem ("LVITEM", (UINT*)item, sizeof(LVITEMA));
2006 case TCM_INSERTITEMW:
2007 case TCM_INSERTITEMA:
2015 TCITEMA *item = (TCITEMA *) sp_e->lParam;
2017 SPY_DumpMem ("TCITEM", (UINT*)item, sizeof(TCITEMA));
2021 case TCM_ADJUSTRECT:
2022 case LVM_GETITEMRECT:
2023 case LVM_GETSUBITEMRECT:
2025 LPRECT rc = (LPRECT) sp_e->lParam;
2027 TRACE("lParam rect (%d,%d)-(%d,%d)\n",
2028 rc->left, rc->top, rc->right, rc->bottom);
2032 case LVM_SETITEMPOSITION32:
2035 case LVM_GETITEMPOSITION:
2038 LPPOINT point = (LPPOINT) sp_e->lParam;
2040 TRACE("lParam point x=%ld, y=%ld\n", point->x, point->y);
2045 if (!enter && (sp_e->msgnum == SBM_SETRANGE)) break;
2046 TRACE("min=%d max=%d\n", (INT)sp_e->wParam, (INT)sp_e->lParam);
2049 if ((enter && (sp_e->msgnum == SBM_GETRANGE)) ||
2050 (!enter && (sp_e->msgnum == SBM_SETRANGE))) break;
2052 LPINT ptmin = (LPINT) sp_e->wParam;
2053 LPINT ptmax = (LPINT) sp_e->lParam;
2055 TRACE("min=%d max=%d\n", *ptmin, *ptmax);
2057 TRACE("min=%d max=n/a\n", *ptmin);
2059 TRACE("min=n/a max=%d\n", *ptmax);
2065 DRAWITEMSTRUCT *lpdis = (DRAWITEMSTRUCT*) sp_e->lParam;
2066 TRACE("DRAWITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2067 lpdis->CtlType, lpdis->CtlID);
2068 TRACE("itemID=0x%08x itemAction=0x%08x itemState=0x%08x\n",
2069 lpdis->itemID, lpdis->itemAction, lpdis->itemState);
2070 TRACE("hWnd=0x%04x hDC=0x%04x (%d,%d)-(%d,%d) itemData=0x%08lx\n",
2071 lpdis->hwndItem, lpdis->hDC, lpdis->rcItem.left,
2072 lpdis->rcItem.top, lpdis->rcItem.right,
2073 lpdis->rcItem.bottom, lpdis->itemData);
2076 case WM_MEASUREITEM:
2078 MEASUREITEMSTRUCT *lpmis = (MEASUREITEMSTRUCT*) sp_e->lParam;
2079 TRACE("MEASUREITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2080 lpmis->CtlType, lpmis->CtlID);
2081 TRACE("itemID=0x%08x itemWidth=0x%08x itemHeight=0x%08x\n",
2082 lpmis->itemID, lpmis->itemWidth, lpmis->itemHeight);
2083 TRACE("itemData=0x%08lx\n", lpmis->itemData);
2086 case WM_WINDOWPOSCHANGED:
2088 case WM_WINDOWPOSCHANGING:
2090 WINDOWPOS *lpwp = (WINDOWPOS *)sp_e->lParam;
2091 TRACE("WINDOWPOS hwnd=0x%04x, after=0x%04x, at (%d,%d) w=%d h=%d, flags=0x%08x\n",
2092 lpwp->hwnd, lpwp->hwndInsertAfter, lpwp->x, lpwp->y,
2093 lpwp->cx, lpwp->cy, lpwp->flags);
2096 case WM_STYLECHANGED:
2098 case WM_STYLECHANGING:
2100 LPSTYLESTRUCT ss = (LPSTYLESTRUCT) sp_e->lParam;
2101 TRACE("STYLESTRUCT: StyleOld=0x%08lx, StyleNew=0x%08lx\n",
2102 ss->styleOld, ss->styleNew);
2107 RECT *rc = (RECT *)sp_e->lParam;
2108 TRACE("Rect (%d,%d)-(%d,%d)\n",
2109 rc->left, rc->top, rc->right, rc->bottom);
2113 /* if (!enter) break; */
2115 NMHDR * pnmh = (NMHDR*) sp_e->lParam;
2117 const SPY_NOTIFY *p;
2118 WCHAR from_class[60];
2121 p = SPY_Bsearch_Notify (&spnfy_array[0], end_spnfy_array,
2124 TRACE("NMHDR hwndFrom=0x%08x idFrom=0x%08x code=%s<0x%08x>, extra=0x%x\n",
2125 pnmh->hwndFrom, pnmh->idFrom, p->name, pnmh->code, p->len);
2128 /* for CUSTOMDRAW, dump all the data for TOOLBARs */
2129 if (pnmh->code == NM_CUSTOMDRAW) {
2130 /* save and restore error code over the next call */
2131 save_error = GetLastError();
2132 GetClassNameW(pnmh->hwndFrom, from_class,
2133 sizeof(from_class)/sizeof(WCHAR));
2134 SetLastError(save_error);
2135 if (strcmpW(TOOLBARCLASSNAMEW, from_class) == 0)
2136 dumplen = sizeof(NMTBCUSTOMDRAW)-sizeof(NMHDR);
2139 q = (UINT *)(pnmh + 1);
2140 SPY_DumpMem ("NM extra", q, (INT)dumplen);
2144 TRACE("NMHDR hwndFrom=0x%08x idFrom=0x%08x code=0x%08x\n",
2145 pnmh->hwndFrom, pnmh->idFrom, pnmh->code);
2148 if (sp_e->data_len > 0)
2149 SPY_DumpMem ("MSG lParam", (UINT *)sp_e->lParam, sp_e->data_len);
2154 /***********************************************************************
2157 void SPY_EnterMessage( INT iFlag, HWND hWnd, UINT msg,
2158 WPARAM wParam, LPARAM lParam )
2163 if (!TRACE_ON(message) || SPY_EXCLUDE(msg)) return;
2166 sp_e.msg_hwnd = hWnd;
2167 sp_e.lParam = lParam;
2168 sp_e.wParam = wParam;
2169 SPY_GetWndName(&sp_e);
2170 SPY_GetMsgStuff(&sp_e);
2171 indent = get_indent_level();
2173 /* each SPY_SENDMESSAGE must be complemented by call to SPY_ExitMessage */
2176 case SPY_DISPATCHMESSAGE16:
2177 TRACE("%*s(%04x) %-16s message [%04x] %s dispatched wp=%04x lp=%08lx\n",
2178 indent, "", WIN_Handle16(hWnd),
2179 debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name, wParam, lParam);
2182 case SPY_DISPATCHMESSAGE:
2183 TRACE("%*s(%08x) %-16s message [%04x] %s dispatched wp=%08x lp=%08lx\n",
2184 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2185 sp_e.msg_name, wParam, lParam);
2188 case SPY_SENDMESSAGE16:
2189 case SPY_SENDMESSAGE:
2192 HTASK16 hTask = GetWindowTask16( WIN_Handle16(hWnd) );
2194 if (hTask == GetCurrentTask()) strcpy( taskName, "self" );
2195 else if (!hTask) strcpy( taskName, "Wine" );
2198 sprintf( taskName, "task %04x ???", hTask );
2199 GetModuleName16( hTask, taskName + 10, sizeof(taskName) - 10 );
2202 if (iFlag == SPY_SENDMESSAGE16)
2203 TRACE("%*s(%04x) %-16s message [%04x] %s sent from %s wp=%04x lp=%08lx\n",
2204 indent, "", WIN_Handle16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2205 sp_e.msg_name, taskName, wParam, lParam );
2207 { TRACE("%*s(%08x) %-16s message [%04x] %s sent from %s wp=%08x lp=%08lx\n",
2208 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2209 sp_e.msg_name, taskName, wParam, lParam );
2210 SPY_DumpStructure(&sp_e, TRUE);
2215 case SPY_DEFWNDPROC16:
2216 if( SPY_ExcludeDWP ) return;
2217 TRACE("%*s(%04x) DefWindowProc16: %s [%04x] wp=%04x lp=%08lx\n",
2218 indent, "", WIN_Handle16(hWnd), sp_e.msg_name, msg, wParam, lParam );
2221 case SPY_DEFWNDPROC:
2222 if( SPY_ExcludeDWP ) return;
2223 TRACE("%*s(%08x) DefWindowProc32: %s [%04x] wp=%08x lp=%08lx\n",
2224 indent, "", hWnd, sp_e.msg_name,
2225 msg, wParam, lParam );
2228 set_indent_level( indent + SPY_INDENT_UNIT );
2232 /***********************************************************************
2235 void SPY_ExitMessage( INT iFlag, HWND hWnd, UINT msg, LRESULT lReturn,
2236 WPARAM wParam, LPARAM lParam )
2241 if (!TRACE_ON(message) || SPY_EXCLUDE(msg) ||
2242 (SPY_ExcludeDWP && (iFlag == SPY_RESULT_DEFWND16 || iFlag == SPY_RESULT_DEFWND)) )
2246 sp_e.msg_hwnd = hWnd;
2247 sp_e.lParam = lParam;
2248 sp_e.wParam = wParam;
2249 SPY_GetWndName(&sp_e);
2250 SPY_GetMsgStuff(&sp_e);
2252 if ((indent = get_indent_level()))
2254 indent -= SPY_INDENT_UNIT;
2255 set_indent_level( indent );
2260 case SPY_RESULT_DEFWND16:
2261 TRACE(" %*s(%04x) DefWindowProc16: %s [%04x] returned %08lx\n",
2262 indent, "", WIN_Handle16(hWnd), sp_e.msg_name, msg, lReturn );
2265 case SPY_RESULT_DEFWND:
2266 TRACE(" %*s(%08x) DefWindowProc32: %s [%04x] returned %08lx\n",
2267 indent, "", hWnd, sp_e.msg_name, msg, lReturn );
2270 case SPY_RESULT_OK16:
2271 TRACE(" %*s(%04x) %-16s message [%04x] %s returned %08lx\n",
2272 indent, "", WIN_Handle16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2273 sp_e.msg_name, lReturn );
2277 TRACE(" %*s(%08x) %-16s message [%04x] %s returned %08lx\n",
2278 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2279 sp_e.msg_name, lReturn );
2280 SPY_DumpStructure(&sp_e, FALSE);
2283 case SPY_RESULT_INVALIDHWND16:
2284 WARN(" %*s(%04x) %-16s message [%04x] %s HAS INVALID HWND\n",
2285 indent, "", WIN_Handle16(hWnd), debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name );
2288 case SPY_RESULT_INVALIDHWND:
2289 WARN(" %*s(%08x) %-16s message [%04x] %s HAS INVALID HWND\n",
2290 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2297 /***********************************************************************
2304 const SPY_NOTIFY *p;
2308 if (!TRACE_ON(message)) return TRUE;
2310 indent_tls_index = TlsAlloc();
2311 if(!RegOpenKeyA(HKEY_LOCAL_MACHINE, "Software\\Wine\\Wine\\Config\\Debug", &hkey))
2313 DWORD type, count = sizeof(buffer);
2316 if (!RegQueryValueExA(hkey, "SpyInclude", 0, &type, buffer, &count) &&
2317 strcmp( buffer, "INCLUDEALL" ))
2319 TRACE("Include=%s\n", buffer );
2320 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2321 SPY_Exclude[i] = (MessageTypeNames[i] && !strstr(buffer,MessageTypeNames[i]));
2324 count = sizeof(buffer);
2326 if (!RegQueryValueExA(hkey, "SpyExclude", 0, &type, buffer, &count))
2328 TRACE("Exclude=%s\n", buffer );
2329 if (!strcmp( buffer, "EXCLUDEALL" ))
2330 for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = TRUE;
2332 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2333 SPY_Exclude[i] = (MessageTypeNames[i] && strstr(buffer,MessageTypeNames[i]));
2337 count = sizeof(buffer);
2338 if(!RegQueryValueExA(hkey, "SpyExcludeDWP", 0, &type, buffer, &count))
2339 SPY_ExcludeDWP = atoi(buffer);
2344 /* find last good entry in spy notify array and save addr for b-search */
2345 p = &spnfy_array[0];
2348 if ((UINT)p->value > (UINT)j) {
2349 ERR("Notify message array out of order\n");
2350 ERR(" between values [%08x] %s and [%08x] %s\n",
2351 j, (p-1)->name, p->value, p->name);
2358 end_spnfy_array = p;
2360 /* find last good entry in each common control message array
2361 * and save addr for b-search.
2364 while (cc_array[i].classname) {
2366 j = 0x0400; /* minimum entry in array */
2367 q = cc_array[i].classmsg;
2369 if (q->value <= j) {
2370 ERR("Class message array out of order for class %s\n",
2371 debugstr_w(cc_array[i].classname));
2372 ERR(" between values [%04x] %s and [%04x] %s\n",
2373 j, (q-1)->name, q->value, q->name);
2380 cc_array[i].lastmsg = (USER_MSG *)q;