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
29 #include "wine/unicode.h"
31 #include "wine/debug.h"
35 WINE_DEFAULT_DEBUG_CHANNEL(message);
37 #define SPY_MAX_MSGNUM WM_USER
38 #define SPY_INDENT_UNIT 4 /* 4 spaces */
42 static const char * const MessageTypeNames[SPY_MAX_MSGNUM + 1] =
60 "WM_CLOSE", /* 0x10 */
76 "WM_SETCURSOR", /* 0x20 */
92 "WM_SETFONT", /* 0x30 */
104 "wm_otherwindowcreated",
105 "wm_otherwindowdestroyed",
106 "wm_activateshellwindow",
110 "wm_compacting", NULL, NULL,
111 "WM_COMMNOTIFY", NULL,
112 "WM_WINDOWPOSCHANGING", /* 0x0046 */
113 "WM_WINDOWPOSCHANGED", /* 0x0047 */
116 "WM_CANCELJOURNAL", NULL, NULL,
120 "WM_INPUTLANGCHANGEREQUEST",
121 "WM_INPUTLANGCHANGE",
125 "WM_NOTIFYFORMAT", NULL, NULL,
126 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
129 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
130 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
133 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
141 "WM_SETICON", /* 0x0080 */
142 "WM_NCCREATE", /* 0x0081 */
143 "WM_NCDESTROY", /* 0x0082 */
144 "WM_NCCALCSIZE", /* 0x0083 */
145 "WM_NCHITTEST", /* 0x0084 */
146 "WM_NCPAINT", /* 0x0085 */
147 "WM_NCACTIVATE", /* 0x0086 */
148 "WM_GETDLGCODE", /* 0x0087 */
150 "WM_SYNCTASK", NULL, NULL, NULL, NULL, NULL, NULL,
153 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
154 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
157 "WM_NCMOUSEMOVE", /* 0x00A0 */
158 "WM_NCLBUTTONDOWN", /* 0x00A1 */
159 "WM_NCLBUTTONUP", /* 0x00A2 */
160 "WM_NCLBUTTONDBLCLK", /* 0x00A3 */
161 "WM_NCRBUTTONDOWN", /* 0x00A4 */
162 "WM_NCRBUTTONUP", /* 0x00A5 */
163 "WM_NCRBUTTONDBLCLK", /* 0x00A6 */
164 "WM_NCMBUTTONDOWN", /* 0x00A7 */
165 "WM_NCMBUTTONUP", /* 0x00A8 */
166 "WM_NCMBUTTONDBLCLK", /* 0x00A9 */
167 NULL, NULL, NULL, NULL, NULL, NULL,
169 /* 0x00B0 - Win32 Edit controls */
170 "EM_GETSEL", /* 0x00b0 */
171 "EM_SETSEL", /* 0x00b1 */
172 "EM_GETRECT", /* 0x00b2 */
173 "EM_SETRECT", /* 0x00b3 */
174 "EM_SETRECTNP", /* 0x00b4 */
175 "EM_SCROLL", /* 0x00b5 */
176 "EM_LINESCROLL", /* 0x00b6 */
177 "EM_SCROLLCARET", /* 0x00b7 */
178 "EM_GETMODIFY", /* 0x00b8 */
179 "EM_SETMODIFY", /* 0x00b9 */
180 "EM_GETLINECOUNT", /* 0x00ba */
181 "EM_LINEINDEX", /* 0x00bb */
182 "EM_SETHANDLE", /* 0x00bc */
183 "EM_GETHANDLE", /* 0x00bd */
184 "EM_GETTHUMB", /* 0x00be */
188 "EM_LINELENGTH", /* 0x00c1 */
189 "EM_REPLACESEL", /* 0x00c2 */
191 "EM_GETLINE", /* 0x00c4 */
192 "EM_LIMITTEXT", /* 0x00c5 */
193 "EM_CANUNDO", /* 0x00c6 */
194 "EM_UNDO", /* 0x00c7 */
195 "EM_FMTLINES", /* 0x00c8 */
196 "EM_LINEFROMCHAR", /* 0x00c9 */
198 "EM_SETTABSTOPS", /* 0x00cb */
199 "EM_SETPASSWORDCHAR", /* 0x00cc */
200 "EM_EMPTYUNDOBUFFER", /* 0x00cd */
201 "EM_GETFIRSTVISIBLELINE", /* 0x00ce */
202 "EM_SETREADONLY", /* 0x00cf */
204 "EM_SETWORDBREAKPROC", /* 0x00d0 */
205 "EM_GETWORDBREAKPROC", /* 0x00d1 */
206 "EM_GETPASSWORDCHAR", /* 0x00d2 */
207 "EM_SETMARGINS", /* 0x00d3 */
208 "EM_GETMARGINS", /* 0x00d4 */
209 "EM_GETLIMITTEXT", /* 0x00d5 */
210 "EM_POSFROMCHAR", /* 0x00d6 */
211 "EM_CHARFROMPOS", /* 0x00d7 */
212 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
214 /* 0x00E0 - Win32 Scrollbars */
215 "SBM_SETPOS", /* 0x00e0 */
216 "SBM_GETPOS", /* 0x00e1 */
217 "SBM_SETRANGE", /* 0x00e2 */
218 "SBM_GETRANGE", /* 0x00e3 */
219 "SBM_ENABLE_ARROWS", /* 0x00e4 */
221 "SBM_SETRANGEREDRAW", /* 0x00e6 */
223 "SBM_SETSCROLLINFO", /* 0x00e9 */
224 "SBM_GETSCROLLINFO", /* 0x00ea */
225 NULL, NULL, NULL, NULL, NULL,
227 /* 0x00F0 - Win32 Buttons */
228 "BM_GETCHECK", /* 0x00f0 */
229 "BM_SETCHECK", /* 0x00f1 */
230 "BM_GETSTATE", /* 0x00f2 */
231 "BM_SETSTATE", /* 0x00f3 */
232 "BM_SETSTYLE", /* 0x00f4 */
233 "BM_CLICK", /* 0x00f5 */
234 "BM_GETIMAGE", /* 0x00f6 */
235 "BM_SETIMAGE", /* 0x00f7 */
236 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
238 "WM_KEYDOWN", /* 0x0100 */
239 "WM_KEYUP", /* 0x0101 */
240 "WM_CHAR", /* 0x0102 */
241 "WM_DEADCHAR", /* 0x0103 */
242 "WM_SYSKEYDOWN", /* 0x0104 */
243 "WM_SYSKEYUP", /* 0x0105 */
244 "WM_SYSCHAR", /* 0x0106 */
245 "WM_SYSDEADCHAR", /* 0x0107 */
246 "WM_KEYLAST", /* 0x0108 */
251 "WM_IME_STARTCOMPOSITION", /* 0x010d */
252 "WM_IME_ENDCOMPOSITION", /* 0x010e */
253 "WM_IME_COMPOSITION", /* 0x010f */
255 "WM_INITDIALOG", /* 0x0110 */
256 "WM_COMMAND", /* 0x0111 */
257 "WM_SYSCOMMAND", /* 0x0112 */
258 "WM_TIMER", /* 0x0113 */
259 "WM_HSCROLL", /* 0x0114 */
260 "WM_VSCROLL", /* 0x0115 */
261 "WM_INITMENU", /* 0x0116 */
262 "WM_INITMENUPOPUP", /* 0x0117 */
263 "WM_SYSTIMER", /* 0x0118 */
264 NULL, NULL, NULL, NULL, NULL, NULL,
265 "WM_MENUSELECT", /* 0x011f */
267 "WM_MENUCHAR", /* 0x0120 */
268 "WM_ENTERIDLE", /* 0x0121 */
270 "WM_MENURBUTTONUP", /* 0x0122 */
271 "WM_MENUDRAG", /* 0x0123 */
272 "WM_MENUGETOBJECT", /* 0x0124 */
273 "WM_UNINITMENUPOPUP", /* 0x0125 */
274 "WM_MENUCOMMAND", /* 0x0126 */
275 "WM_CHANGEUISTATE", /* 0x0127 */
276 "WM_UPDATEUISTATE", /* 0x0128 */
277 "WM_QUERYUISTATE", /* 0x0129 */
279 NULL, NULL, NULL, NULL, NULL, NULL,
283 "WM_LBTRACKPOINT", /* 0x0131 */
284 "WM_CTLCOLORMSGBOX", /* 0x0132 */
285 "WM_CTLCOLOREDIT", /* 0x0133 */
286 "WM_CTLCOLORLISTBOX", /* 0x0134 */
287 "WM_CTLCOLORBTN", /* 0x0135 */
288 "WM_CTLCOLORDLG", /* 0x0136 */
289 "WM_CTLCOLORSCROLLBAR", /* 0x0137 */
290 "WM_CTLCOLORSTATIC", /* 0x0138 */
291 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
293 /* 0x0140 - Win32 Comboboxes */
294 "CB_GETEDITSEL", /* 0x0140 */
295 "CB_LIMITTEXT", /* 0x0141 */
296 "CB_SETEDITSEL", /* 0x0142 */
297 "CB_ADDSTRING", /* 0x0143 */
298 "CB_DELETESTRING", /* 0x0144 */
299 "CB_DIR", /* 0x0145 */
300 "CB_GETCOUNT", /* 0x0146 */
301 "CB_GETCURSEL", /* 0x0147 */
302 "CB_GETLBTEXT", /* 0x0148 */
303 "CB_GETLBTEXTLEN", /* 0x0149 */
304 "CB_INSERTSTRING", /* 0x014a */
305 "CB_RESETCONTENT", /* 0x014b */
306 "CB_FINDSTRING", /* 0x014c */
307 "CB_SELECTSTRING", /* 0x014d */
308 "CB_SETCURSEL", /* 0x014e */
309 "CB_SHOWDROPDOWN", /* 0x014f */
311 "CB_GETITEMDATA", /* 0x0150 */
312 "CB_SETITEMDATA", /* 0x0151 */
313 "CB_GETDROPPEDCONTROLRECT", /* 0x0152 */
314 "CB_SETITEMHEIGHT", /* 0x0153 */
315 "CB_GETITEMHEIGHT", /* 0x0154 */
316 "CB_SETEXTENDEDUI", /* 0x0155 */
317 "CB_GETEXTENDEDUI", /* 0x0156 */
318 "CB_GETDROPPEDSTATE", /* 0x0157 */
319 "CB_FINDSTRINGEXACT", /* 0x0158 */
320 "CB_SETLOCALE", /* 0x0159 */
321 "CB_GETLOCALE", /* 0x015a */
322 "CB_GETTOPINDEX", /* 0x015b */
323 "CB_SETTOPINDEX", /* 0x015c */
324 "CB_GETHORIZONTALEXTENT", /* 0x015d */
325 "CB_SETHORIZONTALEXTENT", /* 0x015e */
326 "CB_GETDROPPEDWIDTH", /* 0x015f */
328 "CB_SETDROPPEDWIDTH", /* 0x0160 */
329 "CB_INITSTORAGE", /* 0x0161 */
330 NULL, NULL, NULL, NULL, NULL, NULL,
331 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
333 /* 0x0170 - Win32 Static controls */
334 "STM_SETICON", /* 0x0170 */
335 "STM_GETICON", /* 0x0171 */
336 "STM_SETIMAGE", /* 0x0172 */
337 "STM_GETIMAGE", /* 0x0173 */
338 NULL, NULL, NULL, NULL,
339 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
341 /* 0x0180 - Win32 Listboxes */
342 "LB_ADDSTRING", /* 0x0180 */
343 "LB_INSERTSTRING", /* 0x0181 */
344 "LB_DELETESTRING", /* 0x0182 */
345 "LB_SELITEMRANGEEX", /* 0x0183 */
346 "LB_RESETCONTENT", /* 0x0184 */
347 "LB_SETSEL", /* 0x0185 */
348 "LB_SETCURSEL", /* 0x0186 */
349 "LB_GETSEL", /* 0x0187 */
350 "LB_GETCURSEL", /* 0x0188 */
351 "LB_GETTEXT", /* 0x0189 */
352 "LB_GETTEXTLEN", /* 0x018a */
353 "LB_GETCOUNT", /* 0x018b */
354 "LB_SELECTSTRING", /* 0x018c */
355 "LB_DIR", /* 0x018d */
356 "LB_GETTOPINDEX", /* 0x018e */
357 "LB_FINDSTRING", /* 0x018f */
359 "LB_GETSELCOUNT", /* 0x0190 */
360 "LB_GETSELITEMS", /* 0x0191 */
361 "LB_SETTABSTOPS", /* 0x0192 */
362 "LB_GETHORIZONTALEXTENT", /* 0x0193 */
363 "LB_SETHORIZONTALEXTENT", /* 0x0194 */
364 "LB_SETCOLUMNWIDTH", /* 0x0195 */
365 "LB_ADDFILE", /* 0x0196 */
366 "LB_SETTOPINDEX", /* 0x0197 */
367 "LB_GETITEMRECT", /* 0x0198 */
368 "LB_GETITEMDATA", /* 0x0199 */
369 "LB_SETITEMDATA", /* 0x019a */
370 "LB_SELITEMRANGE", /* 0x019b */
371 "LB_SETANCHORINDEX", /* 0x019c */
372 "LB_GETANCHORINDEX", /* 0x019d */
373 "LB_SETCARETINDEX", /* 0x019e */
374 "LB_GETCARETINDEX", /* 0x019f */
376 "LB_SETITEMHEIGHT", /* 0x01a0 */
377 "LB_GETITEMHEIGHT", /* 0x01a1 */
378 "LB_FINDSTRINGEXACT", /* 0x01a2 */
379 "LB_CARETON", /* 0x01a3 */
380 "LB_CARETOFF", /* 0x01a4 */
381 "LB_SETLOCALE", /* 0x01a5 */
382 "LB_GETLOCALE", /* 0x01a6 */
383 "LB_SETCOUNT", /* 0x01a7 */
384 "LB_INITSTORAGE", /* 0x01a8 */
385 "LB_ITEMFROMPOINT", /* 0x01a9 */
386 NULL, NULL, NULL, NULL, NULL, NULL,
389 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
390 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
393 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
394 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
397 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
398 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
401 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
402 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
405 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
406 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
408 "WM_MOUSEMOVE", /* 0x0200 */
409 "WM_LBUTTONDOWN", /* 0x0201 */
410 "WM_LBUTTONUP", /* 0x0202 */
411 "WM_LBUTTONDBLCLK", /* 0x0203 */
412 "WM_RBUTTONDOWN", /* 0x0204 */
413 "WM_RBUTTONUP", /* 0x0205 */
414 "WM_RBUTTONDBLCLK", /* 0x0206 */
415 "WM_MBUTTONDOWN", /* 0x0207 */
416 "WM_MBUTTONUP", /* 0x0208 */
417 "WM_MBUTTONDBLCLK", /* 0x0209 */
418 "WM_MOUSEWHEEL", /* 0x020A */
419 NULL, NULL, NULL, NULL, NULL,
421 "WM_PARENTNOTIFY", /* 0x0210 */
422 "WM_ENTERMENULOOP", /* 0x0211 */
423 "WM_EXITMENULOOP", /* 0x0212 */
424 "WM_NEXTMENU", /* 0x0213 */
429 "WM_DEVICECHANGE", NULL, NULL, NULL, NULL, NULL, NULL,
431 "WM_MDICREATE", /* 0x0220 */
432 "WM_MDIDESTROY", /* 0x0221 */
433 "WM_MDIACTIVATE", /* 0x0222 */
434 "WM_MDIRESTORE", /* 0x0223 */
435 "WM_MDINEXT", /* 0x0224 */
436 "WM_MDIMAXIMIZE", /* 0x0225 */
437 "WM_MDITILE", /* 0x0226 */
438 "WM_MDICASCADE", /* 0x0227 */
439 "WM_MDIICONARRANGE", /* 0x0228 */
440 "WM_MDIGETACTIVE", /* 0x0229 */
443 "WM_QUERYDROPOBJECT",
450 "WM_MDISETMENU", /* 0x0230 */
451 "WM_ENTERSIZEMOVE", /* 0x0231 */
452 "WM_EXITSIZEMOVE", /* 0x0232 */
453 "WM_DROPFILES", /* 0x0233 */
454 "WM_MDIREFRESHMENU", NULL, NULL, NULL,
456 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
459 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
460 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
463 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
464 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,
470 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
473 NULL, "WM_IME_SETCONTEXT", "WM_IME_NOTIFY", "WM_IME_CONTROL", "WM_IME_COMPOSITIONFULL", "WM_IME_SELECT", "WM_IME_CHAR", NULL,
474 "WM_IME_REQUEST", NULL, NULL, NULL, NULL, NULL, NULL, NULL,
475 "WM_IME_KEYDOWN", "WM_IME_KEYUP", NULL, NULL, NULL, NULL, NULL, NULL,
476 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
479 NULL, "WM_MOUSEHOVER", NULL, "WM_MOUSELEAVE", NULL, NULL, NULL, NULL,
480 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
481 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
482 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,
488 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,
493 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
495 "WM_CUT", /* 0x0300 */
501 "WM_RENDERALLFORMATS",
502 "WM_DESTROYCLIPBOARD",
505 "WM_VSCROLLCLIPBOARD",
507 "WM_ASKCBFORMATNAME",
509 "WM_HSCROLLCLIPBOARD",
510 "WM_QUERYNEWPALETTE", /* 0x030f*/
512 "WM_PALETTEISCHANGING",
514 "WM_HOTKEY", /* 0x0312 */
515 NULL, NULL, NULL, NULL,
518 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,
523 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,
529 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
531 "WM_QUERYAFXWNDPROC", /* 0x0360 */
532 "WM_SIZEPARENT", /* 0x0361 */
533 "WM_SETMESSAGESTRING", /* 0x0362 */
534 "WM_IDLEUPDATECMDUI", /* 0x0363 */
535 "WM_INITIALUPDATE", /* 0x0364 */
536 "WM_COMMANDHELP", /* 0x0365 */
537 "WM_HELPHITTEST", /* 0x0366 */
538 "WM_EXITHELPMODE", /* 0x0367 */
539 "WM_RECALCPARENT", /* 0x0368 */
540 "WM_SIZECHILD", /* 0x0369 */
541 "WM_KICKIDLE", /* 0x036A */
542 "WM_QUERYCENTERWND", /* 0x036B */
543 "WM_DISABLEMODAL", /* 0x036C */
544 "WM_FLOATSTATUS", /* 0x036D */
545 "WM_ACTIVATETOPLEVEL", /* 0x036E */
546 "WM_QUERY3DCONTROLS", /* 0x036F */
548 "WM_SOCKET_NOTIFY", /* 0x0373 */
549 "WM_SOCKET_DEAD", /* 0x0374 */
550 "WM_POPMESSAGESTRING", /* 0x0375 */
551 "WM_OCC_LOADFROMSTREAM", /* 0x0376 */
552 "WM_OCC_LOADFROMSTORAGE", /* 0x0377 */
553 "WM_OCC_INITNEW", /* 0x0378 */
554 "WM_QUEUE_SENTINEL", /* 0x0379 */
555 "WM_OCC_LOADFROMSTREAM_EX", /* 0x037A */
556 "WM_OCC_LOADFROMSTORAGE_EX", /* 0x037B */
560 "WM_PENWINFIRST", /* 0x0380 */
561 "WM_RCRESULT", /* 0x0381 */
562 "WM_HOOKRCRESULT", /* 0x0382 */
563 "WM_GLOBALRCCHANGE", /* 0x0383 */
564 "WM_SKB", /* 0x0384 */
565 "WM_HEDITCTL", /* 0x0385 */
567 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
568 "WM_PENWINLAST", /* 0x038F */
570 "WM_COALESCE_FIRST", /* 0x0390 */
571 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
572 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
573 "WM_COALESCE_LAST", /* 0x039F */
580 NULL, NULL, NULL, NULL,
581 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
584 NULL, NULL, NULL, NULL, NULL,
608 NULL, NULL, NULL, NULL, NULL, NULL,
609 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
610 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
613 "WM_DDE_INITIATE", /* 0x3E0 */
614 "WM_DDE_TERMINATE", /* 0x3E1 */
615 "WM_DDE_ADVISE", /* 0x3E2 */
616 "WM_DDE_UNADVISE", /* 0x3E3 */
617 "WM_DDE_ACK", /* 0x3E4 */
618 "WM_DDE_DATA", /* 0x3E5 */
619 "WM_DDE_REQUEST", /* 0x3E6 */
620 "WM_DDE_POKE", /* 0x3E7 */
621 "WM_DDE_EXECUTE", /* 0x3E8 */
622 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
626 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
627 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
629 "WM_USER" /* 0x0400 */
633 #define SPY_MAX_LVMMSGNUM 140
634 static const char * const LVMMessageTypeNames[SPY_MAX_LVMMSGNUM + 1] =
636 "LVM_GETBKCOLOR", /* 1000 */
645 "LVM_DELETEALLITEMS",
646 "LVM_GETCALLBACKMASK",
647 "LVM_SETCALLBACKMASK",
651 "LVM_SETITEMPOSITION",
652 "LVM_GETITEMPOSITION",
653 "LVM_GETSTRINGWIDTHA",
660 "LVM_GETEDITCONTROL",
665 "LVM_GETCOLUMNWIDTH",
666 "LVM_SETCOLUMNWIDTH",
669 "LVM_CREATEDRAGIMAGE",
673 "LVM_GETTEXTBKCOLOR",
674 "LVM_SETTEXTBKCOLOR",
676 "LVM_GETCOUNTPERPAGE",
685 "LVM_SETITEMPOSITION32",
686 "LVM_GETSELECTEDCOUNT",
687 "LVM_GETITEMSPACING",
688 "LVM_GETISEARCHSTRINGA",
689 "LVM_SETICONSPACING",
690 "LVM_SETEXTENDEDLISTVIEWSTYLE",
691 "LVM_GETEXTENDEDLISTVIEWSTYLE",
692 "LVM_GETSUBITEMRECT",
693 "LVM_SUBITEMHITTEST",
694 "LVM_SETCOLUMNORDERARRAY",
695 "LVM_GETCOLUMNORDERARRAY",
700 "LVM_APPROXIMATEVIEWRECT",
702 "LVM_GETSELECTIONMARK",
703 "LVM_SETSELECTIONMARK",
709 "LVM_GETNUMBEROFWORKAREAS",
723 "LVM_GETSTRINGWIDTHW",
753 "LVM_GETISEARCHSTRINGW",
776 "LVM_GETBKIMAGEW" /* 0x108B */
780 #define SPY_MAX_TVMSGNUM 65
781 static const char * const TVMessageTypeNames[SPY_MAX_TVMSGNUM + 1] =
783 "TVM_INSERTITEMA", /* 1100 */
798 "TVM_GETEDITCONTROL",
799 "TVM_GETVISIBLECOUNT",
801 "TVM_CREATEDRAGIMAGE",
804 "TVM_SORTCHILDRENCB",
805 "TVM_ENDEDITLABELNOW",
806 "TVM_GETISEARCHSTRINGA",
820 "TVM_SETINSERTMARKCOLOR",
821 "TVM_GETINSERTMARKCOLOR",
847 "TVM_GETISEARCHSTRINGW",
852 #define SPY_MAX_HDMMSGNUM 19
853 static const char * const HDMMessageTypeNames[SPY_MAX_HDMMSGNUM + 1] =
855 "HDM_GETITEMCOUNT", /* 1200 */
871 "HDM_CREATEDRAGIMAGE",
872 "GETORDERARRAYINDEX",
873 "SETORDERARRAYINDEX",
878 #define SPY_MAX_TCMMSGNUM 62
879 static const char * const TCMMessageTypeNames[SPY_MAX_TCMMSGNUM + 1] =
890 "TCM_DELETEALLITEMS",
930 "TCM_SETMINTABWIDTH",
933 "TCM_SETEXTENDEDSTYLE",
934 "TCM_GETEXTENDEDSTYLE",
946 #define SPY_MAX_PGMMSGNUM 13
947 static const char * const PGMMessageTypeNames[SPY_MAX_PGMMSGNUM + 1] =
961 "PGM_GETBUTTONSTATE",
966 #define SPY_MAX_CCMMSGNUM 9
967 static const char * const CCMMessageTypeNames[SPY_MAX_CCMMSGNUM + 1] =
971 "CCM_SETCOLORSCHEME",
972 "CCM_GETCOLORSCHEME",
974 "CCM_SETUNICODEFORMAT",
975 "CCM_GETUNICODEFORMAT",
978 "CCM_SETNOTIFYWINDOW"
981 #define SPY_MAX_WINEMSGNUM 6
982 static const char * const WINEMessageTypeNames[SPY_MAX_WINEMSGNUM + 1] =
984 "WM_WINE_DESTROYWINDOW",
985 "WM_WINE_SETWINDOWPOS",
986 "WM_WINE_SHOWWINDOW",
988 "WM_WINE_SETWINDOWLONG",
989 "WM_WINE_ENABLEWINDOW"
992 /* Virtual key names */
993 #define SPY_MAX_VKKEYSNUM 255
994 static const char * const VK_KeyNames[SPY_MAX_VKKEYSNUM + 1] =
997 "VK_LBUTTON", /* 0x01 */
998 "VK_RBUTTON", /* 0x02 */
999 "VK_CANCEL", /* 0x03 */
1000 "VK_MBUTTON", /* 0x04 */
1004 "VK_BACK", /* 0x08 */
1005 "VK_TAB", /* 0x09 */
1008 "VK_CLEAR", /* 0x0C */
1009 "VK_RETURN", /* 0x0D */
1012 "VK_SHIFT", /* 0x10 */
1013 "VK_CONTROL", /* 0x11 */
1014 "VK_MENU", /* 0x12 */
1015 "VK_PAUSE", /* 0x13 */
1016 "VK_CAPITAL", /* 0x14 */
1023 "VK_ESCAPE", /* 0x1B */
1028 "VK_SPACE", /* 0x20 */
1029 "VK_PRIOR", /* 0x21 */
1030 "VK_NEXT", /* 0x22 */
1031 "VK_END", /* 0x23 */
1032 "VK_HOME", /* 0x24 */
1033 "VK_LEFT", /* 0x25 */
1035 "VK_RIGHT", /* 0x27 */
1036 "VK_DOWN", /* 0x28 */
1037 "VK_SELECT", /* 0x29 */
1038 "VK_PRINT", /* 0x2A */
1039 "VK_EXECUTE", /* 0x2B */
1040 "VK_SNAPSHOT", /* 0x2C */
1041 "VK_INSERT", /* 0x2D */
1042 "VK_DELETE", /* 0x2E */
1043 "VK_HELP", /* 0x2F */
1087 "VK_LWIN", /* 0x5B */
1088 "VK_RWIN", /* 0x5C */
1089 "VK_APPS", /* 0x5D */
1092 "VK_NUMPAD0", /* 0x60 */
1093 "VK_NUMPAD1", /* 0x61 */
1094 "VK_NUMPAD2", /* 0x62 */
1095 "VK_NUMPAD3", /* 0x63 */
1096 "VK_NUMPAD4", /* 0x64 */
1097 "VK_NUMPAD5", /* 0x65 */
1098 "VK_NUMPAD6", /* 0x66 */
1099 "VK_NUMPAD7", /* 0x67 */
1100 "VK_NUMPAD8", /* 0x68 */
1101 "VK_NUMPAD9", /* 0x69 */
1102 "VK_MULTIPLY", /* 0x6A */
1103 "VK_ADD", /* 0x6B */
1104 "VK_SEPARATOR", /* 0x6C */
1105 "VK_SUBTRACT", /* 0x6D */
1106 "VK_DECIMAL", /* 0x6E */
1107 "VK_DIVIDE", /* 0x6F */
1117 "VK_F10", /* 0x79 */
1118 "VK_F11", /* 0x7A */
1119 "VK_F12", /* 0x7B */
1120 "VK_F13", /* 0x7C */
1121 "VK_F14", /* 0x7D */
1122 "VK_F15", /* 0x7E */
1123 "VK_F16", /* 0x7F */
1124 "VK_F17", /* 0x80 */
1125 "VK_F18", /* 0x81 */
1126 "VK_F19", /* 0x82 */
1127 "VK_F20", /* 0x83 */
1128 "VK_F21", /* 0x84 */
1129 "VK_F22", /* 0x85 */
1130 "VK_F23", /* 0x86 */
1131 "VK_F24", /* 0x87 */
1140 "VK_NUMLOCK", /* 0x90 */
1141 "VK_SCROLL", /* 0x91 */
1156 "VK_LSHIFT", /* 0xA0 */
1157 "VK_RSHIFT", /* 0xA1 */
1158 "VK_LCONTROL", /* 0xA2 */
1159 "VK_RCONTROL", /* 0xA3 */
1160 "VK_LMENU", /* 0xA4 */
1161 "VK_RMENU", /* 0xA5 */
1182 "VK_OEM_1", /* 0xBA */
1183 "VK_OEM_PLUS", /* 0xBB */
1184 "VK_OEM_COMMA", /* 0xBC */
1185 "VK_OEM_MINUS", /* 0xBD */
1186 "VK_OEM_PERIOD", /* 0xBE */
1187 "VK_OEM_2", /* 0xBF */
1188 "VK_OEM_3", /* 0xC0 */
1215 "VK_OEM_4", /* 0xDB */
1216 "VK_OEM_5", /* 0xDC */
1217 "VK_OEM_6", /* 0xDD */
1218 "VK_OEM_7", /* 0xDE */
1219 "VK_OEM_8", /* 0xDF */
1221 "VK_OEM_AX", /* 0xE1 */
1222 "VK_OEM_102", /* 0xE2 */
1223 "VK_ICO_HELP", /* 0xE3 */
1224 "VK_ICO_00", /* 0xE4 */
1225 "VK_PROCESSKEY", /* 0xE5 */
1242 "VK_ATTN", /* 0xF6 */
1243 "VK_CRSEL", /* 0xF7 */
1244 "VK_EXSEL", /* 0xF8 */
1245 "VK_EREOF", /* 0xF9 */
1246 "VK_PLAY", /* 0xFA */
1247 "VK_ZOOM", /* 0xFB */
1248 "VK_NONAME", /* 0xFC */
1249 "VK_PA1", /* 0xFD */
1250 "VK_OEM_CLEAR", /* 0xFE */
1255 /************************************************************************/
1258 /* WM_USER+n message values for "common controls" */
1262 const char *name; /* name of control message */
1263 UINT value; /* message number (0x0401-0x0fff */
1264 UINT len; /* length of space at lParam to dump */
1270 const WCHAR *classname; /* class name to match */
1271 const USER_MSG *classmsg; /* pointer to first USER_MSG for class */
1272 USER_MSG *lastmsg; /* pointer to last USER_MSG for class */
1275 #define USM(a,b) { #a ,a,b}
1276 #define SZOF(a) sizeof(a)
1278 /* To dump memory at the lParam for any of these messages, */
1279 /* replace the "0" with a "SZOF(structure)", or with a */
1280 /* number. (First method prefered.) */
1282 static const USER_MSG rebar_array[] = {
1283 USM(RB_INSERTBANDA, 0),
1284 USM(RB_DELETEBAND, 0),
1285 USM(RB_GETBARINFO, 0),
1286 USM(RB_SETBARINFO, 0),
1287 USM(RB_GETBANDINFO, 0),
1288 USM(RB_SETBANDINFOA, 0),
1289 USM(RB_SETPARENT, 0),
1292 USM(RB_INSERTBANDW, 0),
1293 USM(RB_SETBANDINFOW, 0),
1294 USM(RB_GETBANDCOUNT, 0),
1295 USM(RB_GETROWCOUNT, 0),
1296 USM(RB_GETROWHEIGHT, 0),
1297 USM(RB_IDTOINDEX, 0),
1298 USM(RB_GETTOOLTIPS, 0),
1299 USM(RB_SETTOOLTIPS, 0),
1300 USM(RB_SETBKCOLOR, 0),
1301 USM(RB_GETBKCOLOR, 0),
1302 USM(RB_SETTEXTCOLOR, 0),
1303 USM(RB_GETTEXTCOLOR, 0),
1304 USM(RB_SIZETORECT, 0),
1305 USM(RB_BEGINDRAG, 0),
1307 USM(RB_DRAGMOVE, 0),
1308 USM(RB_GETBARHEIGHT, 0),
1309 USM(RB_GETBANDINFOW, 0),
1310 USM(RB_GETBANDINFOA, 0),
1311 USM(RB_MINIMIZEBAND, 0),
1312 USM(RB_MAXIMIZEBAND, 0),
1313 USM(RB_GETBANDBORDERS, 0),
1314 USM(RB_SHOWBAND, 0),
1315 USM(RB_SETPALETTE, 0),
1316 USM(RB_GETPALETTE, 0),
1317 USM(RB_MOVEBAND, 0),
1320 static const USER_MSG toolbar_array[] = {
1321 USM(TB_ENABLEBUTTON ,0),
1322 USM(TB_CHECKBUTTON ,0),
1323 USM(TB_PRESSBUTTON ,0),
1324 USM(TB_HIDEBUTTON ,0),
1325 USM(TB_INDETERMINATE ,0),
1326 USM(TB_MARKBUTTON ,0),
1327 USM(TB_ISBUTTONENABLED ,0),
1328 USM(TB_ISBUTTONCHECKED ,0),
1329 USM(TB_ISBUTTONPRESSED ,0),
1330 USM(TB_ISBUTTONHIDDEN ,0),
1331 USM(TB_ISBUTTONINDETERMINATE ,0),
1332 USM(TB_ISBUTTONHIGHLIGHTED ,0),
1333 USM(TB_SETSTATE ,0),
1334 USM(TB_GETSTATE ,0),
1335 USM(TB_ADDBITMAP ,0),
1336 USM(TB_ADDBUTTONSA ,0),
1337 USM(TB_INSERTBUTTONA ,0),
1338 USM(TB_DELETEBUTTON ,0),
1339 USM(TB_GETBUTTON ,0),
1340 USM(TB_BUTTONCOUNT ,0),
1341 USM(TB_COMMANDTOINDEX ,0),
1342 USM(TB_SAVERESTOREA ,0),
1343 USM(TB_CUSTOMIZE ,0),
1344 USM(TB_ADDSTRINGA ,0),
1345 USM(TB_GETITEMRECT ,0),
1346 USM(TB_BUTTONSTRUCTSIZE ,0),
1347 USM(TB_SETBUTTONSIZE ,0),
1348 USM(TB_SETBITMAPSIZE ,0),
1349 USM(TB_AUTOSIZE ,0),
1350 USM(TB_GETTOOLTIPS ,0),
1351 USM(TB_SETTOOLTIPS ,0),
1352 USM(TB_SETPARENT ,0),
1355 USM(TB_GETBITMAPFLAGS ,0),
1356 USM(TB_SETCMDID ,0),
1357 USM(TB_CHANGEBITMAP ,0),
1358 USM(TB_GETBITMAP ,0),
1359 USM(TB_GETBUTTONTEXTA ,0),
1360 USM(TB_REPLACEBITMAP ,0),
1361 USM(TB_SETINDENT ,0),
1362 USM(TB_SETIMAGELIST ,0),
1363 USM(TB_GETIMAGELIST ,0),
1364 USM(TB_LOADIMAGES ,0),
1366 USM(TB_SETHOTIMAGELIST ,0),
1367 USM(TB_GETHOTIMAGELIST ,0),
1368 USM(TB_SETDISABLEDIMAGELIST ,0),
1369 USM(TB_GETDISABLEDIMAGELIST ,0),
1370 USM(TB_SETSTYLE ,0),
1371 USM(TB_GETSTYLE ,0),
1372 USM(TB_GETBUTTONSIZE ,0),
1373 USM(TB_SETBUTTONWIDTH ,0),
1374 USM(TB_SETMAXTEXTROWS ,0),
1375 USM(TB_GETTEXTROWS ,0),
1376 USM(TB_GETOBJECT ,0),
1377 USM(TB_GETBUTTONINFOW ,0),
1378 USM(TB_SETBUTTONINFOW ,0),
1379 USM(TB_GETBUTTONINFOA ,0),
1380 USM(TB_SETBUTTONINFOA ,0),
1381 USM(TB_INSERTBUTTONW ,0),
1382 USM(TB_ADDBUTTONSW ,0),
1384 USM(TB_SETDRAWTEXTFLAGS ,0),
1385 USM(TB_GETHOTITEM ,0),
1386 USM(TB_SETHOTITEM ,0),
1387 USM(TB_SETANCHORHIGHLIGHT ,0),
1388 USM(TB_GETANCHORHIGHLIGHT ,0),
1389 USM(TB_GETBUTTONTEXTW ,0),
1390 USM(TB_SAVERESTOREW ,0),
1391 USM(TB_ADDSTRINGW ,0),
1392 USM(TB_MAPACCELERATORA ,0),
1393 USM(TB_GETINSERTMARK ,0),
1394 USM(TB_SETINSERTMARK ,0),
1395 USM(TB_INSERTMARKHITTEST ,0),
1396 USM(TB_MOVEBUTTON ,0),
1397 USM(TB_GETMAXSIZE ,0),
1398 USM(TB_SETEXTENDEDSTYLE ,0),
1399 USM(TB_GETEXTENDEDSTYLE ,0),
1400 USM(TB_GETPADDING ,0),
1401 USM(TB_SETPADDING ,0),
1402 USM(TB_SETINSERTMARKCOLOR ,0),
1403 USM(TB_GETINSERTMARKCOLOR ,0),
1404 USM(TB_MAPACCELERATORW ,0),
1405 USM(TB_GETSTRINGW ,0),
1406 USM(TB_GETSTRINGA ,0),
1407 USM(TB_UNKWN45D ,8),
1408 USM(TB_UNKWN45E ,0),
1409 USM(TB_UNKWN460 ,0),
1410 USM(TB_UNKWN463 ,8),
1411 USM(TB_UNKWN464 ,0),
1414 static const USER_MSG tooltips_array[] = {
1415 USM(TTM_ACTIVATE ,0),
1416 USM(TTM_SETDELAYTIME ,0),
1417 USM(TTM_ADDTOOLA ,0),
1418 USM(TTM_DELTOOLA ,0),
1419 USM(TTM_NEWTOOLRECTA ,0),
1420 USM(TTM_RELAYEVENT ,0),
1421 USM(TTM_GETTOOLINFOA ,0),
1422 USM(TTM_HITTESTA ,0),
1423 USM(TTM_GETTEXTA ,0),
1424 USM(TTM_UPDATETIPTEXTA ,0),
1425 USM(TTM_GETTOOLCOUNT ,0),
1426 USM(TTM_ENUMTOOLSA ,0),
1427 USM(TTM_GETCURRENTTOOLA ,0),
1428 USM(TTM_WINDOWFROMPOINT ,0),
1429 USM(TTM_TRACKACTIVATE ,0),
1430 USM(TTM_TRACKPOSITION ,0),
1431 USM(TTM_SETTIPBKCOLOR ,0),
1432 USM(TTM_SETTIPTEXTCOLOR ,0),
1433 USM(TTM_GETDELAYTIME ,0),
1434 USM(TTM_GETTIPBKCOLOR ,0),
1435 USM(TTM_GETTIPTEXTCOLOR ,0),
1436 USM(TTM_SETMAXTIPWIDTH ,0),
1437 USM(TTM_GETMAXTIPWIDTH ,0),
1438 USM(TTM_SETMARGIN ,0),
1439 USM(TTM_GETMARGIN ,0),
1442 USM(TTM_GETBUBBLESIZE ,0),
1443 USM(TTM_ADDTOOLW ,0),
1444 USM(TTM_DELTOOLW ,0),
1445 USM(TTM_NEWTOOLRECTW ,0),
1446 USM(TTM_GETTOOLINFOW ,0),
1447 USM(TTM_SETTOOLINFOW ,0),
1448 USM(TTM_HITTESTW ,0),
1449 USM(TTM_GETTEXTW ,0),
1450 USM(TTM_UPDATETIPTEXTW ,0),
1451 USM(TTM_ENUMTOOLSW ,0),
1452 USM(TTM_GETCURRENTTOOLW ,0),
1455 static const USER_MSG comboex_array[] = {
1456 USM(CBEM_INSERTITEMA ,0),
1457 USM(CBEM_SETIMAGELIST ,0),
1458 USM(CBEM_GETIMAGELIST ,0),
1459 USM(CBEM_GETITEMA ,0),
1460 USM(CBEM_SETITEMA ,0),
1461 USM(CBEM_GETCOMBOCONTROL ,0),
1462 USM(CBEM_GETEDITCONTROL ,0),
1463 USM(CBEM_SETEXSTYLE ,0),
1464 USM(CBEM_GETEXTENDEDSTYLE ,0),
1465 USM(CBEM_HASEDITCHANGED ,0),
1466 USM(CBEM_INSERTITEMW ,0),
1467 USM(CBEM_SETITEMW ,0),
1468 USM(CBEM_GETITEMW ,0),
1469 USM(CBEM_SETEXTENDEDSTYLE ,0),
1472 static const USER_MSG propsht_array[] = {
1473 USM(PSM_SETCURSEL ,0),
1474 USM(PSM_REMOVEPAGE ,0),
1475 USM(PSM_ADDPAGE ,0),
1476 USM(PSM_CHANGED ,0),
1477 USM(PSM_RESTARTWINDOWS ,0),
1478 USM(PSM_REBOOTSYSTEM ,0),
1479 USM(PSM_CANCELTOCLOSE ,0),
1480 USM(PSM_QUERYSIBLINGS ,0),
1481 USM(PSM_UNCHANGED ,0),
1483 USM(PSM_SETTITLEA ,0),
1484 USM(PSM_SETWIZBUTTONS ,0),
1485 USM(PSM_PRESSBUTTON ,0),
1486 USM(PSM_SETCURSELID ,0),
1487 USM(PSM_SETFINISHTEXTA ,0),
1488 USM(PSM_GETTABCONTROL ,0),
1489 USM(PSM_ISDIALOGMESSAGE ,0),
1490 USM(PSM_GETCURRENTPAGEHWND ,0),
1491 USM(PSM_SETTITLEW ,0),
1492 USM(PSM_SETFINISHTEXTW ,0),
1494 const WCHAR PropSheetInfoStr[] =
1495 {'P','r','o','p','e','r','t','y','S','h','e','e','t','I','n','f','o',0 };
1497 static const USER_MSG updown_array[] = {
1498 USM(UDM_SETRANGE ,0),
1499 USM(UDM_GETRANGE ,0),
1502 USM(UDM_SETBUDDY ,0),
1503 USM(UDM_GETBUDDY ,0),
1504 USM(UDM_SETACCEL ,0),
1505 USM(UDM_GETACCEL ,0),
1506 USM(UDM_SETBASE ,0),
1507 USM(UDM_GETBASE ,0),
1508 USM(UDM_SETRANGE32 ,0),
1509 USM(UDM_GETRANGE32 ,0),
1510 USM(UDM_SETPOS32 ,0),
1511 USM(UDM_GETPOS32 ,0),
1517 static CONTROL_CLASS cc_array[] = {
1518 {WC_COMBOBOXEXW, comboex_array, 0},
1519 {WC_PROPSHEETW, propsht_array, 0},
1520 {REBARCLASSNAMEW, rebar_array, 0},
1521 {TOOLBARCLASSNAMEW, toolbar_array, 0},
1522 {TOOLTIPS_CLASSW, tooltips_array, 0},
1523 {UPDOWN_CLASSW, updown_array, 0},
1527 /************************************************************************/
1530 /* WM_NOTIFY function codes display */
1534 const char *name; /* name of notify message */
1535 UINT value; /* notify code value */
1536 UINT len; /* length of extra space to dump */
1539 #define SPNFY(a,b) { #a ,a,sizeof(b)-sizeof(NMHDR)}
1541 /* Array MUST be in descending order by the 'value' field */
1542 /* (since value is UNSIGNED, 0xffffffff is largest and */
1543 /* 0xfffffffe is smaller). A binary search is used to */
1544 /* locate the correct 'value'. */
1545 static const SPY_NOTIFY spnfy_array[] = {
1546 /* common 0U to 0U-99U */
1547 SPNFY(NM_OUTOFMEMORY, NMHDR),
1548 SPNFY(NM_CLICK, NMHDR),
1549 SPNFY(NM_DBLCLK, NMHDR),
1550 SPNFY(NM_RETURN, NMHDR),
1551 SPNFY(NM_RCLICK, NMHDR),
1552 SPNFY(NM_RDBLCLK, NMHDR),
1553 SPNFY(NM_SETFOCUS, NMHDR),
1554 SPNFY(NM_KILLFOCUS, NMHDR),
1555 SPNFY(NM_CUSTOMDRAW, NMCUSTOMDRAW),
1556 SPNFY(NM_HOVER, NMHDR),
1557 SPNFY(NM_NCHITTEST, NMMOUSE),
1558 SPNFY(NM_KEYDOWN, NMKEY),
1559 SPNFY(NM_RELEASEDCAPTURE, NMHDR),
1560 SPNFY(NM_SETCURSOR, NMMOUSE),
1561 SPNFY(NM_CHAR, NMCHAR),
1562 SPNFY(NM_TOOLTIPSCREATED, NMTOOLTIPSCREATED),
1563 /* Listview 0U-100U to 0U-199U */
1564 SPNFY(LVN_ITEMCHANGING, NMLISTVIEW),
1565 SPNFY(LVN_ITEMCHANGED, NMLISTVIEW),
1566 SPNFY(LVN_INSERTITEM, NMLISTVIEW),
1567 SPNFY(LVN_DELETEITEM, NMLISTVIEW),
1568 SPNFY(LVN_DELETEALLITEMS, NMLISTVIEW),
1569 SPNFY(LVN_BEGINLABELEDITA, NMLVDISPINFOA),
1570 SPNFY(LVN_ENDLABELEDITA, NMLVDISPINFOA),
1571 SPNFY(LVN_COLUMNCLICK, NMLISTVIEW),
1572 SPNFY(LVN_BEGINDRAG, NMLISTVIEW),
1573 SPNFY(LVN_BEGINRDRAG, NMLISTVIEW),
1574 SPNFY(LVN_ODCACHEHINT, NMLVCACHEHINT),
1575 SPNFY(LVN_ITEMACTIVATE, NMITEMACTIVATE),
1576 SPNFY(LVN_ODSTATECHANGED, NMLVODSTATECHANGE),
1577 SPNFY(LVN_HOTTRACK, NMLISTVIEW),
1578 SPNFY(LVN_GETDISPINFOA, NMLVDISPINFOA),
1579 SPNFY(LVN_SETDISPINFOA, NMLVDISPINFOA),
1580 SPNFY(LVN_ODFINDITEMA, NMLVFINDITEMA),
1581 SPNFY(LVN_KEYDOWN, NMLVKEYDOWN),
1582 SPNFY(LVN_MARQUEEBEGIN, NMLISTVIEW),
1583 SPNFY(LVN_GETINFOTIPA, NMLVGETINFOTIPA),
1584 SPNFY(LVN_GETINFOTIPW, NMLVGETINFOTIPW),
1585 SPNFY(LVN_BEGINLABELEDITW, NMLVDISPINFOW),
1586 SPNFY(LVN_ENDLABELEDITW, NMLVDISPINFOW),
1587 SPNFY(LVN_GETDISPINFOW, NMLVDISPINFOW),
1588 SPNFY(LVN_SETDISPINFOW, NMLVDISPINFOW),
1589 SPNFY(LVN_ODFINDITEMW, NMLVFINDITEMW),
1590 /* PropertySheet 0U-200U to 0U-299U */
1591 SPNFY(PSN_SETACTIVE, PSHNOTIFY),
1592 SPNFY(PSN_KILLACTIVE, PSHNOTIFY),
1593 SPNFY(PSN_APPLY, PSHNOTIFY),
1594 SPNFY(PSN_RESET, PSHNOTIFY),
1595 SPNFY(PSN_HELP, PSHNOTIFY),
1596 SPNFY(PSN_WIZBACK, PSHNOTIFY),
1597 SPNFY(PSN_WIZNEXT, PSHNOTIFY),
1598 SPNFY(PSN_WIZFINISH, PSHNOTIFY),
1599 SPNFY(PSN_QUERYCANCEL, PSHNOTIFY),
1600 SPNFY(PSN_GETOBJECT, NMOBJECTNOTIFY),
1601 /* SPNFY(PSN_QUERYINITIALFOCUS, .PSHNOTIFY), NIY */
1602 /* SPNFY(PSN_TRANSLATEACCELERATOR, .PSHNOTIFY), NIY */
1603 /* Header 0U-300U to 0U-399U */
1604 SPNFY(HDN_ITEMCHANGINGA, NMHDR),
1605 SPNFY(HDN_ITEMCHANGEDA, NMHDR),
1606 SPNFY(HDN_ITEMCLICKA, NMHDR),
1607 SPNFY(HDN_ITEMDBLCLICKA, NMHDR),
1608 SPNFY(HDN_DIVIDERDBLCLICKA, NMHDR),
1609 SPNFY(HDN_BEGINTRACKA, NMHDR),
1610 SPNFY(HDN_ENDTRACKA, NMHDR),
1611 SPNFY(HDN_GETDISPINFOA, NMHDR),
1612 SPNFY(HDN_BEGINDRAG, NMHDR),
1613 SPNFY(HDN_ENDDRAG, NMHDR),
1614 SPNFY(HDN_ITEMCHANGINGW, NMHDR),
1615 SPNFY(HDN_ITEMCHANGEDW, NMHDR),
1616 SPNFY(HDN_ITEMCLICKW, NMHDR),
1617 SPNFY(HDN_ITEMDBLCLICKW, NMHDR),
1618 SPNFY(HDN_DIVIDERDBLCLICKW, NMHDR),
1619 SPNFY(HDN_BEGINTRACKW, NMHDR),
1620 SPNFY(HDN_ENDTRACKW, NMHDR),
1621 SPNFY(HDN_GETDISPINFOW, NMHDR),
1622 /* Treeview 0U-400U to 0U-499U */
1623 SPNFY(TVN_SELCHANGINGA, NMHDR),
1624 SPNFY(TVN_SELCHANGEDA, NMHDR),
1625 SPNFY(TVN_GETDISPINFOA, NMHDR),
1626 SPNFY(TVN_SETDISPINFOA, NMHDR),
1627 SPNFY(TVN_ITEMEXPANDINGA, NMHDR),
1628 SPNFY(TVN_ITEMEXPANDEDA, NMHDR),
1629 SPNFY(TVN_BEGINDRAGA, NMHDR),
1630 SPNFY(TVN_BEGINRDRAGA, NMHDR),
1631 SPNFY(TVN_DELETEITEMA, NMHDR),
1632 SPNFY(TVN_BEGINLABELEDITA, NMHDR),
1633 SPNFY(TVN_ENDLABELEDITA, NMHDR),
1634 SPNFY(TVN_KEYDOWN, NMHDR),
1635 SPNFY(TVN_SELCHANGINGW, NMHDR),
1636 SPNFY(TVN_SELCHANGEDW, NMHDR),
1637 SPNFY(TVN_GETDISPINFOW, NMHDR),
1638 SPNFY(TVN_SETDISPINFOW, NMHDR),
1639 SPNFY(TVN_ITEMEXPANDINGW, NMHDR),
1640 SPNFY(TVN_ITEMEXPANDEDW, NMHDR),
1641 SPNFY(TVN_BEGINDRAGW, NMHDR),
1642 SPNFY(TVN_BEGINRDRAGW, NMHDR),
1643 SPNFY(TVN_DELETEITEMW, NMHDR),
1644 SPNFY(TVN_BEGINLABELEDITW, NMHDR),
1645 SPNFY(TVN_ENDLABELEDITW, NMHDR),
1646 /* Tooltips 0U-520U to 0U-549U */
1647 SPNFY(TTN_GETDISPINFOA, NMHDR),
1648 SPNFY(TTN_SHOW, NMHDR),
1649 SPNFY(TTN_POP, NMHDR),
1650 SPNFY(TTN_GETDISPINFOW, NMHDR),
1651 /* Tab 0U-550U to 0U-580U */
1652 SPNFY(TCN_KEYDOWN, NMHDR),
1653 SPNFY(TCN_SELCHANGE, NMHDR),
1654 SPNFY(TCN_SELCHANGING, NMHDR),
1655 SPNFY(TCN_GETOBJECT, NMHDR),
1656 /* Common Dialog 0U-601U to 0U-699U */
1657 /* Toolbar 0U-700U to 0U-720U */
1658 SPNFY(TBN_GETBUTTONINFOA, NMTOOLBARA),
1659 SPNFY(TBN_BEGINDRAG, NMTOOLBARA),
1660 SPNFY(TBN_ENDDRAG, NMTOOLBARA),
1661 SPNFY(TBN_BEGINADJUST, NMHDR),
1662 SPNFY(TBN_ENDADJUST, NMHDR),
1663 SPNFY(TBN_RESET, NMHDR),
1664 SPNFY(TBN_QUERYINSERT, NMTOOLBARA),
1665 SPNFY(TBN_QUERYDELETE, NMTOOLBARA),
1666 SPNFY(TBN_TOOLBARCHANGE, NMHDR),
1667 SPNFY(TBN_CUSTHELP, NMHDR),
1668 SPNFY(TBN_DROPDOWN, NMTOOLBARA),
1669 SPNFY(TBN_GETOBJECT, NMOBJECTNOTIFY),
1670 SPNFY(TBN_HOTITEMCHANGE, NMTBHOTITEM),
1671 SPNFY(TBN_DRAGOUT, NMTOOLBARA),
1672 SPNFY(TBN_DELETINGBUTTON, NMTOOLBARA),
1673 SPNFY(TBN_GETDISPINFOA, NMTBDISPINFOA),
1674 SPNFY(TBN_GETDISPINFOW, NMTBDISPINFOW),
1675 SPNFY(TBN_GETINFOTIPA, NMTBGETINFOTIPA),
1676 SPNFY(TBN_GETINFOTIPW, NMTBGETINFOTIPW),
1677 SPNFY(TBN_GETBUTTONINFOW, NMTOOLBARW),
1678 /* Up/Down 0U-721U to 0U-740U */
1679 SPNFY(UDN_DELTAPOS, NMHDR),
1680 /* Month Calendar 0U-750U to 0U-759U */
1681 /* ******************* WARNING ***************************** */
1682 /* The following appear backwards but needs to be this way. */
1683 /* The reason is that MS (and us) define the MCNs as */
1685 /* instead of the way ALL other notifications are */
1687 /* The only place that this is important is in this list */
1689 /* Also since the same error was made with the DTN_ items, */
1690 /* they overlay the MCN_ and need to be inserted in the */
1691 /* other section of the table so that it is in order for */
1692 /* the binary search. */
1694 /* Thank you MS for your obvious quality control!! */
1695 /* ******************* WARNING ***************************** */
1696 /* Date/Time 0U-760U to 0U-799U */
1697 /* SPNFY(MCN_SELECT, NMHDR), */
1698 /* SPNFY(MCN_GETDAYSTATE, NMHDR), */
1699 /* SPNFY(MCN_SELCHANGE, NMHDR), */
1700 /* ******************* WARNING ***************************** */
1701 /* The following appear backwards but needs to be this way. */
1702 /* The reason is that MS (and us) define the MCNs as */
1704 /* instead of the way ALL other notifications are */
1706 /* The only place that this is important is in this list */
1707 /* ******************* WARNING ***************************** */
1708 SPNFY(DTN_FORMATQUERYW, NMHDR),
1709 SPNFY(DTN_FORMATW, NMHDR),
1710 SPNFY(DTN_WMKEYDOWNW, NMHDR),
1711 SPNFY(DTN_USERSTRINGW, NMHDR),
1712 SPNFY(MCN_SELECT, NMHDR),
1713 SPNFY(MCN_GETDAYSTATE, NMHDR),
1714 SPNFY(MCN_SELCHANGE, NMHDR),
1715 SPNFY(DTN_CLOSEUP, NMHDR),
1716 SPNFY(DTN_DROPDOWN, NMHDR),
1717 SPNFY(DTN_FORMATQUERYA, NMHDR),
1718 SPNFY(DTN_FORMATA, NMHDR),
1719 SPNFY(DTN_WMKEYDOWNA, NMHDR),
1720 SPNFY(DTN_USERSTRINGA, NMHDR),
1721 SPNFY(DTN_DATETIMECHANGE, NMHDR),
1722 /* ComboBoxEx 0U-800U to 0U-830U */
1723 SPNFY(CBEN_GETDISPINFOA, NMCOMBOBOXEXA),
1724 SPNFY(CBEN_INSERTITEM, NMCOMBOBOXEXA),
1725 SPNFY(CBEN_DELETEITEM, NMCOMBOBOXEXA),
1726 SPNFY(CBEN_BEGINEDIT, NMHDR),
1727 SPNFY(CBEN_ENDEDITA, NMCBEENDEDITA),
1728 SPNFY(CBEN_ENDEDITW, NMCBEENDEDITW),
1729 SPNFY(CBEN_GETDISPINFOW, NMCOMBOBOXEXW),
1730 SPNFY(CBEN_DRAGBEGINA, NMCBEDRAGBEGINA),
1731 SPNFY(CBEN_DRAGBEGINW, NMCBEDRAGBEGINW),
1732 /* Rebar 0U-831U to 0U-859U */
1733 SPNFY(RBN_HEIGHTCHANGE, NMHDR),
1734 SPNFY(RBN_GETOBJECT, NMOBJECTNOTIFY),
1735 SPNFY(RBN_LAYOUTCHANGED, NMHDR),
1736 SPNFY(RBN_AUTOSIZE, NMRBAUTOSIZE),
1737 SPNFY(RBN_BEGINDRAG, NMREBAR),
1738 SPNFY(RBN_ENDDRAG, NMREBAR),
1739 SPNFY(RBN_DELETINGBAND, NMREBAR),
1740 SPNFY(RBN_DELETEDBAND, NMREBAR),
1741 SPNFY(RBN_CHILDSIZE, NMREBARCHILDSIZE),
1742 /* IP Adderss 0U-860U to 0U-879U */
1743 SPNFY(IPN_FIELDCHANGED, NMHDR),
1744 /* Status bar 0U-880U to 0U-899U */
1745 SPNFY(SBN_SIMPLEMODECHANGE, NMHDR),
1746 /* Pager 0U-900U to 0U-950U */
1747 SPNFY(PGN_SCROLL, NMPGSCROLL),
1748 SPNFY(PGN_CALCSIZE, NMPGCALCSIZE),
1750 static const SPY_NOTIFY *end_spnfy_array; /* ptr to last good entry in array */
1754 static BOOL16 SPY_Exclude[SPY_MAX_MSGNUM+1];
1755 static BOOL16 SPY_ExcludeDWP = 0;
1757 #define SPY_EXCLUDE(msg) \
1758 (SPY_Exclude[(msg) > SPY_MAX_MSGNUM ? SPY_MAX_MSGNUM : (msg)])
1763 UINT msgnum; /* message number */
1764 HWND msg_hwnd; /* window handle for message */
1765 WPARAM wParam; /* message parameter */
1766 LPARAM lParam; /* message parameter */
1767 INT data_len; /* length of data to dump */
1768 char msg_name[60]; /* message name (see SPY_GetMsgName) */
1769 WCHAR wnd_class[60]; /* window class name (full) */
1770 WCHAR wnd_name[16]; /* window name for message */
1773 /* This is defined so that the external entry point can return the addr */
1774 static SPY_INSTANCE ext_sp_e;
1776 static int indent_tls_index;
1778 /***********************************************************************
1781 inline static int get_indent_level(void)
1783 return (int)TlsGetValue( indent_tls_index );
1787 /***********************************************************************
1790 inline static void set_indent_level( int level )
1792 TlsSetValue( indent_tls_index, (void *)level );
1796 /***********************************************************************
1797 * SPY_GetMsgInternal
1799 static const char *SPY_GetMsgInternal( UINT msg )
1801 if (msg <= SPY_MAX_MSGNUM)
1803 if (!MessageTypeNames[msg]) return "???";
1804 return MessageTypeNames[msg];
1807 if (msg >= LVM_FIRST && msg <= LVM_FIRST + SPY_MAX_LVMMSGNUM)
1809 if (!LVMMessageTypeNames[msg-LVM_FIRST]) return "LVM_?";
1810 return LVMMessageTypeNames[msg-LVM_FIRST];
1813 if (msg >= TV_FIRST && msg <= TV_FIRST + SPY_MAX_TVMSGNUM)
1815 if (!TVMessageTypeNames[msg-TV_FIRST]) return "TV_?";
1816 return TVMessageTypeNames[msg-TV_FIRST];
1819 if (msg >= HDM_FIRST && msg <= HDM_FIRST + SPY_MAX_HDMMSGNUM)
1821 if (!HDMMessageTypeNames[msg-HDM_FIRST]) return "HDM_?";
1822 return HDMMessageTypeNames[msg-HDM_FIRST];
1825 if (msg >= TCM_FIRST && msg <= TCM_FIRST + SPY_MAX_TCMMSGNUM)
1827 if (!TCMMessageTypeNames[msg-TCM_FIRST]) return "TCM_?";
1828 return TCMMessageTypeNames[msg-TCM_FIRST];
1831 if (msg >= PGM_FIRST && msg <= PGM_FIRST + SPY_MAX_PGMMSGNUM)
1833 if (!PGMMessageTypeNames[msg-PGM_FIRST]) return "PGM_?";
1834 return PGMMessageTypeNames[msg-PGM_FIRST];
1837 if (msg >= CCM_FIRST && msg <= CCM_FIRST + SPY_MAX_CCMMSGNUM)
1839 if (!CCMMessageTypeNames[msg-CCM_FIRST]) return "???";
1840 return CCMMessageTypeNames[msg-CCM_FIRST];
1843 if (msg >= WM_WINE_DESTROYWINDOW && msg <= WM_WINE_DESTROYWINDOW + SPY_MAX_WINEMSGNUM)
1845 if (!WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW]) return "???";
1846 return WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW];
1851 /***********************************************************************
1854 const USER_MSG *SPY_Bsearch_Msg( const USER_MSG *first, const USER_MSG *last, UINT code)
1857 const USER_MSG *test;
1859 while (last >= first) {
1860 count = 1 + last - first;
1863 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
1864 code, first->value, first->name, last->value, last->name, last->len);
1866 if (first->value == code) return first;
1867 if (last->value == code) return last;
1871 test = first + count;
1873 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
1874 first, last, test, test->value, code, count);
1876 if (test->value == code) return test;
1877 if (test->value > code)
1885 /***********************************************************************
1888 * Get message name and other information for dumping
1890 static void SPY_GetMsgStuff( SPY_INSTANCE *sp_e )
1894 sp_e->msg_name[sizeof(sp_e->msg_name)-1] = 0;
1895 strncpy (sp_e->msg_name, SPY_GetMsgInternal( sp_e->msgnum ),
1896 sizeof(sp_e->msg_name)-1);
1899 if (!sp_e->msg_name[0])
1903 if (sp_e->msgnum >= 0xc000)
1905 if (GlobalGetAtomNameA( sp_e->msgnum, sp_e->msg_name+1, sizeof(sp_e->msg_name)-2 ))
1907 sp_e->msg_name[0] = '\"';
1908 strcat( sp_e->msg_name, "\"" );
1913 TRACE("looking class %s\n", sp_e->wnd_class);
1916 while (cc_array[i].classname &&
1917 strcmpW(cc_array[i].classname, sp_e->wnd_class) !=0) i++;
1919 if (cc_array[i].classname)
1922 TRACE("process class %s, first %p, last %p\n",
1923 debugstr_w(cc_array[i].classname), cc_array[i].classmsg,
1924 cc_array[i].lastmsg);
1926 p = SPY_Bsearch_Msg (cc_array[i].classmsg, cc_array[i].lastmsg,
1929 strncpy (sp_e->msg_name, p->name, sizeof(sp_e->msg_name)-1);
1930 sp_e->data_len = p->len;
1934 sprintf( sp_e->msg_name, "WM_USER+%04x", sp_e->msgnum - WM_USER );
1938 /***********************************************************************
1941 * Sets the value of "wnd_name" and "wnd_class" members of the
1942 * instance structure.
1945 void SPY_GetWndName( SPY_INSTANCE *sp_e )
1950 /* save and restore error code over the next call */
1951 save_error = GetLastError();
1952 /* special code to detect a property sheet dialog */
1953 if ((GetClassLongW(sp_e->msg_hwnd, GCW_ATOM) == (LONG)WC_DIALOGW) &&
1954 (GetPropW(sp_e->msg_hwnd, PropSheetInfoStr))) {
1955 strcpyW(sp_e->wnd_class, WC_PROPSHEETW);
1958 GetClassNameW(sp_e->msg_hwnd, sp_e->wnd_class, sizeof(sp_e->wnd_class)/sizeof(WCHAR));
1960 SetLastError(save_error);
1962 len = InternalGetWindowText(sp_e->msg_hwnd, sp_e->wnd_name, sizeof(sp_e->wnd_name)/sizeof(WCHAR));
1963 if(!len) /* get class name */
1965 LPWSTR dst = sp_e->wnd_name;
1966 LPWSTR src = sp_e->wnd_class;
1967 int n = sizeof(sp_e->wnd_name)/sizeof(WCHAR) - 3;
1969 while ((n-- > 0) && *src) *dst++ = *src++;
1975 /***********************************************************************
1978 * **** External function ****
1982 const char *SPY_GetMsgName( UINT msg, HWND hWnd )
1984 ext_sp_e.msgnum = msg;
1985 ext_sp_e.msg_hwnd = hWnd;
1986 ext_sp_e.lParam = 0;
1987 ext_sp_e.wParam = 0;
1988 SPY_GetWndName(&ext_sp_e);
1989 SPY_GetMsgStuff(&ext_sp_e);
1990 return ext_sp_e.msg_name;
1993 /***********************************************************************
1996 const char *SPY_GetVKeyName(WPARAM wParam)
1998 const char *vk_key_name;
2000 if(wParam <= SPY_MAX_VKKEYSNUM && VK_KeyNames[wParam])
2001 vk_key_name = VK_KeyNames[wParam];
2003 vk_key_name = "VK_???";
2008 /***********************************************************************
2009 * SPY_Bsearch_Notify
2011 const SPY_NOTIFY *SPY_Bsearch_Notify( const SPY_NOTIFY *first, const SPY_NOTIFY *last, UINT code)
2014 const SPY_NOTIFY *test;
2016 while (last >= first) {
2017 count = 1 + last - first;
2020 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
2021 code, first->value, first->name, last->value, last->name, last->len);
2023 if (first->value == code) return first;
2024 if (last->value == code) return last;
2028 test = first + count;
2030 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
2031 first, last, test, test->value, code, count);
2033 if (test->value == code) return test;
2034 if (test->value < code)
2042 /***********************************************************************
2045 void SPY_DumpMem (LPSTR header, UINT *q, INT len)
2049 for(i=0; i<len-12; i+=16) {
2050 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2051 header, i, *q, *(q+1), *(q+2), *(q+3));
2054 switch ((len - i + 3) & (~3)) {
2056 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2057 header, i, *q, *(q+1), *(q+2), *(q+3));
2060 TRACE("%s [%04x] %08x %08x %08x\n",
2061 header, i, *q, *(q+1), *(q+2));
2064 TRACE("%s [%04x] %08x %08x\n",
2065 header, i, *q, *(q+1));
2068 TRACE("%s [%04x] %08x\n",
2076 /***********************************************************************
2079 void SPY_DumpStructure (SPY_INSTANCE *sp_e, BOOL enter)
2081 switch (sp_e->msgnum)
2083 case LVM_INSERTITEMW:
2084 case LVM_INSERTITEMA:
2092 LPLVITEMA item = (LPLVITEMA) sp_e->lParam;
2094 SPY_DumpMem ("LVITEM", (UINT*)item, sizeof(LVITEMA));
2098 case TCM_INSERTITEMW:
2099 case TCM_INSERTITEMA:
2107 TCITEMA *item = (TCITEMA *) sp_e->lParam;
2109 SPY_DumpMem ("TCITEM", (UINT*)item, sizeof(TCITEMA));
2113 case TCM_ADJUSTRECT:
2114 case LVM_GETITEMRECT:
2115 case LVM_GETSUBITEMRECT:
2117 LPRECT rc = (LPRECT) sp_e->lParam;
2119 TRACE("lParam rect (%ld,%ld)-(%ld,%ld)\n",
2120 rc->left, rc->top, rc->right, rc->bottom);
2124 case LVM_SETITEMPOSITION32:
2127 case LVM_GETITEMPOSITION:
2130 LPPOINT point = (LPPOINT) sp_e->lParam;
2132 TRACE("lParam point x=%ld, y=%ld\n", point->x, point->y);
2137 if (!enter && (sp_e->msgnum == SBM_SETRANGE)) break;
2138 TRACE("min=%d max=%d\n", (INT)sp_e->wParam, (INT)sp_e->lParam);
2141 if ((enter && (sp_e->msgnum == SBM_GETRANGE)) ||
2142 (!enter && (sp_e->msgnum == SBM_SETRANGE))) break;
2144 LPINT ptmin = (LPINT) sp_e->wParam;
2145 LPINT ptmax = (LPINT) sp_e->lParam;
2147 TRACE("min=%d max=%d\n", *ptmin, *ptmax);
2149 TRACE("min=%d max=n/a\n", *ptmin);
2151 TRACE("min=n/a max=%d\n", *ptmax);
2157 DRAWITEMSTRUCT *lpdis = (DRAWITEMSTRUCT*) sp_e->lParam;
2158 TRACE("DRAWITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2159 lpdis->CtlType, lpdis->CtlID);
2160 TRACE("itemID=0x%08x itemAction=0x%08x itemState=0x%08x\n",
2161 lpdis->itemID, lpdis->itemAction, lpdis->itemState);
2162 TRACE("hWnd=%p hDC=%p (%ld,%ld)-(%ld,%ld) itemData=0x%08lx\n",
2163 lpdis->hwndItem, lpdis->hDC, lpdis->rcItem.left,
2164 lpdis->rcItem.top, lpdis->rcItem.right,
2165 lpdis->rcItem.bottom, lpdis->itemData);
2168 case WM_MEASUREITEM:
2170 MEASUREITEMSTRUCT *lpmis = (MEASUREITEMSTRUCT*) sp_e->lParam;
2171 TRACE("MEASUREITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2172 lpmis->CtlType, lpmis->CtlID);
2173 TRACE("itemID=0x%08x itemWidth=0x%08x itemHeight=0x%08x\n",
2174 lpmis->itemID, lpmis->itemWidth, lpmis->itemHeight);
2175 TRACE("itemData=0x%08lx\n", lpmis->itemData);
2178 case WM_WINDOWPOSCHANGED:
2180 case WM_WINDOWPOSCHANGING:
2182 WINDOWPOS *lpwp = (WINDOWPOS *)sp_e->lParam;
2183 TRACE("WINDOWPOS hwnd=%p, after=%p, at (%d,%d) w=%d h=%d, flags=0x%08x\n",
2184 lpwp->hwnd, lpwp->hwndInsertAfter, lpwp->x, lpwp->y,
2185 lpwp->cx, lpwp->cy, lpwp->flags);
2188 case WM_STYLECHANGED:
2190 case WM_STYLECHANGING:
2192 LPSTYLESTRUCT ss = (LPSTYLESTRUCT) sp_e->lParam;
2193 TRACE("STYLESTRUCT: StyleOld=0x%08lx, StyleNew=0x%08lx\n",
2194 ss->styleOld, ss->styleNew);
2199 RECT *rc = (RECT *)sp_e->lParam;
2200 TRACE("Rect (%ld,%ld)-(%ld,%ld)\n",
2201 rc->left, rc->top, rc->right, rc->bottom);
2205 /* if (!enter) break; */
2207 NMHDR * pnmh = (NMHDR*) sp_e->lParam;
2209 const SPY_NOTIFY *p;
2210 WCHAR from_class[60];
2213 p = SPY_Bsearch_Notify (&spnfy_array[0], end_spnfy_array,
2216 TRACE("NMHDR hwndFrom=%p idFrom=0x%08x code=%s<0x%08x>, extra=0x%x\n",
2217 pnmh->hwndFrom, pnmh->idFrom, p->name, pnmh->code, p->len);
2220 /* for CUSTOMDRAW, dump all the data for TOOLBARs */
2221 if (pnmh->code == NM_CUSTOMDRAW) {
2222 /* save and restore error code over the next call */
2223 save_error = GetLastError();
2224 GetClassNameW(pnmh->hwndFrom, from_class,
2225 sizeof(from_class)/sizeof(WCHAR));
2226 SetLastError(save_error);
2227 if (strcmpW(TOOLBARCLASSNAMEW, from_class) == 0)
2228 dumplen = sizeof(NMTBCUSTOMDRAW)-sizeof(NMHDR);
2231 q = (UINT *)(pnmh + 1);
2232 SPY_DumpMem ("NM extra", q, (INT)dumplen);
2236 TRACE("NMHDR hwndFrom=%p idFrom=0x%08x code=0x%08x\n",
2237 pnmh->hwndFrom, pnmh->idFrom, pnmh->code);
2240 if (sp_e->data_len > 0)
2241 SPY_DumpMem ("MSG lParam", (UINT *)sp_e->lParam, sp_e->data_len);
2246 /***********************************************************************
2249 void SPY_EnterMessage( INT iFlag, HWND hWnd, UINT msg,
2250 WPARAM wParam, LPARAM lParam )
2255 if (!TRACE_ON(message) || SPY_EXCLUDE(msg)) return;
2258 sp_e.msg_hwnd = hWnd;
2259 sp_e.lParam = lParam;
2260 sp_e.wParam = wParam;
2261 SPY_GetWndName(&sp_e);
2262 SPY_GetMsgStuff(&sp_e);
2263 indent = get_indent_level();
2265 /* each SPY_SENDMESSAGE must be complemented by call to SPY_ExitMessage */
2268 case SPY_DISPATCHMESSAGE16:
2269 TRACE("%*s(%04x) %-16s message [%04x] %s dispatched wp=%04x lp=%08lx\n",
2270 indent, "", HWND_16(hWnd),
2271 debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name, wParam, lParam);
2274 case SPY_DISPATCHMESSAGE:
2275 TRACE("%*s(%p) %-16s message [%04x] %s dispatched wp=%08x lp=%08lx\n",
2276 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2277 sp_e.msg_name, wParam, lParam);
2280 case SPY_SENDMESSAGE16:
2281 case SPY_SENDMESSAGE:
2284 DWORD tid = GetWindowThreadProcessId( hWnd, NULL );
2286 if (tid == GetCurrentThreadId()) strcpy( taskName, "self" );
2287 else sprintf( taskName, "tid %04lx", GetCurrentThreadId() );
2289 if (iFlag == SPY_SENDMESSAGE16)
2290 TRACE("%*s(%04x) %-16s message [%04x] %s sent from %s wp=%04x lp=%08lx\n",
2291 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2292 sp_e.msg_name, taskName, wParam, lParam );
2294 { TRACE("%*s(%p) %-16s message [%04x] %s sent from %s wp=%08x lp=%08lx\n",
2295 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2296 sp_e.msg_name, taskName, wParam, lParam );
2297 SPY_DumpStructure(&sp_e, TRUE);
2302 case SPY_DEFWNDPROC16:
2303 if( SPY_ExcludeDWP ) return;
2304 TRACE("%*s(%04x) DefWindowProc16: %s [%04x] wp=%04x lp=%08lx\n",
2305 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, wParam, lParam );
2308 case SPY_DEFWNDPROC:
2309 if( SPY_ExcludeDWP ) return;
2310 TRACE("%*s(%p) DefWindowProc32: %s [%04x] wp=%08x lp=%08lx\n",
2311 indent, "", hWnd, sp_e.msg_name,
2312 msg, wParam, lParam );
2315 set_indent_level( indent + SPY_INDENT_UNIT );
2319 /***********************************************************************
2322 void SPY_ExitMessage( INT iFlag, HWND hWnd, UINT msg, LRESULT lReturn,
2323 WPARAM wParam, LPARAM lParam )
2328 if (!TRACE_ON(message) || SPY_EXCLUDE(msg) ||
2329 (SPY_ExcludeDWP && (iFlag == SPY_RESULT_DEFWND16 || iFlag == SPY_RESULT_DEFWND)) )
2333 sp_e.msg_hwnd = hWnd;
2334 sp_e.lParam = lParam;
2335 sp_e.wParam = wParam;
2336 SPY_GetWndName(&sp_e);
2337 SPY_GetMsgStuff(&sp_e);
2339 if ((indent = get_indent_level()))
2341 indent -= SPY_INDENT_UNIT;
2342 set_indent_level( indent );
2347 case SPY_RESULT_DEFWND16:
2348 TRACE(" %*s(%04x) DefWindowProc16: %s [%04x] returned %08lx\n",
2349 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, lReturn );
2352 case SPY_RESULT_DEFWND:
2353 TRACE(" %*s(%p) DefWindowProc32: %s [%04x] returned %08lx\n",
2354 indent, "", hWnd, sp_e.msg_name, msg, lReturn );
2357 case SPY_RESULT_OK16:
2358 TRACE(" %*s(%04x) %-16s message [%04x] %s returned %08lx\n",
2359 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2360 sp_e.msg_name, lReturn );
2364 TRACE(" %*s(%p) %-16s message [%04x] %s returned %08lx\n",
2365 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2366 sp_e.msg_name, lReturn );
2367 SPY_DumpStructure(&sp_e, FALSE);
2370 case SPY_RESULT_INVALIDHWND16:
2371 WARN(" %*s(%04x) %-16s message [%04x] %s HAS INVALID HWND\n",
2372 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name );
2375 case SPY_RESULT_INVALIDHWND:
2376 WARN(" %*s(%p) %-16s message [%04x] %s HAS INVALID HWND\n",
2377 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2384 /***********************************************************************
2391 const SPY_NOTIFY *p;
2395 if (!TRACE_ON(message)) return TRUE;
2397 indent_tls_index = TlsAlloc();
2398 if(!RegOpenKeyA(HKEY_LOCAL_MACHINE, "Software\\Wine\\Wine\\Config\\Debug", &hkey))
2400 DWORD type, count = sizeof(buffer);
2403 if (!RegQueryValueExA(hkey, "SpyInclude", 0, &type, buffer, &count) &&
2404 strcmp( buffer, "INCLUDEALL" ))
2406 TRACE("Include=%s\n", buffer );
2407 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2408 SPY_Exclude[i] = (MessageTypeNames[i] && !strstr(buffer,MessageTypeNames[i]));
2411 count = sizeof(buffer);
2413 if (!RegQueryValueExA(hkey, "SpyExclude", 0, &type, buffer, &count))
2415 TRACE("Exclude=%s\n", buffer );
2416 if (!strcmp( buffer, "EXCLUDEALL" ))
2417 for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = TRUE;
2419 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2420 SPY_Exclude[i] = (MessageTypeNames[i] && strstr(buffer,MessageTypeNames[i]));
2424 count = sizeof(buffer);
2425 if(!RegQueryValueExA(hkey, "SpyExcludeDWP", 0, &type, buffer, &count))
2426 SPY_ExcludeDWP = atoi(buffer);
2431 /* find last good entry in spy notify array and save addr for b-search */
2432 p = &spnfy_array[0];
2435 if ((UINT)p->value > (UINT)j) {
2436 ERR("Notify message array out of order\n");
2437 ERR(" between values [%08x] %s and [%08x] %s\n",
2438 j, (p-1)->name, p->value, p->name);
2445 end_spnfy_array = p;
2447 /* find last good entry in each common control message array
2448 * and save addr for b-search.
2451 while (cc_array[i].classname) {
2453 j = 0x0400; /* minimum entry in array */
2454 q = cc_array[i].classmsg;
2456 if (q->value <= j) {
2457 ERR("Class message array out of order for class %s\n",
2458 debugstr_w(cc_array[i].classname));
2459 ERR(" between values [%04x] %s and [%04x] %s\n",
2460 j, (q-1)->name, q->value, q->name);
2467 cc_array[i].lastmsg = (USER_MSG *)q;