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/winuser16.h"
30 #include "wine/winbase16.h"
31 #include "wine/unicode.h"
33 #include "wine/debug.h"
37 WINE_DEFAULT_DEBUG_CHANNEL(message);
39 #define SPY_MAX_MSGNUM WM_USER
40 #define SPY_INDENT_UNIT 4 /* 4 spaces */
44 static const char * const MessageTypeNames[SPY_MAX_MSGNUM + 1] =
62 "WM_CLOSE", /* 0x10 */
78 "WM_SETCURSOR", /* 0x20 */
94 "WM_SETFONT", /* 0x30 */
106 "wm_otherwindowcreated",
107 "wm_otherwindowdestroyed",
108 "wm_activateshellwindow",
112 "wm_compacting", NULL, NULL,
113 "WM_COMMNOTIFY", NULL,
114 "WM_WINDOWPOSCHANGING", /* 0x0046 */
115 "WM_WINDOWPOSCHANGED", /* 0x0047 */
118 "WM_CANCELJOURNAL", NULL, NULL,
122 "WM_INPUTLANGCHANGEREQUEST",
123 "WM_INPUTLANGCHANGE",
127 "WM_NOTIFYFORMAT", NULL, NULL,
128 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
131 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
132 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
135 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
143 "WM_SETICON", /* 0x0080 */
144 "WM_NCCREATE", /* 0x0081 */
145 "WM_NCDESTROY", /* 0x0082 */
146 "WM_NCCALCSIZE", /* 0x0083 */
147 "WM_NCHITTEST", /* 0x0084 */
148 "WM_NCPAINT", /* 0x0085 */
149 "WM_NCACTIVATE", /* 0x0086 */
150 "WM_GETDLGCODE", /* 0x0087 */
152 "WM_SYNCTASK", NULL, NULL, NULL, NULL, NULL, NULL,
155 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
156 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
159 "WM_NCMOUSEMOVE", /* 0x00A0 */
160 "WM_NCLBUTTONDOWN", /* 0x00A1 */
161 "WM_NCLBUTTONUP", /* 0x00A2 */
162 "WM_NCLBUTTONDBLCLK", /* 0x00A3 */
163 "WM_NCRBUTTONDOWN", /* 0x00A4 */
164 "WM_NCRBUTTONUP", /* 0x00A5 */
165 "WM_NCRBUTTONDBLCLK", /* 0x00A6 */
166 "WM_NCMBUTTONDOWN", /* 0x00A7 */
167 "WM_NCMBUTTONUP", /* 0x00A8 */
168 "WM_NCMBUTTONDBLCLK", /* 0x00A9 */
169 NULL, NULL, NULL, NULL, NULL, NULL,
171 /* 0x00B0 - Win32 Edit controls */
172 "EM_GETSEL", /* 0x00b0 */
173 "EM_SETSEL", /* 0x00b1 */
174 "EM_GETRECT", /* 0x00b2 */
175 "EM_SETRECT", /* 0x00b3 */
176 "EM_SETRECTNP", /* 0x00b4 */
177 "EM_SCROLL", /* 0x00b5 */
178 "EM_LINESCROLL", /* 0x00b6 */
179 "EM_SCROLLCARET", /* 0x00b7 */
180 "EM_GETMODIFY", /* 0x00b8 */
181 "EM_SETMODIFY", /* 0x00b9 */
182 "EM_GETLINECOUNT", /* 0x00ba */
183 "EM_LINEINDEX", /* 0x00bb */
184 "EM_SETHANDLE", /* 0x00bc */
185 "EM_GETHANDLE", /* 0x00bd */
186 "EM_GETTHUMB", /* 0x00be */
190 "EM_LINELENGTH", /* 0x00c1 */
191 "EM_REPLACESEL", /* 0x00c2 */
193 "EM_GETLINE", /* 0x00c4 */
194 "EM_LIMITTEXT", /* 0x00c5 */
195 "EM_CANUNDO", /* 0x00c6 */
196 "EM_UNDO", /* 0x00c7 */
197 "EM_FMTLINES", /* 0x00c8 */
198 "EM_LINEFROMCHAR", /* 0x00c9 */
200 "EM_SETTABSTOPS", /* 0x00cb */
201 "EM_SETPASSWORDCHAR", /* 0x00cc */
202 "EM_EMPTYUNDOBUFFER", /* 0x00cd */
203 "EM_GETFIRSTVISIBLELINE", /* 0x00ce */
204 "EM_SETREADONLY", /* 0x00cf */
206 "EM_SETWORDBREAKPROC", /* 0x00d0 */
207 "EM_GETWORDBREAKPROC", /* 0x00d1 */
208 "EM_GETPASSWORDCHAR", /* 0x00d2 */
209 "EM_SETMARGINS", /* 0x00d3 */
210 "EM_GETMARGINS", /* 0x00d4 */
211 "EM_GETLIMITTEXT", /* 0x00d5 */
212 "EM_POSFROMCHAR", /* 0x00d6 */
213 "EM_CHARFROMPOS", /* 0x00d7 */
214 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
216 /* 0x00E0 - Win32 Scrollbars */
217 "SBM_SETPOS", /* 0x00e0 */
218 "SBM_GETPOS", /* 0x00e1 */
219 "SBM_SETRANGE", /* 0x00e2 */
220 "SBM_GETRANGE", /* 0x00e3 */
221 "SBM_ENABLE_ARROWS", /* 0x00e4 */
223 "SBM_SETRANGEREDRAW", /* 0x00e6 */
225 "SBM_SETSCROLLINFO", /* 0x00e9 */
226 "SBM_GETSCROLLINFO", /* 0x00ea */
227 NULL, NULL, NULL, NULL, NULL,
229 /* 0x00F0 - Win32 Buttons */
230 "BM_GETCHECK", /* 0x00f0 */
231 "BM_SETCHECK", /* 0x00f1 */
232 "BM_GETSTATE", /* 0x00f2 */
233 "BM_SETSTATE", /* 0x00f3 */
234 "BM_SETSTYLE", /* 0x00f4 */
235 "BM_CLICK", /* 0x00f5 */
236 "BM_GETIMAGE", /* 0x00f6 */
237 "BM_SETIMAGE", /* 0x00f7 */
238 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
240 "WM_KEYDOWN", /* 0x0100 */
241 "WM_KEYUP", /* 0x0101 */
242 "WM_CHAR", /* 0x0102 */
243 "WM_DEADCHAR", /* 0x0103 */
244 "WM_SYSKEYDOWN", /* 0x0104 */
245 "WM_SYSKEYUP", /* 0x0105 */
246 "WM_SYSCHAR", /* 0x0106 */
247 "WM_SYSDEADCHAR", /* 0x0107 */
248 "WM_KEYLAST", /* 0x0108 */
253 "WM_IME_STARTCOMPOSITION", /* 0x010d */
254 "WM_IME_ENDCOMPOSITION", /* 0x010e */
255 "WM_IME_COMPOSITION", /* 0x010f */
257 "WM_INITDIALOG", /* 0x0110 */
258 "WM_COMMAND", /* 0x0111 */
259 "WM_SYSCOMMAND", /* 0x0112 */
260 "WM_TIMER", /* 0x0113 */
261 "WM_HSCROLL", /* 0x0114 */
262 "WM_VSCROLL", /* 0x0115 */
263 "WM_INITMENU", /* 0x0116 */
264 "WM_INITMENUPOPUP", /* 0x0117 */
265 "WM_SYSTIMER", /* 0x0118 */
266 NULL, NULL, NULL, NULL, NULL, NULL,
267 "WM_MENUSELECT", /* 0x011f */
269 "WM_MENUCHAR", /* 0x0120 */
270 "WM_ENTERIDLE", /* 0x0121 */
272 "WM_MENURBUTTONUP", /* 0x0122 */
273 "WM_MENUDRAG", /* 0x0123 */
274 "WM_MENUGETOBJECT", /* 0x0124 */
275 "WM_UNINITMENUPOPUP", /* 0x0125 */
276 "WM_MENUCOMMAND", /* 0x0126 */
277 "WM_CHANGEUISTATE", /* 0x0127 */
278 "WM_UPDATEUISTATE", /* 0x0128 */
279 "WM_QUERYUISTATE", /* 0x0129 */
281 NULL, NULL, NULL, NULL, NULL, NULL,
285 "WM_LBTRACKPOINT", /* 0x0131 */
286 "WM_CTLCOLORMSGBOX", /* 0x0132 */
287 "WM_CTLCOLOREDIT", /* 0x0133 */
288 "WM_CTLCOLORLISTBOX", /* 0x0134 */
289 "WM_CTLCOLORBTN", /* 0x0135 */
290 "WM_CTLCOLORDLG", /* 0x0136 */
291 "WM_CTLCOLORSCROLLBAR", /* 0x0137 */
292 "WM_CTLCOLORSTATIC", /* 0x0138 */
293 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
295 /* 0x0140 - Win32 Comboboxes */
296 "CB_GETEDITSEL", /* 0x0140 */
297 "CB_LIMITTEXT", /* 0x0141 */
298 "CB_SETEDITSEL", /* 0x0142 */
299 "CB_ADDSTRING", /* 0x0143 */
300 "CB_DELETESTRING", /* 0x0144 */
301 "CB_DIR", /* 0x0145 */
302 "CB_GETCOUNT", /* 0x0146 */
303 "CB_GETCURSEL", /* 0x0147 */
304 "CB_GETLBTEXT", /* 0x0148 */
305 "CB_GETLBTEXTLEN", /* 0x0149 */
306 "CB_INSERTSTRING", /* 0x014a */
307 "CB_RESETCONTENT", /* 0x014b */
308 "CB_FINDSTRING", /* 0x014c */
309 "CB_SELECTSTRING", /* 0x014d */
310 "CB_SETCURSEL", /* 0x014e */
311 "CB_SHOWDROPDOWN", /* 0x014f */
313 "CB_GETITEMDATA", /* 0x0150 */
314 "CB_SETITEMDATA", /* 0x0151 */
315 "CB_GETDROPPEDCONTROLRECT", /* 0x0152 */
316 "CB_SETITEMHEIGHT", /* 0x0153 */
317 "CB_GETITEMHEIGHT", /* 0x0154 */
318 "CB_SETEXTENDEDUI", /* 0x0155 */
319 "CB_GETEXTENDEDUI", /* 0x0156 */
320 "CB_GETDROPPEDSTATE", /* 0x0157 */
321 "CB_FINDSTRINGEXACT", /* 0x0158 */
322 "CB_SETLOCALE", /* 0x0159 */
323 "CB_GETLOCALE", /* 0x015a */
324 "CB_GETTOPINDEX", /* 0x015b */
325 "CB_SETTOPINDEX", /* 0x015c */
326 "CB_GETHORIZONTALEXTENT", /* 0x015d */
327 "CB_SETHORIZONTALEXTENT", /* 0x015e */
328 "CB_GETDROPPEDWIDTH", /* 0x015f */
330 "CB_SETDROPPEDWIDTH", /* 0x0160 */
331 "CB_INITSTORAGE", /* 0x0161 */
332 NULL, NULL, NULL, NULL, NULL, NULL,
333 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
335 /* 0x0170 - Win32 Static controls */
336 "STM_SETICON", /* 0x0170 */
337 "STM_GETICON", /* 0x0171 */
338 "STM_SETIMAGE", /* 0x0172 */
339 "STM_GETIMAGE", /* 0x0173 */
340 NULL, NULL, NULL, NULL,
341 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
343 /* 0x0180 - Win32 Listboxes */
344 "LB_ADDSTRING", /* 0x0180 */
345 "LB_INSERTSTRING", /* 0x0181 */
346 "LB_DELETESTRING", /* 0x0182 */
347 "LB_SELITEMRANGEEX", /* 0x0183 */
348 "LB_RESETCONTENT", /* 0x0184 */
349 "LB_SETSEL", /* 0x0185 */
350 "LB_SETCURSEL", /* 0x0186 */
351 "LB_GETSEL", /* 0x0187 */
352 "LB_GETCURSEL", /* 0x0188 */
353 "LB_GETTEXT", /* 0x0189 */
354 "LB_GETTEXTLEN", /* 0x018a */
355 "LB_GETCOUNT", /* 0x018b */
356 "LB_SELECTSTRING", /* 0x018c */
357 "LB_DIR", /* 0x018d */
358 "LB_GETTOPINDEX", /* 0x018e */
359 "LB_FINDSTRING", /* 0x018f */
361 "LB_GETSELCOUNT", /* 0x0190 */
362 "LB_GETSELITEMS", /* 0x0191 */
363 "LB_SETTABSTOPS", /* 0x0192 */
364 "LB_GETHORIZONTALEXTENT", /* 0x0193 */
365 "LB_SETHORIZONTALEXTENT", /* 0x0194 */
366 "LB_SETCOLUMNWIDTH", /* 0x0195 */
367 "LB_ADDFILE", /* 0x0196 */
368 "LB_SETTOPINDEX", /* 0x0197 */
369 "LB_GETITEMRECT", /* 0x0198 */
370 "LB_GETITEMDATA", /* 0x0199 */
371 "LB_SETITEMDATA", /* 0x019a */
372 "LB_SELITEMRANGE", /* 0x019b */
373 "LB_SETANCHORINDEX", /* 0x019c */
374 "LB_GETANCHORINDEX", /* 0x019d */
375 "LB_SETCARETINDEX", /* 0x019e */
376 "LB_GETCARETINDEX", /* 0x019f */
378 "LB_SETITEMHEIGHT", /* 0x01a0 */
379 "LB_GETITEMHEIGHT", /* 0x01a1 */
380 "LB_FINDSTRINGEXACT", /* 0x01a2 */
381 "LB_CARETON", /* 0x01a3 */
382 "LB_CARETOFF", /* 0x01a4 */
383 "LB_SETLOCALE", /* 0x01a5 */
384 "LB_GETLOCALE", /* 0x01a6 */
385 "LB_SETCOUNT", /* 0x01a7 */
386 "LB_INITSTORAGE", /* 0x01a8 */
387 "LB_ITEMFROMPOINT", /* 0x01a9 */
388 NULL, NULL, NULL, NULL, NULL, NULL,
391 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
392 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
395 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
396 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
399 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
400 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
403 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
404 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
407 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
408 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
410 "WM_MOUSEMOVE", /* 0x0200 */
411 "WM_LBUTTONDOWN", /* 0x0201 */
412 "WM_LBUTTONUP", /* 0x0202 */
413 "WM_LBUTTONDBLCLK", /* 0x0203 */
414 "WM_RBUTTONDOWN", /* 0x0204 */
415 "WM_RBUTTONUP", /* 0x0205 */
416 "WM_RBUTTONDBLCLK", /* 0x0206 */
417 "WM_MBUTTONDOWN", /* 0x0207 */
418 "WM_MBUTTONUP", /* 0x0208 */
419 "WM_MBUTTONDBLCLK", /* 0x0209 */
420 "WM_MOUSEWHEEL", /* 0x020A */
421 NULL, NULL, NULL, NULL, NULL,
423 "WM_PARENTNOTIFY", /* 0x0210 */
424 "WM_ENTERMENULOOP", /* 0x0211 */
425 "WM_EXITMENULOOP", /* 0x0212 */
426 "WM_NEXTMENU", /* 0x0213 */
431 "WM_DEVICECHANGE", NULL, NULL, NULL, NULL, NULL, NULL,
433 "WM_MDICREATE", /* 0x0220 */
434 "WM_MDIDESTROY", /* 0x0221 */
435 "WM_MDIACTIVATE", /* 0x0222 */
436 "WM_MDIRESTORE", /* 0x0223 */
437 "WM_MDINEXT", /* 0x0224 */
438 "WM_MDIMAXIMIZE", /* 0x0225 */
439 "WM_MDITILE", /* 0x0226 */
440 "WM_MDICASCADE", /* 0x0227 */
441 "WM_MDIICONARRANGE", /* 0x0228 */
442 "WM_MDIGETACTIVE", /* 0x0229 */
445 "WM_QUERYDROPOBJECT",
452 "WM_MDISETMENU", /* 0x0230 */
453 "WM_ENTERSIZEMOVE", /* 0x0231 */
454 "WM_EXITSIZEMOVE", /* 0x0232 */
455 "WM_DROPFILES", /* 0x0233 */
456 "WM_MDIREFRESHMENU", NULL, NULL, NULL,
458 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
461 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
462 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
465 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
466 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,
471 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
472 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
475 NULL, "WM_IME_SETCONTEXT", "WM_IME_NOTIFY", "WM_IME_CONTROL", "WM_IME_COMPOSITIONFULL", "WM_IME_SELECT", "WM_IME_CHAR", NULL,
476 "WM_IME_REQUEST", NULL, NULL, NULL, NULL, NULL, NULL, NULL,
477 "WM_IME_KEYDOWN", "WM_IME_KEYUP", NULL, NULL, NULL, NULL, NULL, NULL,
478 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
481 NULL, "WM_MOUSEHOVER", NULL, "WM_MOUSELEAVE", NULL, NULL, NULL, NULL,
482 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
483 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
484 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,
489 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
490 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,
494 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
495 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
497 "WM_CUT", /* 0x0300 */
503 "WM_RENDERALLFORMATS",
504 "WM_DESTROYCLIPBOARD",
507 "WM_VSCROLLCLIPBOARD",
509 "WM_ASKCBFORMATNAME",
511 "WM_HSCROLLCLIPBOARD",
512 "WM_QUERYNEWPALETTE", /* 0x030f*/
514 "WM_PALETTEISCHANGING",
516 "WM_HOTKEY", /* 0x0312 */
517 NULL, NULL, NULL, NULL,
520 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,
524 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
525 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,
530 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
531 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
533 "WM_QUERYAFXWNDPROC", /* 0x0360 */
534 "WM_SIZEPARENT", /* 0x0361 */
535 "WM_SETMESSAGESTRING", /* 0x0362 */
536 "WM_IDLEUPDATECMDUI", /* 0x0363 */
537 "WM_INITIALUPDATE", /* 0x0364 */
538 "WM_COMMANDHELP", /* 0x0365 */
539 "WM_HELPHITTEST", /* 0x0366 */
540 "WM_EXITHELPMODE", /* 0x0367 */
541 "WM_RECALCPARENT", /* 0x0368 */
542 "WM_SIZECHILD", /* 0x0369 */
543 "WM_KICKIDLE", /* 0x036A */
544 "WM_QUERYCENTERWND", /* 0x036B */
545 "WM_DISABLEMODAL", /* 0x036C */
546 "WM_FLOATSTATUS", /* 0x036D */
547 "WM_ACTIVATETOPLEVEL", /* 0x036E */
548 "WM_QUERY3DCONTROLS", /* 0x036F */
550 "WM_SOCKET_NOTIFY", /* 0x0373 */
551 "WM_SOCKET_DEAD", /* 0x0374 */
552 "WM_POPMESSAGESTRING", /* 0x0375 */
553 "WM_OCC_LOADFROMSTREAM", /* 0x0376 */
554 "WM_OCC_LOADFROMSTORAGE", /* 0x0377 */
555 "WM_OCC_INITNEW", /* 0x0378 */
556 "WM_QUEUE_SENTINEL", /* 0x0379 */
557 "WM_OCC_LOADFROMSTREAM_EX", /* 0x037A */
558 "WM_OCC_LOADFROMSTORAGE_EX", /* 0x037B */
562 "WM_PENWINFIRST", /* 0x0380 */
563 "WM_RCRESULT", /* 0x0381 */
564 "WM_HOOKRCRESULT", /* 0x0382 */
565 "WM_GLOBALRCCHANGE", /* 0x0383 */
566 "WM_SKB", /* 0x0384 */
567 "WM_HEDITCTL", /* 0x0385 */
569 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
570 "WM_PENWINLAST", /* 0x038F */
572 "WM_COALESCE_FIRST", /* 0x0390 */
573 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
574 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
575 "WM_COALESCE_LAST", /* 0x039F */
582 NULL, NULL, NULL, NULL,
583 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
586 NULL, NULL, NULL, NULL, NULL,
610 NULL, NULL, NULL, NULL, NULL, NULL,
611 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
612 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
615 "WM_DDE_INITIATE", /* 0x3E0 */
616 "WM_DDE_TERMINATE", /* 0x3E1 */
617 "WM_DDE_ADVISE", /* 0x3E2 */
618 "WM_DDE_UNADVISE", /* 0x3E3 */
619 "WM_DDE_ACK", /* 0x3E4 */
620 "WM_DDE_DATA", /* 0x3E5 */
621 "WM_DDE_REQUEST", /* 0x3E6 */
622 "WM_DDE_POKE", /* 0x3E7 */
623 "WM_DDE_EXECUTE", /* 0x3E8 */
624 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
628 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
629 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
631 "WM_USER" /* 0x0400 */
635 #define SPY_MAX_LVMMSGNUM 140
636 static const char * const LVMMessageTypeNames[SPY_MAX_LVMMSGNUM + 1] =
638 "LVM_GETBKCOLOR", /* 1000 */
647 "LVM_DELETEALLITEMS",
648 "LVM_GETCALLBACKMASK",
649 "LVM_SETCALLBACKMASK",
653 "LVM_SETITEMPOSITION",
654 "LVM_GETITEMPOSITION",
655 "LVM_GETSTRINGWIDTHA",
662 "LVM_GETEDITCONTROL",
667 "LVM_GETCOLUMNWIDTH",
668 "LVM_SETCOLUMNWIDTH",
671 "LVM_CREATEDRAGIMAGE",
675 "LVM_GETTEXTBKCOLOR",
676 "LVM_SETTEXTBKCOLOR",
678 "LVM_GETCOUNTPERPAGE",
687 "LVM_SETITEMPOSITION32",
688 "LVM_GETSELECTEDCOUNT",
689 "LVM_GETITEMSPACING",
690 "LVM_GETISEARCHSTRINGA",
691 "LVM_SETICONSPACING",
692 "LVM_SETEXTENDEDLISTVIEWSTYLE",
693 "LVM_GETEXTENDEDLISTVIEWSTYLE",
694 "LVM_GETSUBITEMRECT",
695 "LVM_SUBITEMHITTEST",
696 "LVM_SETCOLUMNORDERARRAY",
697 "LVM_GETCOLUMNORDERARRAY",
702 "LVM_APPROXIMATEVIEWRECT",
704 "LVM_GETSELECTIONMARK",
705 "LVM_SETSELECTIONMARK",
711 "LVM_GETNUMBEROFWORKAREAS",
725 "LVM_GETSTRINGWIDTHW",
755 "LVM_GETISEARCHSTRINGW",
778 "LVM_GETBKIMAGEW" /* 0x108B */
782 #define SPY_MAX_TVMSGNUM 65
783 static const char * const TVMessageTypeNames[SPY_MAX_TVMSGNUM + 1] =
785 "TVM_INSERTITEMA", /* 1100 */
800 "TVM_GETEDITCONTROL",
801 "TVM_GETVISIBLECOUNT",
803 "TVM_CREATEDRAGIMAGE",
806 "TVM_SORTCHILDRENCB",
807 "TVM_ENDEDITLABELNOW",
808 "TVM_GETISEARCHSTRINGA",
822 "TVM_SETINSERTMARKCOLOR",
823 "TVM_GETINSERTMARKCOLOR",
849 "TVM_GETISEARCHSTRINGW",
854 #define SPY_MAX_HDMMSGNUM 19
855 static const char * const HDMMessageTypeNames[SPY_MAX_HDMMSGNUM + 1] =
857 "HDM_GETITEMCOUNT", /* 1200 */
873 "HDM_CREATEDRAGIMAGE",
874 "GETORDERARRAYINDEX",
875 "SETORDERARRAYINDEX",
880 #define SPY_MAX_TCMMSGNUM 62
881 static const char * const TCMMessageTypeNames[SPY_MAX_TCMMSGNUM + 1] =
892 "TCM_DELETEALLITEMS",
932 "TCM_SETMINTABWIDTH",
935 "TCM_SETEXTENDEDSTYLE",
936 "TCM_GETEXTENDEDSTYLE",
948 #define SPY_MAX_PGMMSGNUM 13
949 static const char * const PGMMessageTypeNames[SPY_MAX_PGMMSGNUM + 1] =
963 "PGM_GETBUTTONSTATE",
968 #define SPY_MAX_CCMMSGNUM 9
969 static const char * const CCMMessageTypeNames[SPY_MAX_CCMMSGNUM + 1] =
973 "CCM_SETCOLORSCHEME",
974 "CCM_GETCOLORSCHEME",
976 "CCM_SETUNICODEFORMAT",
977 "CCM_GETUNICODEFORMAT",
980 "CCM_SETNOTIFYWINDOW"
983 #define SPY_MAX_WINEMSGNUM 6
984 static const char * const WINEMessageTypeNames[SPY_MAX_WINEMSGNUM + 1] =
986 "WM_WINE_DESTROYWINDOW",
987 "WM_WINE_SETWINDOWPOS",
988 "WM_WINE_SHOWWINDOW",
990 "WM_WINE_SETWINDOWLONG",
991 "WM_WINE_ENABLEWINDOW"
994 /* Virtual key names */
995 #define SPY_MAX_VKKEYSNUM 255
996 static const char * const VK_KeyNames[SPY_MAX_VKKEYSNUM + 1] =
999 "VK_LBUTTON", /* 0x01 */
1000 "VK_RBUTTON", /* 0x02 */
1001 "VK_CANCEL", /* 0x03 */
1002 "VK_MBUTTON", /* 0x04 */
1006 "VK_BACK", /* 0x08 */
1007 "VK_TAB", /* 0x09 */
1010 "VK_CLEAR", /* 0x0C */
1011 "VK_RETURN", /* 0x0D */
1014 "VK_SHIFT", /* 0x10 */
1015 "VK_CONTROL", /* 0x11 */
1016 "VK_MENU", /* 0x12 */
1017 "VK_PAUSE", /* 0x13 */
1018 "VK_CAPITAL", /* 0x14 */
1025 "VK_ESCAPE", /* 0x1B */
1030 "VK_SPACE", /* 0x20 */
1031 "VK_PRIOR", /* 0x21 */
1032 "VK_NEXT", /* 0x22 */
1033 "VK_END", /* 0x23 */
1034 "VK_HOME", /* 0x24 */
1035 "VK_LEFT", /* 0x25 */
1037 "VK_RIGHT", /* 0x27 */
1038 "VK_DOWN", /* 0x28 */
1039 "VK_SELECT", /* 0x29 */
1040 "VK_PRINT", /* 0x2A */
1041 "VK_EXECUTE", /* 0x2B */
1042 "VK_SNAPSHOT", /* 0x2C */
1043 "VK_INSERT", /* 0x2D */
1044 "VK_DELETE", /* 0x2E */
1045 "VK_HELP", /* 0x2F */
1089 "VK_LWIN", /* 0x5B */
1090 "VK_RWIN", /* 0x5C */
1091 "VK_APPS", /* 0x5D */
1094 "VK_NUMPAD0", /* 0x60 */
1095 "VK_NUMPAD1", /* 0x61 */
1096 "VK_NUMPAD2", /* 0x62 */
1097 "VK_NUMPAD3", /* 0x63 */
1098 "VK_NUMPAD4", /* 0x64 */
1099 "VK_NUMPAD5", /* 0x65 */
1100 "VK_NUMPAD6", /* 0x66 */
1101 "VK_NUMPAD7", /* 0x67 */
1102 "VK_NUMPAD8", /* 0x68 */
1103 "VK_NUMPAD9", /* 0x69 */
1104 "VK_MULTIPLY", /* 0x6A */
1105 "VK_ADD", /* 0x6B */
1106 "VK_SEPARATOR", /* 0x6C */
1107 "VK_SUBTRACT", /* 0x6D */
1108 "VK_DECIMAL", /* 0x6E */
1109 "VK_DIVIDE", /* 0x6F */
1119 "VK_F10", /* 0x79 */
1120 "VK_F11", /* 0x7A */
1121 "VK_F12", /* 0x7B */
1122 "VK_F13", /* 0x7C */
1123 "VK_F14", /* 0x7D */
1124 "VK_F15", /* 0x7E */
1125 "VK_F16", /* 0x7F */
1126 "VK_F17", /* 0x80 */
1127 "VK_F18", /* 0x81 */
1128 "VK_F19", /* 0x82 */
1129 "VK_F20", /* 0x83 */
1130 "VK_F21", /* 0x84 */
1131 "VK_F22", /* 0x85 */
1132 "VK_F23", /* 0x86 */
1133 "VK_F24", /* 0x87 */
1142 "VK_NUMLOCK", /* 0x90 */
1143 "VK_SCROLL", /* 0x91 */
1158 "VK_LSHIFT", /* 0xA0 */
1159 "VK_RSHIFT", /* 0xA1 */
1160 "VK_LCONTROL", /* 0xA2 */
1161 "VK_RCONTROL", /* 0xA3 */
1162 "VK_LMENU", /* 0xA4 */
1163 "VK_RMENU", /* 0xA5 */
1184 "VK_OEM_1", /* 0xBA */
1185 "VK_OEM_PLUS", /* 0xBB */
1186 "VK_OEM_COMMA", /* 0xBC */
1187 "VK_OEM_MINUS", /* 0xBD */
1188 "VK_OEM_PERIOD", /* 0xBE */
1189 "VK_OEM_2", /* 0xBF */
1190 "VK_OEM_3", /* 0xC0 */
1217 "VK_OEM_4", /* 0xDB */
1218 "VK_OEM_5", /* 0xDC */
1219 "VK_OEM_6", /* 0xDD */
1220 "VK_OEM_7", /* 0xDE */
1221 "VK_OEM_8", /* 0xDF */
1223 "VK_OEM_AX", /* 0xE1 */
1224 "VK_OEM_102", /* 0xE2 */
1225 "VK_ICO_HELP", /* 0xE3 */
1226 "VK_ICO_00", /* 0xE4 */
1227 "VK_PROCESSKEY", /* 0xE5 */
1244 "VK_ATTN", /* 0xF6 */
1245 "VK_CRSEL", /* 0xF7 */
1246 "VK_EXSEL", /* 0xF8 */
1247 "VK_EREOF", /* 0xF9 */
1248 "VK_PLAY", /* 0xFA */
1249 "VK_ZOOM", /* 0xFB */
1250 "VK_NONAME", /* 0xFC */
1251 "VK_PA1", /* 0xFD */
1252 "VK_OEM_CLEAR", /* 0xFE */
1257 /************************************************************************/
1260 /* WM_USER+n message values for "common controls" */
1264 const char *name; /* name of control message */
1265 UINT value; /* message number (0x0401-0x0fff */
1266 UINT len; /* length of space at lParam to dump */
1272 const WCHAR *classname; /* class name to match */
1273 const USER_MSG *classmsg; /* pointer to first USER_MSG for class */
1274 USER_MSG *lastmsg; /* pointer to last USER_MSG for class */
1277 #define USM(a,b) { #a ,a,b}
1278 #define SZOF(a) sizeof(a)
1280 /* To dump memory at the lParam for any of these messages, */
1281 /* replace the "0" with a "SZOF(structure)", or with a */
1282 /* number. (First method prefered.) */
1284 static const USER_MSG rebar_array[] = {
1285 USM(RB_INSERTBANDA, 0),
1286 USM(RB_DELETEBAND, 0),
1287 USM(RB_GETBARINFO, 0),
1288 USM(RB_SETBARINFO, 0),
1289 USM(RB_GETBANDINFO, 0),
1290 USM(RB_SETBANDINFOA, 0),
1291 USM(RB_SETPARENT, 0),
1294 USM(RB_INSERTBANDW, 0),
1295 USM(RB_SETBANDINFOW, 0),
1296 USM(RB_GETBANDCOUNT, 0),
1297 USM(RB_GETROWCOUNT, 0),
1298 USM(RB_GETROWHEIGHT, 0),
1299 USM(RB_IDTOINDEX, 0),
1300 USM(RB_GETTOOLTIPS, 0),
1301 USM(RB_SETTOOLTIPS, 0),
1302 USM(RB_SETBKCOLOR, 0),
1303 USM(RB_GETBKCOLOR, 0),
1304 USM(RB_SETTEXTCOLOR, 0),
1305 USM(RB_GETTEXTCOLOR, 0),
1306 USM(RB_SIZETORECT, 0),
1307 USM(RB_BEGINDRAG, 0),
1309 USM(RB_DRAGMOVE, 0),
1310 USM(RB_GETBARHEIGHT, 0),
1311 USM(RB_GETBANDINFOW, 0),
1312 USM(RB_GETBANDINFOA, 0),
1313 USM(RB_MINIMIZEBAND, 0),
1314 USM(RB_MAXIMIZEBAND, 0),
1315 USM(RB_GETBANDBORDERS, 0),
1316 USM(RB_SHOWBAND, 0),
1317 USM(RB_SETPALETTE, 0),
1318 USM(RB_GETPALETTE, 0),
1319 USM(RB_MOVEBAND, 0),
1322 static const USER_MSG toolbar_array[] = {
1323 USM(TB_ENABLEBUTTON ,0),
1324 USM(TB_CHECKBUTTON ,0),
1325 USM(TB_PRESSBUTTON ,0),
1326 USM(TB_HIDEBUTTON ,0),
1327 USM(TB_INDETERMINATE ,0),
1328 USM(TB_MARKBUTTON ,0),
1329 USM(TB_ISBUTTONENABLED ,0),
1330 USM(TB_ISBUTTONCHECKED ,0),
1331 USM(TB_ISBUTTONPRESSED ,0),
1332 USM(TB_ISBUTTONHIDDEN ,0),
1333 USM(TB_ISBUTTONINDETERMINATE ,0),
1334 USM(TB_ISBUTTONHIGHLIGHTED ,0),
1335 USM(TB_SETSTATE ,0),
1336 USM(TB_GETSTATE ,0),
1337 USM(TB_ADDBITMAP ,0),
1338 USM(TB_ADDBUTTONSA ,0),
1339 USM(TB_INSERTBUTTONA ,0),
1340 USM(TB_DELETEBUTTON ,0),
1341 USM(TB_GETBUTTON ,0),
1342 USM(TB_BUTTONCOUNT ,0),
1343 USM(TB_COMMANDTOINDEX ,0),
1344 USM(TB_SAVERESTOREA ,0),
1345 USM(TB_CUSTOMIZE ,0),
1346 USM(TB_ADDSTRINGA ,0),
1347 USM(TB_GETITEMRECT ,0),
1348 USM(TB_BUTTONSTRUCTSIZE ,0),
1349 USM(TB_SETBUTTONSIZE ,0),
1350 USM(TB_SETBITMAPSIZE ,0),
1351 USM(TB_AUTOSIZE ,0),
1352 USM(TB_GETTOOLTIPS ,0),
1353 USM(TB_SETTOOLTIPS ,0),
1354 USM(TB_SETPARENT ,0),
1357 USM(TB_GETBITMAPFLAGS ,0),
1358 USM(TB_SETCMDID ,0),
1359 USM(TB_CHANGEBITMAP ,0),
1360 USM(TB_GETBITMAP ,0),
1361 USM(TB_GETBUTTONTEXTA ,0),
1362 USM(TB_REPLACEBITMAP ,0),
1363 USM(TB_SETINDENT ,0),
1364 USM(TB_SETIMAGELIST ,0),
1365 USM(TB_GETIMAGELIST ,0),
1366 USM(TB_LOADIMAGES ,0),
1368 USM(TB_SETHOTIMAGELIST ,0),
1369 USM(TB_GETHOTIMAGELIST ,0),
1370 USM(TB_SETDISABLEDIMAGELIST ,0),
1371 USM(TB_GETDISABLEDIMAGELIST ,0),
1372 USM(TB_SETSTYLE ,0),
1373 USM(TB_GETSTYLE ,0),
1374 USM(TB_GETBUTTONSIZE ,0),
1375 USM(TB_SETBUTTONWIDTH ,0),
1376 USM(TB_SETMAXTEXTROWS ,0),
1377 USM(TB_GETTEXTROWS ,0),
1378 USM(TB_GETOBJECT ,0),
1379 USM(TB_GETBUTTONINFOW ,0),
1380 USM(TB_SETBUTTONINFOW ,0),
1381 USM(TB_GETBUTTONINFOA ,0),
1382 USM(TB_SETBUTTONINFOA ,0),
1383 USM(TB_INSERTBUTTONW ,0),
1384 USM(TB_ADDBUTTONSW ,0),
1386 USM(TB_SETDRAWTEXTFLAGS ,0),
1387 USM(TB_GETHOTITEM ,0),
1388 USM(TB_SETHOTITEM ,0),
1389 USM(TB_SETANCHORHIGHLIGHT ,0),
1390 USM(TB_GETANCHORHIGHLIGHT ,0),
1391 USM(TB_GETBUTTONTEXTW ,0),
1392 USM(TB_SAVERESTOREW ,0),
1393 USM(TB_ADDSTRINGW ,0),
1394 USM(TB_MAPACCELERATORA ,0),
1395 USM(TB_GETINSERTMARK ,0),
1396 USM(TB_SETINSERTMARK ,0),
1397 USM(TB_INSERTMARKHITTEST ,0),
1398 USM(TB_MOVEBUTTON ,0),
1399 USM(TB_GETMAXSIZE ,0),
1400 USM(TB_SETEXTENDEDSTYLE ,0),
1401 USM(TB_GETEXTENDEDSTYLE ,0),
1402 USM(TB_GETPADDING ,0),
1403 USM(TB_SETPADDING ,0),
1404 USM(TB_SETINSERTMARKCOLOR ,0),
1405 USM(TB_GETINSERTMARKCOLOR ,0),
1406 USM(TB_MAPACCELERATORW ,0),
1407 USM(TB_GETSTRINGW ,0),
1408 USM(TB_GETSTRINGA ,0),
1409 USM(TB_UNKWN45D ,8),
1410 USM(TB_UNKWN45E ,0),
1411 USM(TB_UNKWN460 ,0),
1412 USM(TB_UNKWN463 ,8),
1413 USM(TB_UNKWN464 ,0),
1416 static const USER_MSG tooltips_array[] = {
1417 USM(TTM_ACTIVATE ,0),
1418 USM(TTM_SETDELAYTIME ,0),
1419 USM(TTM_ADDTOOLA ,0),
1420 USM(TTM_DELTOOLA ,0),
1421 USM(TTM_NEWTOOLRECTA ,0),
1422 USM(TTM_RELAYEVENT ,0),
1423 USM(TTM_GETTOOLINFOA ,0),
1424 USM(TTM_HITTESTA ,0),
1425 USM(TTM_GETTEXTA ,0),
1426 USM(TTM_UPDATETIPTEXTA ,0),
1427 USM(TTM_GETTOOLCOUNT ,0),
1428 USM(TTM_ENUMTOOLSA ,0),
1429 USM(TTM_GETCURRENTTOOLA ,0),
1430 USM(TTM_WINDOWFROMPOINT ,0),
1431 USM(TTM_TRACKACTIVATE ,0),
1432 USM(TTM_TRACKPOSITION ,0),
1433 USM(TTM_SETTIPBKCOLOR ,0),
1434 USM(TTM_SETTIPTEXTCOLOR ,0),
1435 USM(TTM_GETDELAYTIME ,0),
1436 USM(TTM_GETTIPBKCOLOR ,0),
1437 USM(TTM_GETTIPTEXTCOLOR ,0),
1438 USM(TTM_SETMAXTIPWIDTH ,0),
1439 USM(TTM_GETMAXTIPWIDTH ,0),
1440 USM(TTM_SETMARGIN ,0),
1441 USM(TTM_GETMARGIN ,0),
1444 USM(TTM_GETBUBBLESIZE ,0),
1445 USM(TTM_ADDTOOLW ,0),
1446 USM(TTM_DELTOOLW ,0),
1447 USM(TTM_NEWTOOLRECTW ,0),
1448 USM(TTM_GETTOOLINFOW ,0),
1449 USM(TTM_SETTOOLINFOW ,0),
1450 USM(TTM_HITTESTW ,0),
1451 USM(TTM_GETTEXTW ,0),
1452 USM(TTM_UPDATETIPTEXTW ,0),
1453 USM(TTM_ENUMTOOLSW ,0),
1454 USM(TTM_GETCURRENTTOOLW ,0),
1457 static const USER_MSG comboex_array[] = {
1458 USM(CBEM_INSERTITEMA ,0),
1459 USM(CBEM_SETIMAGELIST ,0),
1460 USM(CBEM_GETIMAGELIST ,0),
1461 USM(CBEM_GETITEMA ,0),
1462 USM(CBEM_SETITEMA ,0),
1463 USM(CBEM_GETCOMBOCONTROL ,0),
1464 USM(CBEM_GETEDITCONTROL ,0),
1465 USM(CBEM_SETEXSTYLE ,0),
1466 USM(CBEM_GETEXTENDEDSTYLE ,0),
1467 USM(CBEM_HASEDITCHANGED ,0),
1468 USM(CBEM_INSERTITEMW ,0),
1469 USM(CBEM_SETITEMW ,0),
1470 USM(CBEM_GETITEMW ,0),
1471 USM(CBEM_SETEXTENDEDSTYLE ,0),
1474 static const USER_MSG propsht_array[] = {
1475 USM(PSM_SETCURSEL ,0),
1476 USM(PSM_REMOVEPAGE ,0),
1477 USM(PSM_ADDPAGE ,0),
1478 USM(PSM_CHANGED ,0),
1479 USM(PSM_RESTARTWINDOWS ,0),
1480 USM(PSM_REBOOTSYSTEM ,0),
1481 USM(PSM_CANCELTOCLOSE ,0),
1482 USM(PSM_QUERYSIBLINGS ,0),
1483 USM(PSM_UNCHANGED ,0),
1485 USM(PSM_SETTITLEA ,0),
1486 USM(PSM_SETWIZBUTTONS ,0),
1487 USM(PSM_PRESSBUTTON ,0),
1488 USM(PSM_SETCURSELID ,0),
1489 USM(PSM_SETFINISHTEXTA ,0),
1490 USM(PSM_GETTABCONTROL ,0),
1491 USM(PSM_ISDIALOGMESSAGE ,0),
1492 USM(PSM_GETCURRENTPAGEHWND ,0),
1493 USM(PSM_SETTITLEW ,0),
1494 USM(PSM_SETFINISHTEXTW ,0),
1496 const WCHAR PropSheetInfoStr[] =
1497 {'P','r','o','p','e','r','t','y','S','h','e','e','t','I','n','f','o',0 };
1499 static const USER_MSG updown_array[] = {
1500 USM(UDM_SETRANGE ,0),
1501 USM(UDM_GETRANGE ,0),
1504 USM(UDM_SETBUDDY ,0),
1505 USM(UDM_GETBUDDY ,0),
1506 USM(UDM_SETACCEL ,0),
1507 USM(UDM_GETACCEL ,0),
1508 USM(UDM_SETBASE ,0),
1509 USM(UDM_GETBASE ,0),
1510 USM(UDM_SETRANGE32 ,0),
1511 USM(UDM_GETRANGE32 ,0),
1512 USM(UDM_SETPOS32 ,0),
1513 USM(UDM_GETPOS32 ,0),
1519 static CONTROL_CLASS cc_array[] = {
1520 {WC_COMBOBOXEXW, comboex_array, 0},
1521 {WC_PROPSHEETW, propsht_array, 0},
1522 {REBARCLASSNAMEW, rebar_array, 0},
1523 {TOOLBARCLASSNAMEW, toolbar_array, 0},
1524 {TOOLTIPS_CLASSW, tooltips_array, 0},
1525 {UPDOWN_CLASSW, updown_array, 0},
1529 /************************************************************************/
1532 /* WM_NOTIFY function codes display */
1536 const char *name; /* name of notify message */
1537 UINT value; /* notify code value */
1538 UINT len; /* length of extra space to dump */
1541 #define SPNFY(a,b) { #a ,a,sizeof(b)-sizeof(NMHDR)}
1543 /* Array MUST be in descending order by the 'value' field */
1544 /* (since value is UNSIGNED, 0xffffffff is largest and */
1545 /* 0xfffffffe is smaller). A binary search is used to */
1546 /* locate the correct 'value'. */
1547 static const SPY_NOTIFY spnfy_array[] = {
1548 /* common 0U to 0U-99U */
1549 SPNFY(NM_OUTOFMEMORY, NMHDR),
1550 SPNFY(NM_CLICK, NMHDR),
1551 SPNFY(NM_DBLCLK, NMHDR),
1552 SPNFY(NM_RETURN, NMHDR),
1553 SPNFY(NM_RCLICK, NMHDR),
1554 SPNFY(NM_RDBLCLK, NMHDR),
1555 SPNFY(NM_SETFOCUS, NMHDR),
1556 SPNFY(NM_KILLFOCUS, NMHDR),
1557 SPNFY(NM_CUSTOMDRAW, NMCUSTOMDRAW),
1558 SPNFY(NM_HOVER, NMHDR),
1559 SPNFY(NM_NCHITTEST, NMMOUSE),
1560 SPNFY(NM_KEYDOWN, NMKEY),
1561 SPNFY(NM_RELEASEDCAPTURE, NMHDR),
1562 SPNFY(NM_SETCURSOR, NMMOUSE),
1563 SPNFY(NM_CHAR, NMCHAR),
1564 SPNFY(NM_TOOLTIPSCREATED, NMTOOLTIPSCREATED),
1565 /* Listview 0U-100U to 0U-199U */
1566 SPNFY(LVN_ITEMCHANGING, NMLISTVIEW),
1567 SPNFY(LVN_ITEMCHANGED, NMLISTVIEW),
1568 SPNFY(LVN_INSERTITEM, NMLISTVIEW),
1569 SPNFY(LVN_DELETEITEM, NMLISTVIEW),
1570 SPNFY(LVN_DELETEALLITEMS, NMLISTVIEW),
1571 SPNFY(LVN_BEGINLABELEDITA, NMLVDISPINFOA),
1572 SPNFY(LVN_ENDLABELEDITA, NMLVDISPINFOA),
1573 SPNFY(LVN_COLUMNCLICK, NMLISTVIEW),
1574 SPNFY(LVN_BEGINDRAG, NMLISTVIEW),
1575 SPNFY(LVN_BEGINRDRAG, NMLISTVIEW),
1576 SPNFY(LVN_ODCACHEHINT, NMLVCACHEHINT),
1577 SPNFY(LVN_ITEMACTIVATE, NMITEMACTIVATE),
1578 SPNFY(LVN_ODSTATECHANGED, NMLVODSTATECHANGE),
1579 SPNFY(LVN_HOTTRACK, NMLISTVIEW),
1580 SPNFY(LVN_GETDISPINFOA, NMLVDISPINFOA),
1581 SPNFY(LVN_SETDISPINFOA, NMLVDISPINFOA),
1582 SPNFY(LVN_ODFINDITEMA, NMLVFINDITEMA),
1583 SPNFY(LVN_KEYDOWN, NMLVKEYDOWN),
1584 SPNFY(LVN_MARQUEEBEGIN, NMLISTVIEW),
1585 SPNFY(LVN_GETINFOTIPA, NMLVGETINFOTIPA),
1586 SPNFY(LVN_GETINFOTIPW, NMLVGETINFOTIPW),
1587 SPNFY(LVN_BEGINLABELEDITW, NMLVDISPINFOW),
1588 SPNFY(LVN_ENDLABELEDITW, NMLVDISPINFOW),
1589 SPNFY(LVN_GETDISPINFOW, NMLVDISPINFOW),
1590 SPNFY(LVN_SETDISPINFOW, NMLVDISPINFOW),
1591 SPNFY(LVN_ODFINDITEMW, NMLVFINDITEMW),
1592 /* PropertySheet 0U-200U to 0U-299U */
1593 SPNFY(PSN_SETACTIVE, PSHNOTIFY),
1594 SPNFY(PSN_KILLACTIVE, PSHNOTIFY),
1595 SPNFY(PSN_APPLY, PSHNOTIFY),
1596 SPNFY(PSN_RESET, PSHNOTIFY),
1597 SPNFY(PSN_HELP, PSHNOTIFY),
1598 SPNFY(PSN_WIZBACK, PSHNOTIFY),
1599 SPNFY(PSN_WIZNEXT, PSHNOTIFY),
1600 SPNFY(PSN_WIZFINISH, PSHNOTIFY),
1601 SPNFY(PSN_QUERYCANCEL, PSHNOTIFY),
1602 SPNFY(PSN_GETOBJECT, NMOBJECTNOTIFY),
1603 /* SPNFY(PSN_QUERYINITIALFOCUS, .PSHNOTIFY), NIY */
1604 /* SPNFY(PSN_TRANSLATEACCELERATOR, .PSHNOTIFY), NIY */
1605 /* Header 0U-300U to 0U-399U */
1606 SPNFY(HDN_ITEMCHANGINGA, NMHDR),
1607 SPNFY(HDN_ITEMCHANGEDA, NMHDR),
1608 SPNFY(HDN_ITEMCLICKA, NMHDR),
1609 SPNFY(HDN_ITEMDBLCLICKA, NMHDR),
1610 SPNFY(HDN_DIVIDERDBLCLICKA, NMHDR),
1611 SPNFY(HDN_BEGINTRACKA, NMHDR),
1612 SPNFY(HDN_ENDTRACKA, NMHDR),
1613 SPNFY(HDN_GETDISPINFOA, NMHDR),
1614 SPNFY(HDN_BEGINDRAG, NMHDR),
1615 SPNFY(HDN_ENDDRAG, NMHDR),
1616 SPNFY(HDN_ITEMCHANGINGW, NMHDR),
1617 SPNFY(HDN_ITEMCHANGEDW, NMHDR),
1618 SPNFY(HDN_ITEMCLICKW, NMHDR),
1619 SPNFY(HDN_ITEMDBLCLICKW, NMHDR),
1620 SPNFY(HDN_DIVIDERDBLCLICKW, NMHDR),
1621 SPNFY(HDN_BEGINTRACKW, NMHDR),
1622 SPNFY(HDN_ENDTRACKW, NMHDR),
1623 SPNFY(HDN_GETDISPINFOW, NMHDR),
1624 /* Treeview 0U-400U to 0U-499U */
1625 SPNFY(TVN_SELCHANGINGA, NMHDR),
1626 SPNFY(TVN_SELCHANGEDA, NMHDR),
1627 SPNFY(TVN_GETDISPINFOA, NMHDR),
1628 SPNFY(TVN_SETDISPINFOA, NMHDR),
1629 SPNFY(TVN_ITEMEXPANDINGA, NMHDR),
1630 SPNFY(TVN_ITEMEXPANDEDA, NMHDR),
1631 SPNFY(TVN_BEGINDRAGA, NMHDR),
1632 SPNFY(TVN_BEGINRDRAGA, NMHDR),
1633 SPNFY(TVN_DELETEITEMA, NMHDR),
1634 SPNFY(TVN_BEGINLABELEDITA, NMHDR),
1635 SPNFY(TVN_ENDLABELEDITA, NMHDR),
1636 SPNFY(TVN_KEYDOWN, NMHDR),
1637 SPNFY(TVN_SELCHANGINGW, NMHDR),
1638 SPNFY(TVN_SELCHANGEDW, NMHDR),
1639 SPNFY(TVN_GETDISPINFOW, NMHDR),
1640 SPNFY(TVN_SETDISPINFOW, NMHDR),
1641 SPNFY(TVN_ITEMEXPANDINGW, NMHDR),
1642 SPNFY(TVN_ITEMEXPANDEDW, NMHDR),
1643 SPNFY(TVN_BEGINDRAGW, NMHDR),
1644 SPNFY(TVN_BEGINRDRAGW, NMHDR),
1645 SPNFY(TVN_DELETEITEMW, NMHDR),
1646 SPNFY(TVN_BEGINLABELEDITW, NMHDR),
1647 SPNFY(TVN_ENDLABELEDITW, NMHDR),
1648 /* Tooltips 0U-520U to 0U-549U */
1649 SPNFY(TTN_GETDISPINFOA, NMHDR),
1650 SPNFY(TTN_SHOW, NMHDR),
1651 SPNFY(TTN_POP, NMHDR),
1652 SPNFY(TTN_GETDISPINFOW, NMHDR),
1653 /* Tab 0U-550U to 0U-580U */
1654 SPNFY(TCN_KEYDOWN, NMHDR),
1655 SPNFY(TCN_SELCHANGE, NMHDR),
1656 SPNFY(TCN_SELCHANGING, NMHDR),
1657 SPNFY(TCN_GETOBJECT, NMHDR),
1658 /* Common Dialog 0U-601U to 0U-699U */
1659 /* Toolbar 0U-700U to 0U-720U */
1660 SPNFY(TBN_GETBUTTONINFOA, NMTOOLBARA),
1661 SPNFY(TBN_BEGINDRAG, NMTOOLBARA),
1662 SPNFY(TBN_ENDDRAG, NMTOOLBARA),
1663 SPNFY(TBN_BEGINADJUST, NMHDR),
1664 SPNFY(TBN_ENDADJUST, NMHDR),
1665 SPNFY(TBN_RESET, NMHDR),
1666 SPNFY(TBN_QUERYINSERT, NMTOOLBARA),
1667 SPNFY(TBN_QUERYDELETE, NMTOOLBARA),
1668 SPNFY(TBN_TOOLBARCHANGE, NMHDR),
1669 SPNFY(TBN_CUSTHELP, NMHDR),
1670 SPNFY(TBN_DROPDOWN, NMTOOLBARA),
1671 SPNFY(TBN_GETOBJECT, NMOBJECTNOTIFY),
1672 SPNFY(TBN_HOTITEMCHANGE, NMTBHOTITEM),
1673 SPNFY(TBN_DRAGOUT, NMTOOLBARA),
1674 SPNFY(TBN_DELETINGBUTTON, NMTOOLBARA),
1675 SPNFY(TBN_GETDISPINFOA, NMTBDISPINFOA),
1676 SPNFY(TBN_GETDISPINFOW, NMTBDISPINFOW),
1677 SPNFY(TBN_GETINFOTIPA, NMTBGETINFOTIPA),
1678 SPNFY(TBN_GETINFOTIPW, NMTBGETINFOTIPW),
1679 SPNFY(TBN_GETBUTTONINFOW, NMTOOLBARW),
1680 /* Up/Down 0U-721U to 0U-740U */
1681 SPNFY(UDN_DELTAPOS, NMHDR),
1682 /* Month Calendar 0U-750U to 0U-759U */
1683 /* ******************* WARNING ***************************** */
1684 /* The following appear backwards but needs to be this way. */
1685 /* The reason is that MS (and us) define the MCNs as */
1687 /* instead of the way ALL other notifications are */
1689 /* The only place that this is important is in this list */
1691 /* Also since the same error was made with the DTN_ items, */
1692 /* they overlay the MCN_ and need to be inserted in the */
1693 /* other section of the table so that it is in order for */
1694 /* the binary search. */
1696 /* Thank you MS for your obvious quality control!! */
1697 /* ******************* WARNING ***************************** */
1698 /* Date/Time 0U-760U to 0U-799U */
1699 /* SPNFY(MCN_SELECT, NMHDR), */
1700 /* SPNFY(MCN_GETDAYSTATE, NMHDR), */
1701 /* SPNFY(MCN_SELCHANGE, NMHDR), */
1702 /* ******************* WARNING ***************************** */
1703 /* The following appear backwards but needs to be this way. */
1704 /* The reason is that MS (and us) define the MCNs as */
1706 /* instead of the way ALL other notifications are */
1708 /* The only place that this is important is in this list */
1709 /* ******************* WARNING ***************************** */
1710 SPNFY(DTN_FORMATQUERYW, NMHDR),
1711 SPNFY(DTN_FORMATW, NMHDR),
1712 SPNFY(DTN_WMKEYDOWNW, NMHDR),
1713 SPNFY(DTN_USERSTRINGW, NMHDR),
1714 SPNFY(MCN_SELECT, NMHDR),
1715 SPNFY(MCN_GETDAYSTATE, NMHDR),
1716 SPNFY(MCN_SELCHANGE, NMHDR),
1717 SPNFY(DTN_CLOSEUP, NMHDR),
1718 SPNFY(DTN_DROPDOWN, NMHDR),
1719 SPNFY(DTN_FORMATQUERYA, NMHDR),
1720 SPNFY(DTN_FORMATA, NMHDR),
1721 SPNFY(DTN_WMKEYDOWNA, NMHDR),
1722 SPNFY(DTN_USERSTRINGA, NMHDR),
1723 SPNFY(DTN_DATETIMECHANGE, NMHDR),
1724 /* ComboBoxEx 0U-800U to 0U-830U */
1725 SPNFY(CBEN_GETDISPINFOA, NMCOMBOBOXEXA),
1726 SPNFY(CBEN_INSERTITEM, NMCOMBOBOXEXA),
1727 SPNFY(CBEN_DELETEITEM, NMCOMBOBOXEXA),
1728 SPNFY(CBEN_BEGINEDIT, NMHDR),
1729 SPNFY(CBEN_ENDEDITA, NMCBEENDEDITA),
1730 SPNFY(CBEN_ENDEDITW, NMCBEENDEDITW),
1731 SPNFY(CBEN_GETDISPINFOW, NMCOMBOBOXEXW),
1732 SPNFY(CBEN_DRAGBEGINA, NMCBEDRAGBEGINA),
1733 SPNFY(CBEN_DRAGBEGINW, NMCBEDRAGBEGINW),
1734 /* Rebar 0U-831U to 0U-859U */
1735 SPNFY(RBN_HEIGHTCHANGE, NMHDR),
1736 SPNFY(RBN_GETOBJECT, NMOBJECTNOTIFY),
1737 SPNFY(RBN_LAYOUTCHANGED, NMHDR),
1738 SPNFY(RBN_AUTOSIZE, NMRBAUTOSIZE),
1739 SPNFY(RBN_BEGINDRAG, NMREBAR),
1740 SPNFY(RBN_ENDDRAG, NMREBAR),
1741 SPNFY(RBN_DELETINGBAND, NMREBAR),
1742 SPNFY(RBN_DELETEDBAND, NMREBAR),
1743 SPNFY(RBN_CHILDSIZE, NMREBARCHILDSIZE),
1744 /* IP Adderss 0U-860U to 0U-879U */
1745 SPNFY(IPN_FIELDCHANGED, NMHDR),
1746 /* Status bar 0U-880U to 0U-899U */
1747 SPNFY(SBN_SIMPLEMODECHANGE, NMHDR),
1748 /* Pager 0U-900U to 0U-950U */
1749 SPNFY(PGN_SCROLL, NMPGSCROLL),
1750 SPNFY(PGN_CALCSIZE, NMPGCALCSIZE),
1752 static const SPY_NOTIFY *end_spnfy_array; /* ptr to last good entry in array */
1756 static BOOL16 SPY_Exclude[SPY_MAX_MSGNUM+1];
1757 static BOOL16 SPY_ExcludeDWP = 0;
1759 #define SPY_EXCLUDE(msg) \
1760 (SPY_Exclude[(msg) > SPY_MAX_MSGNUM ? SPY_MAX_MSGNUM : (msg)])
1765 UINT msgnum; /* message number */
1766 HWND msg_hwnd; /* window handle for message */
1767 WPARAM wParam; /* message parameter */
1768 LPARAM lParam; /* message parameter */
1769 INT data_len; /* length of data to dump */
1770 char msg_name[60]; /* message name (see SPY_GetMsgName) */
1771 WCHAR wnd_class[60]; /* window class name (full) */
1772 WCHAR wnd_name[16]; /* window name for message */
1775 /* This is defined so that the external entry point can return the addr */
1776 static SPY_INSTANCE ext_sp_e;
1778 static int indent_tls_index;
1780 /***********************************************************************
1783 inline static int get_indent_level(void)
1785 return (int)TlsGetValue( indent_tls_index );
1789 /***********************************************************************
1792 inline static void set_indent_level( int level )
1794 TlsSetValue( indent_tls_index, (void *)level );
1798 /***********************************************************************
1799 * SPY_GetMsgInternal
1801 static const char *SPY_GetMsgInternal( UINT msg )
1803 static char msg_buffer[20];
1805 if (msg <= SPY_MAX_MSGNUM)
1807 if (!MessageTypeNames[msg]) return "???";
1808 return MessageTypeNames[msg];
1811 if (msg >= LVM_FIRST && msg <= LVM_FIRST + SPY_MAX_LVMMSGNUM)
1813 if (!LVMMessageTypeNames[msg-LVM_FIRST]) return "LVM_?";
1814 return LVMMessageTypeNames[msg-LVM_FIRST];
1817 if (msg >= TV_FIRST && msg <= TV_FIRST + SPY_MAX_TVMSGNUM)
1819 if (!TVMessageTypeNames[msg-TV_FIRST]) return "TV_?";
1820 return TVMessageTypeNames[msg-TV_FIRST];
1823 if (msg >= HDM_FIRST && msg <= HDM_FIRST + SPY_MAX_HDMMSGNUM)
1825 if (!HDMMessageTypeNames[msg-HDM_FIRST]) return "HDM_?";
1826 return HDMMessageTypeNames[msg-HDM_FIRST];
1829 if (msg >= TCM_FIRST && msg <= TCM_FIRST + SPY_MAX_TCMMSGNUM)
1831 if (!TCMMessageTypeNames[msg-TCM_FIRST]) return "TCM_?";
1832 return TCMMessageTypeNames[msg-TCM_FIRST];
1835 if (msg >= PGM_FIRST && msg <= PGM_FIRST + SPY_MAX_PGMMSGNUM)
1837 if (!PGMMessageTypeNames[msg-PGM_FIRST]) return "PGM_?";
1838 return PGMMessageTypeNames[msg-PGM_FIRST];
1841 if (msg >= CCM_FIRST && msg <= CCM_FIRST + SPY_MAX_CCMMSGNUM)
1843 if (!CCMMessageTypeNames[msg-CCM_FIRST]) return "???";
1844 return CCMMessageTypeNames[msg-CCM_FIRST];
1847 if (msg >= WM_WINE_DESTROYWINDOW && msg <= WM_WINE_DESTROYWINDOW + SPY_MAX_WINEMSGNUM)
1849 if (!WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW]) return "???";
1850 return WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW];
1853 sprintf( msg_buffer, "WM_USER+%04x", msg - WM_USER );
1857 /***********************************************************************
1860 const USER_MSG *SPY_Bsearch_Msg( const USER_MSG *first, const USER_MSG *last, UINT code)
1863 const USER_MSG *test;
1865 while (last >= first) {
1866 count = 1 + last - first;
1869 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
1870 code, first->value, first->name, last->value, last->name, last->len);
1872 if (first->value == code) return first;
1873 if (last->value == code) return last;
1877 test = first + count;
1879 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
1880 first, last, test, test->value, code, count);
1882 if (test->value == code) return test;
1883 if (test->value > code)
1891 /***********************************************************************
1894 * Get message name and other information for dumping
1896 static void SPY_GetMsgStuff( SPY_INSTANCE *sp_e )
1900 sp_e->msg_name[sizeof(sp_e->msg_name)-1] = 0;
1901 strncpy (sp_e->msg_name, SPY_GetMsgInternal( sp_e->msgnum ),
1902 sizeof(sp_e->msg_name)-1);
1905 if (strncmp(sp_e->msg_name, "WM_USER+", 8) == 0) {
1909 TRACE("looking class %s\n", sp_e->wnd_class);
1912 while (cc_array[i].classname &&
1913 strcmpW(cc_array[i].classname, sp_e->wnd_class) !=0) i++;
1915 if (!cc_array[i].classname) return;
1917 TRACE("process class %s, first %p, last %p\n",
1918 debugstr_w(cc_array[i].classname), cc_array[i].classmsg,
1919 cc_array[i].lastmsg);
1921 p = SPY_Bsearch_Msg (cc_array[i].classmsg, cc_array[i].lastmsg,
1924 strncpy (sp_e->msg_name, p->name, sizeof(sp_e->msg_name)-1);
1925 sp_e->data_len = p->len;
1930 /***********************************************************************
1933 * Sets the value of "wnd_name" and "wnd_class" members of the
1934 * instance structure.
1937 void SPY_GetWndName( SPY_INSTANCE *sp_e )
1942 /* save and restore error code over the next call */
1943 save_error = GetLastError();
1944 /* special code to detect a property sheet dialog */
1945 if ((GetClassLongW(sp_e->msg_hwnd, GCW_ATOM) == (LONG)WC_DIALOGW) &&
1946 (GetPropW(sp_e->msg_hwnd, PropSheetInfoStr))) {
1947 strcpyW(sp_e->wnd_class, WC_PROPSHEETW);
1950 GetClassNameW(sp_e->msg_hwnd, sp_e->wnd_class, sizeof(sp_e->wnd_class)/sizeof(WCHAR));
1952 SetLastError(save_error);
1954 len = InternalGetWindowText(sp_e->msg_hwnd, sp_e->wnd_name, sizeof(sp_e->wnd_name)/sizeof(WCHAR));
1955 if(!len) /* get class name */
1957 LPWSTR dst = sp_e->wnd_name;
1958 LPWSTR src = sp_e->wnd_class;
1959 int n = sizeof(sp_e->wnd_name)/sizeof(WCHAR) - 3;
1961 while ((n-- > 0) && *src) *dst++ = *src++;
1967 /***********************************************************************
1970 * **** External function ****
1974 const char *SPY_GetMsgName( UINT msg, HWND hWnd )
1976 ext_sp_e.msgnum = msg;
1977 ext_sp_e.msg_hwnd = hWnd;
1978 ext_sp_e.lParam = 0;
1979 ext_sp_e.wParam = 0;
1980 SPY_GetWndName(&ext_sp_e);
1981 SPY_GetMsgStuff(&ext_sp_e);
1982 return ext_sp_e.msg_name;
1985 /***********************************************************************
1988 const char *SPY_GetVKeyName(WPARAM wParam)
1990 const char *vk_key_name;
1992 if(wParam <= SPY_MAX_VKKEYSNUM && VK_KeyNames[wParam])
1993 vk_key_name = VK_KeyNames[wParam];
1995 vk_key_name = "VK_???";
2000 /***********************************************************************
2001 * SPY_Bsearch_Notify
2003 const SPY_NOTIFY *SPY_Bsearch_Notify( const SPY_NOTIFY *first, const SPY_NOTIFY *last, UINT code)
2006 const SPY_NOTIFY *test;
2008 while (last >= first) {
2009 count = 1 + last - first;
2012 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
2013 code, first->value, first->name, last->value, last->name, last->len);
2015 if (first->value == code) return first;
2016 if (last->value == code) return last;
2020 test = first + count;
2022 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
2023 first, last, test, test->value, code, count);
2025 if (test->value == code) return test;
2026 if (test->value < code)
2034 /***********************************************************************
2037 void SPY_DumpMem (LPSTR header, UINT *q, INT len)
2041 for(i=0; i<len-12; i+=16) {
2042 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2043 header, i, *q, *(q+1), *(q+2), *(q+3));
2046 switch ((len - i + 3) & (~3)) {
2048 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2049 header, i, *q, *(q+1), *(q+2), *(q+3));
2052 TRACE("%s [%04x] %08x %08x %08x\n",
2053 header, i, *q, *(q+1), *(q+2));
2056 TRACE("%s [%04x] %08x %08x\n",
2057 header, i, *q, *(q+1));
2060 TRACE("%s [%04x] %08x\n",
2068 /***********************************************************************
2071 void SPY_DumpStructure (SPY_INSTANCE *sp_e, BOOL enter)
2073 switch (sp_e->msgnum)
2075 case LVM_INSERTITEMW:
2076 case LVM_INSERTITEMA:
2084 LPLVITEMA item = (LPLVITEMA) sp_e->lParam;
2086 SPY_DumpMem ("LVITEM", (UINT*)item, sizeof(LVITEMA));
2090 case TCM_INSERTITEMW:
2091 case TCM_INSERTITEMA:
2099 TCITEMA *item = (TCITEMA *) sp_e->lParam;
2101 SPY_DumpMem ("TCITEM", (UINT*)item, sizeof(TCITEMA));
2105 case TCM_ADJUSTRECT:
2106 case LVM_GETITEMRECT:
2107 case LVM_GETSUBITEMRECT:
2109 LPRECT rc = (LPRECT) sp_e->lParam;
2111 TRACE("lParam rect (%d,%d)-(%d,%d)\n",
2112 rc->left, rc->top, rc->right, rc->bottom);
2116 case LVM_SETITEMPOSITION32:
2119 case LVM_GETITEMPOSITION:
2122 LPPOINT point = (LPPOINT) sp_e->lParam;
2124 TRACE("lParam point x=%ld, y=%ld\n", point->x, point->y);
2129 if (!enter && (sp_e->msgnum == SBM_SETRANGE)) break;
2130 TRACE("min=%d max=%d\n", (INT)sp_e->wParam, (INT)sp_e->lParam);
2133 if ((enter && (sp_e->msgnum == SBM_GETRANGE)) ||
2134 (!enter && (sp_e->msgnum == SBM_SETRANGE))) break;
2136 LPINT ptmin = (LPINT) sp_e->wParam;
2137 LPINT ptmax = (LPINT) sp_e->lParam;
2139 TRACE("min=%d max=%d\n", *ptmin, *ptmax);
2141 TRACE("min=%d max=n/a\n", *ptmin);
2143 TRACE("min=n/a max=%d\n", *ptmax);
2149 DRAWITEMSTRUCT *lpdis = (DRAWITEMSTRUCT*) sp_e->lParam;
2150 TRACE("DRAWITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2151 lpdis->CtlType, lpdis->CtlID);
2152 TRACE("itemID=0x%08x itemAction=0x%08x itemState=0x%08x\n",
2153 lpdis->itemID, lpdis->itemAction, lpdis->itemState);
2154 TRACE("hWnd=0x%04x hDC=0x%04x (%d,%d)-(%d,%d) itemData=0x%08lx\n",
2155 lpdis->hwndItem, lpdis->hDC, lpdis->rcItem.left,
2156 lpdis->rcItem.top, lpdis->rcItem.right,
2157 lpdis->rcItem.bottom, lpdis->itemData);
2160 case WM_MEASUREITEM:
2162 MEASUREITEMSTRUCT *lpmis = (MEASUREITEMSTRUCT*) sp_e->lParam;
2163 TRACE("MEASUREITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2164 lpmis->CtlType, lpmis->CtlID);
2165 TRACE("itemID=0x%08x itemWidth=0x%08x itemHeight=0x%08x\n",
2166 lpmis->itemID, lpmis->itemWidth, lpmis->itemHeight);
2167 TRACE("itemData=0x%08lx\n", lpmis->itemData);
2170 case WM_WINDOWPOSCHANGED:
2172 case WM_WINDOWPOSCHANGING:
2174 WINDOWPOS *lpwp = (WINDOWPOS *)sp_e->lParam;
2175 TRACE("WINDOWPOS hwnd=0x%04x, after=0x%04x, at (%d,%d) w=%d h=%d, flags=0x%08x\n",
2176 lpwp->hwnd, lpwp->hwndInsertAfter, lpwp->x, lpwp->y,
2177 lpwp->cx, lpwp->cy, lpwp->flags);
2180 case WM_STYLECHANGED:
2182 case WM_STYLECHANGING:
2184 LPSTYLESTRUCT ss = (LPSTYLESTRUCT) sp_e->lParam;
2185 TRACE("STYLESTRUCT: StyleOld=0x%08lx, StyleNew=0x%08lx\n",
2186 ss->styleOld, ss->styleNew);
2191 RECT *rc = (RECT *)sp_e->lParam;
2192 TRACE("Rect (%d,%d)-(%d,%d)\n",
2193 rc->left, rc->top, rc->right, rc->bottom);
2197 /* if (!enter) break; */
2199 NMHDR * pnmh = (NMHDR*) sp_e->lParam;
2201 const SPY_NOTIFY *p;
2202 WCHAR from_class[60];
2205 p = SPY_Bsearch_Notify (&spnfy_array[0], end_spnfy_array,
2208 TRACE("NMHDR hwndFrom=0x%08x idFrom=0x%08x code=%s<0x%08x>, extra=0x%x\n",
2209 pnmh->hwndFrom, pnmh->idFrom, p->name, pnmh->code, p->len);
2212 /* for CUSTOMDRAW, dump all the data for TOOLBARs */
2213 if (pnmh->code == NM_CUSTOMDRAW) {
2214 /* save and restore error code over the next call */
2215 save_error = GetLastError();
2216 GetClassNameW(pnmh->hwndFrom, from_class,
2217 sizeof(from_class)/sizeof(WCHAR));
2218 SetLastError(save_error);
2219 if (strcmpW(TOOLBARCLASSNAMEW, from_class) == 0)
2220 dumplen = sizeof(NMTBCUSTOMDRAW)-sizeof(NMHDR);
2223 q = (UINT *)(pnmh + 1);
2224 SPY_DumpMem ("NM extra", q, (INT)dumplen);
2228 TRACE("NMHDR hwndFrom=0x%08x idFrom=0x%08x code=0x%08x\n",
2229 pnmh->hwndFrom, pnmh->idFrom, pnmh->code);
2232 if (sp_e->data_len > 0)
2233 SPY_DumpMem ("MSG lParam", (UINT *)sp_e->lParam, sp_e->data_len);
2238 /***********************************************************************
2241 void SPY_EnterMessage( INT iFlag, HWND hWnd, UINT msg,
2242 WPARAM wParam, LPARAM lParam )
2247 if (!TRACE_ON(message) || SPY_EXCLUDE(msg)) return;
2250 sp_e.msg_hwnd = hWnd;
2251 sp_e.lParam = lParam;
2252 sp_e.wParam = wParam;
2253 SPY_GetWndName(&sp_e);
2254 SPY_GetMsgStuff(&sp_e);
2255 indent = get_indent_level();
2257 /* each SPY_SENDMESSAGE must be complemented by call to SPY_ExitMessage */
2260 case SPY_DISPATCHMESSAGE16:
2261 TRACE("%*s(%04x) %-16s message [%04x] %s dispatched wp=%04x lp=%08lx\n",
2262 indent, "", HWND_16(hWnd),
2263 debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name, wParam, lParam);
2266 case SPY_DISPATCHMESSAGE:
2267 TRACE("%*s(%08x) %-16s message [%04x] %s dispatched wp=%08x lp=%08lx\n",
2268 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2269 sp_e.msg_name, wParam, lParam);
2272 case SPY_SENDMESSAGE16:
2273 case SPY_SENDMESSAGE:
2276 HTASK16 hTask = GetWindowTask16( HWND_16(hWnd) );
2278 if (hTask == GetCurrentTask()) strcpy( taskName, "self" );
2279 else if (!hTask) strcpy( taskName, "Wine" );
2282 sprintf( taskName, "task %04x ???", hTask );
2283 GetModuleName16( hTask, taskName + 10, sizeof(taskName) - 10 );
2286 if (iFlag == SPY_SENDMESSAGE16)
2287 TRACE("%*s(%04x) %-16s message [%04x] %s sent from %s wp=%04x lp=%08lx\n",
2288 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2289 sp_e.msg_name, taskName, wParam, lParam );
2291 { TRACE("%*s(%08x) %-16s message [%04x] %s sent from %s wp=%08x lp=%08lx\n",
2292 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2293 sp_e.msg_name, taskName, wParam, lParam );
2294 SPY_DumpStructure(&sp_e, TRUE);
2299 case SPY_DEFWNDPROC16:
2300 if( SPY_ExcludeDWP ) return;
2301 TRACE("%*s(%04x) DefWindowProc16: %s [%04x] wp=%04x lp=%08lx\n",
2302 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, wParam, lParam );
2305 case SPY_DEFWNDPROC:
2306 if( SPY_ExcludeDWP ) return;
2307 TRACE("%*s(%08x) DefWindowProc32: %s [%04x] wp=%08x lp=%08lx\n",
2308 indent, "", hWnd, sp_e.msg_name,
2309 msg, wParam, lParam );
2312 set_indent_level( indent + SPY_INDENT_UNIT );
2316 /***********************************************************************
2319 void SPY_ExitMessage( INT iFlag, HWND hWnd, UINT msg, LRESULT lReturn,
2320 WPARAM wParam, LPARAM lParam )
2325 if (!TRACE_ON(message) || SPY_EXCLUDE(msg) ||
2326 (SPY_ExcludeDWP && (iFlag == SPY_RESULT_DEFWND16 || iFlag == SPY_RESULT_DEFWND)) )
2330 sp_e.msg_hwnd = hWnd;
2331 sp_e.lParam = lParam;
2332 sp_e.wParam = wParam;
2333 SPY_GetWndName(&sp_e);
2334 SPY_GetMsgStuff(&sp_e);
2336 if ((indent = get_indent_level()))
2338 indent -= SPY_INDENT_UNIT;
2339 set_indent_level( indent );
2344 case SPY_RESULT_DEFWND16:
2345 TRACE(" %*s(%04x) DefWindowProc16: %s [%04x] returned %08lx\n",
2346 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, lReturn );
2349 case SPY_RESULT_DEFWND:
2350 TRACE(" %*s(%08x) DefWindowProc32: %s [%04x] returned %08lx\n",
2351 indent, "", hWnd, sp_e.msg_name, msg, lReturn );
2354 case SPY_RESULT_OK16:
2355 TRACE(" %*s(%04x) %-16s message [%04x] %s returned %08lx\n",
2356 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2357 sp_e.msg_name, lReturn );
2361 TRACE(" %*s(%08x) %-16s message [%04x] %s returned %08lx\n",
2362 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2363 sp_e.msg_name, lReturn );
2364 SPY_DumpStructure(&sp_e, FALSE);
2367 case SPY_RESULT_INVALIDHWND16:
2368 WARN(" %*s(%04x) %-16s message [%04x] %s HAS INVALID HWND\n",
2369 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name );
2372 case SPY_RESULT_INVALIDHWND:
2373 WARN(" %*s(%08x) %-16s message [%04x] %s HAS INVALID HWND\n",
2374 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2381 /***********************************************************************
2388 const SPY_NOTIFY *p;
2392 if (!TRACE_ON(message)) return TRUE;
2394 indent_tls_index = TlsAlloc();
2395 if(!RegOpenKeyA(HKEY_LOCAL_MACHINE, "Software\\Wine\\Wine\\Config\\Debug", &hkey))
2397 DWORD type, count = sizeof(buffer);
2400 if (!RegQueryValueExA(hkey, "SpyInclude", 0, &type, buffer, &count) &&
2401 strcmp( buffer, "INCLUDEALL" ))
2403 TRACE("Include=%s\n", buffer );
2404 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2405 SPY_Exclude[i] = (MessageTypeNames[i] && !strstr(buffer,MessageTypeNames[i]));
2408 count = sizeof(buffer);
2410 if (!RegQueryValueExA(hkey, "SpyExclude", 0, &type, buffer, &count))
2412 TRACE("Exclude=%s\n", buffer );
2413 if (!strcmp( buffer, "EXCLUDEALL" ))
2414 for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = TRUE;
2416 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2417 SPY_Exclude[i] = (MessageTypeNames[i] && strstr(buffer,MessageTypeNames[i]));
2421 count = sizeof(buffer);
2422 if(!RegQueryValueExA(hkey, "SpyExcludeDWP", 0, &type, buffer, &count))
2423 SPY_ExcludeDWP = atoi(buffer);
2428 /* find last good entry in spy notify array and save addr for b-search */
2429 p = &spnfy_array[0];
2432 if ((UINT)p->value > (UINT)j) {
2433 ERR("Notify message array out of order\n");
2434 ERR(" between values [%08x] %s and [%08x] %s\n",
2435 j, (p-1)->name, p->value, p->name);
2442 end_spnfy_array = p;
2444 /* find last good entry in each common control message array
2445 * and save addr for b-search.
2448 while (cc_array[i].classname) {
2450 j = 0x0400; /* minimum entry in array */
2451 q = cc_array[i].classmsg;
2453 if (q->value <= j) {
2454 ERR("Class message array out of order for class %s\n",
2455 debugstr_w(cc_array[i].classname));
2456 ERR(" between values [%04x] %s and [%04x] %s\n",
2457 j, (q-1)->name, q->value, q->name);
2464 cc_array[i].lastmsg = (USER_MSG *)q;