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
31 #include "wine/unicode.h"
33 #include "wine/debug.h"
39 WINE_DEFAULT_DEBUG_CHANNEL(message);
41 #define SPY_MAX_MSGNUM WM_USER
42 #define SPY_INDENT_UNIT 4 /* 4 spaces */
46 static const char * const MessageTypeNames[SPY_MAX_MSGNUM + 1] =
64 "WM_CLOSE", /* 0x10 */
80 "WM_SETCURSOR", /* 0x20 */
96 "WM_SETFONT", /* 0x30 */
108 "wm_otherwindowcreated",
109 "wm_otherwindowdestroyed",
110 "wm_activateshellwindow",
114 "wm_compacting", NULL, NULL,
115 "WM_COMMNOTIFY", NULL,
116 "WM_WINDOWPOSCHANGING", /* 0x0046 */
117 "WM_WINDOWPOSCHANGED", /* 0x0047 */
120 "WM_CANCELJOURNAL", NULL, NULL,
124 "WM_INPUTLANGCHANGEREQUEST",
125 "WM_INPUTLANGCHANGE",
129 "WM_NOTIFYFORMAT", NULL, NULL,
130 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
133 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
134 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
137 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
145 "WM_SETICON", /* 0x0080 */
146 "WM_NCCREATE", /* 0x0081 */
147 "WM_NCDESTROY", /* 0x0082 */
148 "WM_NCCALCSIZE", /* 0x0083 */
149 "WM_NCHITTEST", /* 0x0084 */
150 "WM_NCPAINT", /* 0x0085 */
151 "WM_NCACTIVATE", /* 0x0086 */
152 "WM_GETDLGCODE", /* 0x0087 */
154 "WM_SYNCTASK", NULL, NULL, NULL, NULL, NULL, NULL,
157 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
158 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
161 "WM_NCMOUSEMOVE", /* 0x00A0 */
162 "WM_NCLBUTTONDOWN", /* 0x00A1 */
163 "WM_NCLBUTTONUP", /* 0x00A2 */
164 "WM_NCLBUTTONDBLCLK", /* 0x00A3 */
165 "WM_NCRBUTTONDOWN", /* 0x00A4 */
166 "WM_NCRBUTTONUP", /* 0x00A5 */
167 "WM_NCRBUTTONDBLCLK", /* 0x00A6 */
168 "WM_NCMBUTTONDOWN", /* 0x00A7 */
169 "WM_NCMBUTTONUP", /* 0x00A8 */
170 "WM_NCMBUTTONDBLCLK", /* 0x00A9 */
171 NULL, NULL, NULL, NULL, NULL, NULL,
173 /* 0x00B0 - Win32 Edit controls */
174 "EM_GETSEL", /* 0x00b0 */
175 "EM_SETSEL", /* 0x00b1 */
176 "EM_GETRECT", /* 0x00b2 */
177 "EM_SETRECT", /* 0x00b3 */
178 "EM_SETRECTNP", /* 0x00b4 */
179 "EM_SCROLL", /* 0x00b5 */
180 "EM_LINESCROLL", /* 0x00b6 */
181 "EM_SCROLLCARET", /* 0x00b7 */
182 "EM_GETMODIFY", /* 0x00b8 */
183 "EM_SETMODIFY", /* 0x00b9 */
184 "EM_GETLINECOUNT", /* 0x00ba */
185 "EM_LINEINDEX", /* 0x00bb */
186 "EM_SETHANDLE", /* 0x00bc */
187 "EM_GETHANDLE", /* 0x00bd */
188 "EM_GETTHUMB", /* 0x00be */
192 "EM_LINELENGTH", /* 0x00c1 */
193 "EM_REPLACESEL", /* 0x00c2 */
195 "EM_GETLINE", /* 0x00c4 */
196 "EM_LIMITTEXT", /* 0x00c5 */
197 "EM_CANUNDO", /* 0x00c6 */
198 "EM_UNDO", /* 0x00c7 */
199 "EM_FMTLINES", /* 0x00c8 */
200 "EM_LINEFROMCHAR", /* 0x00c9 */
202 "EM_SETTABSTOPS", /* 0x00cb */
203 "EM_SETPASSWORDCHAR", /* 0x00cc */
204 "EM_EMPTYUNDOBUFFER", /* 0x00cd */
205 "EM_GETFIRSTVISIBLELINE", /* 0x00ce */
206 "EM_SETREADONLY", /* 0x00cf */
208 "EM_SETWORDBREAKPROC", /* 0x00d0 */
209 "EM_GETWORDBREAKPROC", /* 0x00d1 */
210 "EM_GETPASSWORDCHAR", /* 0x00d2 */
211 "EM_SETMARGINS", /* 0x00d3 */
212 "EM_GETMARGINS", /* 0x00d4 */
213 "EM_GETLIMITTEXT", /* 0x00d5 */
214 "EM_POSFROMCHAR", /* 0x00d6 */
215 "EM_CHARFROMPOS", /* 0x00d7 */
216 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
218 /* 0x00E0 - Win32 Scrollbars */
219 "SBM_SETPOS", /* 0x00e0 */
220 "SBM_GETPOS", /* 0x00e1 */
221 "SBM_SETRANGE", /* 0x00e2 */
222 "SBM_GETRANGE", /* 0x00e3 */
223 "SBM_ENABLE_ARROWS", /* 0x00e4 */
225 "SBM_SETRANGEREDRAW", /* 0x00e6 */
227 "SBM_SETSCROLLINFO", /* 0x00e9 */
228 "SBM_GETSCROLLINFO", /* 0x00ea */
229 NULL, NULL, NULL, NULL, NULL,
231 /* 0x00F0 - Win32 Buttons */
232 "BM_GETCHECK", /* 0x00f0 */
233 "BM_SETCHECK", /* 0x00f1 */
234 "BM_GETSTATE", /* 0x00f2 */
235 "BM_SETSTATE", /* 0x00f3 */
236 "BM_SETSTYLE", /* 0x00f4 */
237 "BM_CLICK", /* 0x00f5 */
238 "BM_GETIMAGE", /* 0x00f6 */
239 "BM_SETIMAGE", /* 0x00f7 */
240 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
242 "WM_KEYDOWN", /* 0x0100 */
243 "WM_KEYUP", /* 0x0101 */
244 "WM_CHAR", /* 0x0102 */
245 "WM_DEADCHAR", /* 0x0103 */
246 "WM_SYSKEYDOWN", /* 0x0104 */
247 "WM_SYSKEYUP", /* 0x0105 */
248 "WM_SYSCHAR", /* 0x0106 */
249 "WM_SYSDEADCHAR", /* 0x0107 */
250 "WM_KEYLAST", /* 0x0108 */
255 "WM_IME_STARTCOMPOSITION", /* 0x010d */
256 "WM_IME_ENDCOMPOSITION", /* 0x010e */
257 "WM_IME_COMPOSITION", /* 0x010f */
259 "WM_INITDIALOG", /* 0x0110 */
260 "WM_COMMAND", /* 0x0111 */
261 "WM_SYSCOMMAND", /* 0x0112 */
262 "WM_TIMER", /* 0x0113 */
263 "WM_HSCROLL", /* 0x0114 */
264 "WM_VSCROLL", /* 0x0115 */
265 "WM_INITMENU", /* 0x0116 */
266 "WM_INITMENUPOPUP", /* 0x0117 */
267 "WM_SYSTIMER", /* 0x0118 */
268 NULL, NULL, NULL, NULL, NULL, NULL,
269 "WM_MENUSELECT", /* 0x011f */
271 "WM_MENUCHAR", /* 0x0120 */
272 "WM_ENTERIDLE", /* 0x0121 */
274 "WM_MENURBUTTONUP", /* 0x0122 */
275 "WM_MENUDRAG", /* 0x0123 */
276 "WM_MENUGETOBJECT", /* 0x0124 */
277 "WM_UNINITMENUPOPUP", /* 0x0125 */
278 "WM_MENUCOMMAND", /* 0x0126 */
279 "WM_CHANGEUISTATE", /* 0x0127 */
280 "WM_UPDATEUISTATE", /* 0x0128 */
281 "WM_QUERYUISTATE", /* 0x0129 */
283 NULL, NULL, NULL, NULL, NULL, NULL,
287 "WM_LBTRACKPOINT", /* 0x0131 */
288 "WM_CTLCOLORMSGBOX", /* 0x0132 */
289 "WM_CTLCOLOREDIT", /* 0x0133 */
290 "WM_CTLCOLORLISTBOX", /* 0x0134 */
291 "WM_CTLCOLORBTN", /* 0x0135 */
292 "WM_CTLCOLORDLG", /* 0x0136 */
293 "WM_CTLCOLORSCROLLBAR", /* 0x0137 */
294 "WM_CTLCOLORSTATIC", /* 0x0138 */
295 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
297 /* 0x0140 - Win32 Comboboxes */
298 "CB_GETEDITSEL", /* 0x0140 */
299 "CB_LIMITTEXT", /* 0x0141 */
300 "CB_SETEDITSEL", /* 0x0142 */
301 "CB_ADDSTRING", /* 0x0143 */
302 "CB_DELETESTRING", /* 0x0144 */
303 "CB_DIR", /* 0x0145 */
304 "CB_GETCOUNT", /* 0x0146 */
305 "CB_GETCURSEL", /* 0x0147 */
306 "CB_GETLBTEXT", /* 0x0148 */
307 "CB_GETLBTEXTLEN", /* 0x0149 */
308 "CB_INSERTSTRING", /* 0x014a */
309 "CB_RESETCONTENT", /* 0x014b */
310 "CB_FINDSTRING", /* 0x014c */
311 "CB_SELECTSTRING", /* 0x014d */
312 "CB_SETCURSEL", /* 0x014e */
313 "CB_SHOWDROPDOWN", /* 0x014f */
315 "CB_GETITEMDATA", /* 0x0150 */
316 "CB_SETITEMDATA", /* 0x0151 */
317 "CB_GETDROPPEDCONTROLRECT", /* 0x0152 */
318 "CB_SETITEMHEIGHT", /* 0x0153 */
319 "CB_GETITEMHEIGHT", /* 0x0154 */
320 "CB_SETEXTENDEDUI", /* 0x0155 */
321 "CB_GETEXTENDEDUI", /* 0x0156 */
322 "CB_GETDROPPEDSTATE", /* 0x0157 */
323 "CB_FINDSTRINGEXACT", /* 0x0158 */
324 "CB_SETLOCALE", /* 0x0159 */
325 "CB_GETLOCALE", /* 0x015a */
326 "CB_GETTOPINDEX", /* 0x015b */
327 "CB_SETTOPINDEX", /* 0x015c */
328 "CB_GETHORIZONTALEXTENT", /* 0x015d */
329 "CB_SETHORIZONTALEXTENT", /* 0x015e */
330 "CB_GETDROPPEDWIDTH", /* 0x015f */
332 "CB_SETDROPPEDWIDTH", /* 0x0160 */
333 "CB_INITSTORAGE", /* 0x0161 */
334 NULL, NULL, NULL, NULL, NULL, NULL,
335 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
337 /* 0x0170 - Win32 Static controls */
338 "STM_SETICON", /* 0x0170 */
339 "STM_GETICON", /* 0x0171 */
340 "STM_SETIMAGE", /* 0x0172 */
341 "STM_GETIMAGE", /* 0x0173 */
342 NULL, NULL, NULL, NULL,
343 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
345 /* 0x0180 - Win32 Listboxes */
346 "LB_ADDSTRING", /* 0x0180 */
347 "LB_INSERTSTRING", /* 0x0181 */
348 "LB_DELETESTRING", /* 0x0182 */
349 "LB_SELITEMRANGEEX", /* 0x0183 */
350 "LB_RESETCONTENT", /* 0x0184 */
351 "LB_SETSEL", /* 0x0185 */
352 "LB_SETCURSEL", /* 0x0186 */
353 "LB_GETSEL", /* 0x0187 */
354 "LB_GETCURSEL", /* 0x0188 */
355 "LB_GETTEXT", /* 0x0189 */
356 "LB_GETTEXTLEN", /* 0x018a */
357 "LB_GETCOUNT", /* 0x018b */
358 "LB_SELECTSTRING", /* 0x018c */
359 "LB_DIR", /* 0x018d */
360 "LB_GETTOPINDEX", /* 0x018e */
361 "LB_FINDSTRING", /* 0x018f */
363 "LB_GETSELCOUNT", /* 0x0190 */
364 "LB_GETSELITEMS", /* 0x0191 */
365 "LB_SETTABSTOPS", /* 0x0192 */
366 "LB_GETHORIZONTALEXTENT", /* 0x0193 */
367 "LB_SETHORIZONTALEXTENT", /* 0x0194 */
368 "LB_SETCOLUMNWIDTH", /* 0x0195 */
369 "LB_ADDFILE", /* 0x0196 */
370 "LB_SETTOPINDEX", /* 0x0197 */
371 "LB_GETITEMRECT", /* 0x0198 */
372 "LB_GETITEMDATA", /* 0x0199 */
373 "LB_SETITEMDATA", /* 0x019a */
374 "LB_SELITEMRANGE", /* 0x019b */
375 "LB_SETANCHORINDEX", /* 0x019c */
376 "LB_GETANCHORINDEX", /* 0x019d */
377 "LB_SETCARETINDEX", /* 0x019e */
378 "LB_GETCARETINDEX", /* 0x019f */
380 "LB_SETITEMHEIGHT", /* 0x01a0 */
381 "LB_GETITEMHEIGHT", /* 0x01a1 */
382 "LB_FINDSTRINGEXACT", /* 0x01a2 */
383 "LB_CARETON", /* 0x01a3 */
384 "LB_CARETOFF", /* 0x01a4 */
385 "LB_SETLOCALE", /* 0x01a5 */
386 "LB_GETLOCALE", /* 0x01a6 */
387 "LB_SETCOUNT", /* 0x01a7 */
388 "LB_INITSTORAGE", /* 0x01a8 */
389 "LB_ITEMFROMPOINT", /* 0x01a9 */
390 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,
409 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
410 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
412 "WM_MOUSEMOVE", /* 0x0200 */
413 "WM_LBUTTONDOWN", /* 0x0201 */
414 "WM_LBUTTONUP", /* 0x0202 */
415 "WM_LBUTTONDBLCLK", /* 0x0203 */
416 "WM_RBUTTONDOWN", /* 0x0204 */
417 "WM_RBUTTONUP", /* 0x0205 */
418 "WM_RBUTTONDBLCLK", /* 0x0206 */
419 "WM_MBUTTONDOWN", /* 0x0207 */
420 "WM_MBUTTONUP", /* 0x0208 */
421 "WM_MBUTTONDBLCLK", /* 0x0209 */
422 "WM_MOUSEWHEEL", /* 0x020A */
423 NULL, NULL, NULL, NULL, NULL,
425 "WM_PARENTNOTIFY", /* 0x0210 */
426 "WM_ENTERMENULOOP", /* 0x0211 */
427 "WM_EXITMENULOOP", /* 0x0212 */
428 "WM_NEXTMENU", /* 0x0213 */
433 "WM_DEVICECHANGE", NULL, NULL, NULL, NULL, NULL, NULL,
435 "WM_MDICREATE", /* 0x0220 */
436 "WM_MDIDESTROY", /* 0x0221 */
437 "WM_MDIACTIVATE", /* 0x0222 */
438 "WM_MDIRESTORE", /* 0x0223 */
439 "WM_MDINEXT", /* 0x0224 */
440 "WM_MDIMAXIMIZE", /* 0x0225 */
441 "WM_MDITILE", /* 0x0226 */
442 "WM_MDICASCADE", /* 0x0227 */
443 "WM_MDIICONARRANGE", /* 0x0228 */
444 "WM_MDIGETACTIVE", /* 0x0229 */
447 "WM_QUERYDROPOBJECT",
454 "WM_MDISETMENU", /* 0x0230 */
455 "WM_ENTERSIZEMOVE", /* 0x0231 */
456 "WM_EXITSIZEMOVE", /* 0x0232 */
457 "WM_DROPFILES", /* 0x0233 */
458 "WM_MDIREFRESHMENU", 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,
471 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
472 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
473 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
474 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
478 "WM_IME_SETCONTEXT", /* 0x0281 */
479 "WM_IME_NOTIFY", /* 0x0282 */
480 "WM_IME_CONTROL", /* 0x0283 */
481 "WM_IME_COMPOSITIONFULL", /* 0x0284 */
482 "WM_IME_SELECT", /* 0x0285 */
483 "WM_IME_CHAR", /* 0x0286 */
485 "WM_IME_REQUEST", /* 0x0288 */
486 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
487 "WM_IME_KEYDOWN", /* 0x0290 */
488 "WM_IME_KEYUP", /* 0x0291 */
489 NULL, NULL, NULL, NULL, NULL, NULL,
490 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
493 "WM_NCMOUSEHOVER", /* 0x02A0 */
494 "WM_MOUSEHOVER", /* 0x02A1 */
495 "WM_NCMOUSELEAVE", /* 0x02A2 */
496 "WM_MOUSELEAVE", /* 0x02A3 */
497 NULL, NULL, NULL, NULL, NULL, NULL,
498 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
499 "WM_WTSSESSION_CHANGE", /* 0x02B1 */
500 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
501 NULL, NULL, NULL, NULL, NULL, NULL,
504 "WM_TABLET_FIRST", /* 0x02c0 */
505 "WM_TABLET_FIRST+1", /* 0x02c1 */
506 "WM_TABLET_FIRST+2", /* 0x02c2 */
507 "WM_TABLET_FIRST+3", /* 0x02c3 */
508 "WM_TABLET_FIRST+4", /* 0x02c4 */
509 "WM_TABLET_FIRST+5", /* 0x02c5 */
510 "WM_TABLET_FIRST+7", /* 0x02c6 */
511 "WM_TABLET_FIRST+8", /* 0x02c7 */
512 "WM_TABLET_FIRST+9", /* 0x02c8 */
513 "WM_TABLET_FIRST+10", /* 0x02c9 */
514 "WM_TABLET_FIRST+11", /* 0x02ca */
515 "WM_TABLET_FIRST+12", /* 0x02cb */
516 "WM_TABLET_FIRST+13", /* 0x02cc */
517 "WM_TABLET_FIRST+14", /* 0x02cd */
518 "WM_TABLET_FIRST+15", /* 0x02ce */
519 "WM_TABLET_FIRST+16", /* 0x02cf */
520 "WM_TABLET_FIRST+17", /* 0x02d0 */
521 "WM_TABLET_FIRST+18", /* 0x02d1 */
522 "WM_TABLET_FIRST+19", /* 0x02d2 */
523 "WM_TABLET_FIRST+20", /* 0x02d3 */
524 "WM_TABLET_FIRST+21", /* 0x02d4 */
525 "WM_TABLET_FIRST+22", /* 0x02d5 */
526 "WM_TABLET_FIRST+23", /* 0x02d6 */
527 "WM_TABLET_FIRST+24", /* 0x02d7 */
528 "WM_TABLET_FIRST+25", /* 0x02d8 */
529 "WM_TABLET_FIRST+26", /* 0x02d9 */
530 "WM_TABLET_FIRST+27", /* 0x02da */
531 "WM_TABLET_FIRST+28", /* 0x02db */
532 "WM_TABLET_FIRST+29", /* 0x02dc */
533 "WM_TABLET_FIRST+30", /* 0x02dd */
534 "WM_TABLET_FIRST+31", /* 0x02de */
535 "WM_TABLET_LAST", /* 0x02df */
537 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
538 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
539 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
540 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
542 "WM_CUT", /* 0x0300 */
548 "WM_RENDERALLFORMATS",
549 "WM_DESTROYCLIPBOARD",
552 "WM_VSCROLLCLIPBOARD",
554 "WM_ASKCBFORMATNAME",
556 "WM_HSCROLLCLIPBOARD",
557 "WM_QUERYNEWPALETTE", /* 0x030f*/
559 "WM_PALETTEISCHANGING",
561 "WM_HOTKEY", /* 0x0312 */
562 NULL, NULL, NULL, NULL,
565 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
567 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
568 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
569 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
570 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
573 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
574 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
575 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
576 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
578 "WM_QUERYAFXWNDPROC", /* 0x0360 */
579 "WM_SIZEPARENT", /* 0x0361 */
580 "WM_SETMESSAGESTRING", /* 0x0362 */
581 "WM_IDLEUPDATECMDUI", /* 0x0363 */
582 "WM_INITIALUPDATE", /* 0x0364 */
583 "WM_COMMANDHELP", /* 0x0365 */
584 "WM_HELPHITTEST", /* 0x0366 */
585 "WM_EXITHELPMODE", /* 0x0367 */
586 "WM_RECALCPARENT", /* 0x0368 */
587 "WM_SIZECHILD", /* 0x0369 */
588 "WM_KICKIDLE", /* 0x036A */
589 "WM_QUERYCENTERWND", /* 0x036B */
590 "WM_DISABLEMODAL", /* 0x036C */
591 "WM_FLOATSTATUS", /* 0x036D */
592 "WM_ACTIVATETOPLEVEL", /* 0x036E */
593 "WM_QUERY3DCONTROLS", /* 0x036F */
595 "WM_SOCKET_NOTIFY", /* 0x0373 */
596 "WM_SOCKET_DEAD", /* 0x0374 */
597 "WM_POPMESSAGESTRING", /* 0x0375 */
598 "WM_OCC_LOADFROMSTREAM", /* 0x0376 */
599 "WM_OCC_LOADFROMSTORAGE", /* 0x0377 */
600 "WM_OCC_INITNEW", /* 0x0378 */
601 "WM_QUEUE_SENTINEL", /* 0x0379 */
602 "WM_OCC_LOADFROMSTREAM_EX", /* 0x037A */
603 "WM_OCC_LOADFROMSTORAGE_EX", /* 0x037B */
607 "WM_PENWINFIRST", /* 0x0380 */
608 "WM_RCRESULT", /* 0x0381 */
609 "WM_HOOKRCRESULT", /* 0x0382 */
610 "WM_GLOBALRCCHANGE", /* 0x0383 */
611 "WM_SKB", /* 0x0384 */
612 "WM_HEDITCTL", /* 0x0385 */
614 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
615 "WM_PENWINLAST", /* 0x038F */
617 "WM_COALESCE_FIRST", /* 0x0390 */
618 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
619 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
620 "WM_COALESCE_LAST", /* 0x039F */
627 NULL, NULL, NULL, NULL,
628 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
631 NULL, NULL, NULL, NULL, NULL,
655 NULL, NULL, NULL, NULL, NULL, NULL,
656 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
657 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
660 "WM_DDE_INITIATE", /* 0x3E0 */
661 "WM_DDE_TERMINATE", /* 0x3E1 */
662 "WM_DDE_ADVISE", /* 0x3E2 */
663 "WM_DDE_UNADVISE", /* 0x3E3 */
664 "WM_DDE_ACK", /* 0x3E4 */
665 "WM_DDE_DATA", /* 0x3E5 */
666 "WM_DDE_REQUEST", /* 0x3E6 */
667 "WM_DDE_POKE", /* 0x3E7 */
668 "WM_DDE_EXECUTE", /* 0x3E8 */
669 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
673 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
674 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
676 "WM_USER" /* 0x0400 */
680 #define SPY_MAX_LVMMSGNUM 140
681 static const char * const LVMMessageTypeNames[SPY_MAX_LVMMSGNUM + 1] =
683 "LVM_GETBKCOLOR", /* 1000 */
692 "LVM_DELETEALLITEMS",
693 "LVM_GETCALLBACKMASK",
694 "LVM_SETCALLBACKMASK",
698 "LVM_SETITEMPOSITION",
699 "LVM_GETITEMPOSITION",
700 "LVM_GETSTRINGWIDTHA",
707 "LVM_GETEDITCONTROL",
712 "LVM_GETCOLUMNWIDTH",
713 "LVM_SETCOLUMNWIDTH",
716 "LVM_CREATEDRAGIMAGE",
720 "LVM_GETTEXTBKCOLOR",
721 "LVM_SETTEXTBKCOLOR",
723 "LVM_GETCOUNTPERPAGE",
732 "LVM_SETITEMPOSITION32",
733 "LVM_GETSELECTEDCOUNT",
734 "LVM_GETITEMSPACING",
735 "LVM_GETISEARCHSTRINGA",
736 "LVM_SETICONSPACING",
737 "LVM_SETEXTENDEDLISTVIEWSTYLE",
738 "LVM_GETEXTENDEDLISTVIEWSTYLE",
739 "LVM_GETSUBITEMRECT",
740 "LVM_SUBITEMHITTEST",
741 "LVM_SETCOLUMNORDERARRAY",
742 "LVM_GETCOLUMNORDERARRAY",
747 "LVM_APPROXIMATEVIEWRECT",
749 "LVM_GETSELECTIONMARK",
750 "LVM_SETSELECTIONMARK",
756 "LVM_GETNUMBEROFWORKAREAS",
770 "LVM_GETSTRINGWIDTHW",
800 "LVM_GETISEARCHSTRINGW",
823 "LVM_GETBKIMAGEW" /* 0x108B */
827 #define SPY_MAX_TVMSGNUM 65
828 static const char * const TVMessageTypeNames[SPY_MAX_TVMSGNUM + 1] =
830 "TVM_INSERTITEMA", /* 1100 */
845 "TVM_GETEDITCONTROL",
846 "TVM_GETVISIBLECOUNT",
848 "TVM_CREATEDRAGIMAGE",
851 "TVM_SORTCHILDRENCB",
852 "TVM_ENDEDITLABELNOW",
853 "TVM_GETISEARCHSTRINGA",
867 "TVM_SETINSERTMARKCOLOR",
868 "TVM_GETINSERTMARKCOLOR",
894 "TVM_GETISEARCHSTRINGW",
899 #define SPY_MAX_HDMMSGNUM 19
900 static const char * const HDMMessageTypeNames[SPY_MAX_HDMMSGNUM + 1] =
902 "HDM_GETITEMCOUNT", /* 1200 */
918 "HDM_CREATEDRAGIMAGE",
919 "GETORDERARRAYINDEX",
920 "SETORDERARRAYINDEX",
925 #define SPY_MAX_TCMMSGNUM 62
926 static const char * const TCMMessageTypeNames[SPY_MAX_TCMMSGNUM + 1] =
937 "TCM_DELETEALLITEMS",
977 "TCM_SETMINTABWIDTH",
980 "TCM_SETEXTENDEDSTYLE",
981 "TCM_GETEXTENDEDSTYLE",
993 #define SPY_MAX_PGMMSGNUM 13
994 static const char * const PGMMessageTypeNames[SPY_MAX_PGMMSGNUM + 1] =
1006 "PGM_SETBUTTONSIZE",
1007 "PGM_GETBUTTONSIZE",
1008 "PGM_GETBUTTONSTATE",
1013 #define SPY_MAX_CCMMSGNUM 9
1014 static const char * const CCMMessageTypeNames[SPY_MAX_CCMMSGNUM + 1] =
1018 "CCM_SETCOLORSCHEME",
1019 "CCM_GETCOLORSCHEME",
1020 "CCM_GETDROPTARGET",
1021 "CCM_SETUNICODEFORMAT",
1022 "CCM_GETUNICODEFORMAT",
1025 "CCM_SETNOTIFYWINDOW"
1028 #define SPY_MAX_WINEMSGNUM 6
1029 static const char * const WINEMessageTypeNames[SPY_MAX_WINEMSGNUM + 1] =
1031 "WM_WINE_DESTROYWINDOW",
1032 "WM_WINE_SETWINDOWPOS",
1033 "WM_WINE_SHOWWINDOW",
1034 "WM_WINE_SETPARENT",
1035 "WM_WINE_SETWINDOWLONG",
1036 "WM_WINE_ENABLEWINDOW"
1039 /* Virtual key names */
1040 #define SPY_MAX_VKKEYSNUM 255
1041 static const char * const VK_KeyNames[SPY_MAX_VKKEYSNUM + 1] =
1044 "VK_LBUTTON", /* 0x01 */
1045 "VK_RBUTTON", /* 0x02 */
1046 "VK_CANCEL", /* 0x03 */
1047 "VK_MBUTTON", /* 0x04 */
1051 "VK_BACK", /* 0x08 */
1052 "VK_TAB", /* 0x09 */
1055 "VK_CLEAR", /* 0x0C */
1056 "VK_RETURN", /* 0x0D */
1059 "VK_SHIFT", /* 0x10 */
1060 "VK_CONTROL", /* 0x11 */
1061 "VK_MENU", /* 0x12 */
1062 "VK_PAUSE", /* 0x13 */
1063 "VK_CAPITAL", /* 0x14 */
1070 "VK_ESCAPE", /* 0x1B */
1075 "VK_SPACE", /* 0x20 */
1076 "VK_PRIOR", /* 0x21 */
1077 "VK_NEXT", /* 0x22 */
1078 "VK_END", /* 0x23 */
1079 "VK_HOME", /* 0x24 */
1080 "VK_LEFT", /* 0x25 */
1082 "VK_RIGHT", /* 0x27 */
1083 "VK_DOWN", /* 0x28 */
1084 "VK_SELECT", /* 0x29 */
1085 "VK_PRINT", /* 0x2A */
1086 "VK_EXECUTE", /* 0x2B */
1087 "VK_SNAPSHOT", /* 0x2C */
1088 "VK_INSERT", /* 0x2D */
1089 "VK_DELETE", /* 0x2E */
1090 "VK_HELP", /* 0x2F */
1134 "VK_LWIN", /* 0x5B */
1135 "VK_RWIN", /* 0x5C */
1136 "VK_APPS", /* 0x5D */
1139 "VK_NUMPAD0", /* 0x60 */
1140 "VK_NUMPAD1", /* 0x61 */
1141 "VK_NUMPAD2", /* 0x62 */
1142 "VK_NUMPAD3", /* 0x63 */
1143 "VK_NUMPAD4", /* 0x64 */
1144 "VK_NUMPAD5", /* 0x65 */
1145 "VK_NUMPAD6", /* 0x66 */
1146 "VK_NUMPAD7", /* 0x67 */
1147 "VK_NUMPAD8", /* 0x68 */
1148 "VK_NUMPAD9", /* 0x69 */
1149 "VK_MULTIPLY", /* 0x6A */
1150 "VK_ADD", /* 0x6B */
1151 "VK_SEPARATOR", /* 0x6C */
1152 "VK_SUBTRACT", /* 0x6D */
1153 "VK_DECIMAL", /* 0x6E */
1154 "VK_DIVIDE", /* 0x6F */
1164 "VK_F10", /* 0x79 */
1165 "VK_F11", /* 0x7A */
1166 "VK_F12", /* 0x7B */
1167 "VK_F13", /* 0x7C */
1168 "VK_F14", /* 0x7D */
1169 "VK_F15", /* 0x7E */
1170 "VK_F16", /* 0x7F */
1171 "VK_F17", /* 0x80 */
1172 "VK_F18", /* 0x81 */
1173 "VK_F19", /* 0x82 */
1174 "VK_F20", /* 0x83 */
1175 "VK_F21", /* 0x84 */
1176 "VK_F22", /* 0x85 */
1177 "VK_F23", /* 0x86 */
1178 "VK_F24", /* 0x87 */
1187 "VK_NUMLOCK", /* 0x90 */
1188 "VK_SCROLL", /* 0x91 */
1203 "VK_LSHIFT", /* 0xA0 */
1204 "VK_RSHIFT", /* 0xA1 */
1205 "VK_LCONTROL", /* 0xA2 */
1206 "VK_RCONTROL", /* 0xA3 */
1207 "VK_LMENU", /* 0xA4 */
1208 "VK_RMENU", /* 0xA5 */
1229 "VK_OEM_1", /* 0xBA */
1230 "VK_OEM_PLUS", /* 0xBB */
1231 "VK_OEM_COMMA", /* 0xBC */
1232 "VK_OEM_MINUS", /* 0xBD */
1233 "VK_OEM_PERIOD", /* 0xBE */
1234 "VK_OEM_2", /* 0xBF */
1235 "VK_OEM_3", /* 0xC0 */
1262 "VK_OEM_4", /* 0xDB */
1263 "VK_OEM_5", /* 0xDC */
1264 "VK_OEM_6", /* 0xDD */
1265 "VK_OEM_7", /* 0xDE */
1266 "VK_OEM_8", /* 0xDF */
1268 "VK_OEM_AX", /* 0xE1 */
1269 "VK_OEM_102", /* 0xE2 */
1270 "VK_ICO_HELP", /* 0xE3 */
1271 "VK_ICO_00", /* 0xE4 */
1272 "VK_PROCESSKEY", /* 0xE5 */
1289 "VK_ATTN", /* 0xF6 */
1290 "VK_CRSEL", /* 0xF7 */
1291 "VK_EXSEL", /* 0xF8 */
1292 "VK_EREOF", /* 0xF9 */
1293 "VK_PLAY", /* 0xFA */
1294 "VK_ZOOM", /* 0xFB */
1295 "VK_NONAME", /* 0xFC */
1296 "VK_PA1", /* 0xFD */
1297 "VK_OEM_CLEAR", /* 0xFE */
1302 /************************************************************************/
1305 /* WM_USER+n message values for "common controls" */
1309 const char *name; /* name of control message */
1310 UINT value; /* message number (0x0401-0x0fff */
1311 UINT len; /* length of space at lParam to dump */
1317 const WCHAR *classname; /* class name to match */
1318 const USER_MSG *classmsg; /* pointer to first USER_MSG for class */
1319 USER_MSG *lastmsg; /* pointer to last USER_MSG for class */
1322 #define USM(a,b) { #a ,a,b}
1323 #define SZOF(a) sizeof(a)
1325 /* To dump memory at the lParam for any of these messages, */
1326 /* replace the "0" with a "SZOF(structure)", or with a */
1327 /* number. (First method prefered.) */
1329 #define RB_GETBANDINFO_OLD (WM_USER+5) /* obsoleted after IE3, but we have to support it anyway */
1331 static const USER_MSG rebar_array[] = {
1332 USM(RB_INSERTBANDA, 0),
1333 USM(RB_DELETEBAND, 0),
1334 USM(RB_GETBARINFO, 0),
1335 USM(RB_SETBARINFO, 0),
1336 USM(RB_GETBANDINFO_OLD, 0),
1337 USM(RB_SETBANDINFOA, 0),
1338 USM(RB_SETPARENT, 0),
1341 USM(RB_INSERTBANDW, 0),
1342 USM(RB_SETBANDINFOW, 0),
1343 USM(RB_GETBANDCOUNT, 0),
1344 USM(RB_GETROWCOUNT, 0),
1345 USM(RB_GETROWHEIGHT, 0),
1346 USM(RB_IDTOINDEX, 0),
1347 USM(RB_GETTOOLTIPS, 0),
1348 USM(RB_SETTOOLTIPS, 0),
1349 USM(RB_SETBKCOLOR, 0),
1350 USM(RB_GETBKCOLOR, 0),
1351 USM(RB_SETTEXTCOLOR, 0),
1352 USM(RB_GETTEXTCOLOR, 0),
1353 USM(RB_SIZETORECT, 0),
1354 USM(RB_BEGINDRAG, 0),
1356 USM(RB_DRAGMOVE, 0),
1357 USM(RB_GETBARHEIGHT, 0),
1358 USM(RB_GETBANDINFOW, 0),
1359 USM(RB_GETBANDINFOA, 0),
1360 USM(RB_MINIMIZEBAND, 0),
1361 USM(RB_MAXIMIZEBAND, 0),
1362 USM(RB_GETBANDBORDERS, 0),
1363 USM(RB_SHOWBAND, 0),
1364 USM(RB_SETPALETTE, 0),
1365 USM(RB_GETPALETTE, 0),
1366 USM(RB_MOVEBAND, 0),
1369 static const USER_MSG toolbar_array[] = {
1370 USM(TB_ENABLEBUTTON ,0),
1371 USM(TB_CHECKBUTTON ,0),
1372 USM(TB_PRESSBUTTON ,0),
1373 USM(TB_HIDEBUTTON ,0),
1374 USM(TB_INDETERMINATE ,0),
1375 USM(TB_MARKBUTTON ,0),
1376 USM(TB_ISBUTTONENABLED ,0),
1377 USM(TB_ISBUTTONCHECKED ,0),
1378 USM(TB_ISBUTTONPRESSED ,0),
1379 USM(TB_ISBUTTONHIDDEN ,0),
1380 USM(TB_ISBUTTONINDETERMINATE ,0),
1381 USM(TB_ISBUTTONHIGHLIGHTED ,0),
1382 USM(TB_SETSTATE ,0),
1383 USM(TB_GETSTATE ,0),
1384 USM(TB_ADDBITMAP ,0),
1385 USM(TB_ADDBUTTONSA ,0),
1386 USM(TB_INSERTBUTTONA ,0),
1387 USM(TB_DELETEBUTTON ,0),
1388 USM(TB_GETBUTTON ,0),
1389 USM(TB_BUTTONCOUNT ,0),
1390 USM(TB_COMMANDTOINDEX ,0),
1391 USM(TB_SAVERESTOREA ,0),
1392 USM(TB_CUSTOMIZE ,0),
1393 USM(TB_ADDSTRINGA ,0),
1394 USM(TB_GETITEMRECT ,0),
1395 USM(TB_BUTTONSTRUCTSIZE ,0),
1396 USM(TB_SETBUTTONSIZE ,0),
1397 USM(TB_SETBITMAPSIZE ,0),
1398 USM(TB_AUTOSIZE ,0),
1399 USM(TB_GETTOOLTIPS ,0),
1400 USM(TB_SETTOOLTIPS ,0),
1401 USM(TB_SETPARENT ,0),
1404 USM(TB_GETBITMAPFLAGS ,0),
1405 USM(TB_SETCMDID ,0),
1406 USM(TB_CHANGEBITMAP ,0),
1407 USM(TB_GETBITMAP ,0),
1408 USM(TB_GETBUTTONTEXTA ,0),
1409 USM(TB_REPLACEBITMAP ,0),
1410 USM(TB_SETINDENT ,0),
1411 USM(TB_SETIMAGELIST ,0),
1412 USM(TB_GETIMAGELIST ,0),
1413 USM(TB_LOADIMAGES ,0),
1415 USM(TB_SETHOTIMAGELIST ,0),
1416 USM(TB_GETHOTIMAGELIST ,0),
1417 USM(TB_SETDISABLEDIMAGELIST ,0),
1418 USM(TB_GETDISABLEDIMAGELIST ,0),
1419 USM(TB_SETSTYLE ,0),
1420 USM(TB_GETSTYLE ,0),
1421 USM(TB_GETBUTTONSIZE ,0),
1422 USM(TB_SETBUTTONWIDTH ,0),
1423 USM(TB_SETMAXTEXTROWS ,0),
1424 USM(TB_GETTEXTROWS ,0),
1425 USM(TB_GETOBJECT ,0),
1426 USM(TB_GETBUTTONINFOW ,0),
1427 USM(TB_SETBUTTONINFOW ,0),
1428 USM(TB_GETBUTTONINFOA ,0),
1429 USM(TB_SETBUTTONINFOA ,0),
1430 USM(TB_INSERTBUTTONW ,0),
1431 USM(TB_ADDBUTTONSW ,0),
1433 USM(TB_SETDRAWTEXTFLAGS ,0),
1434 USM(TB_GETHOTITEM ,0),
1435 USM(TB_SETHOTITEM ,0),
1436 USM(TB_SETANCHORHIGHLIGHT ,0),
1437 USM(TB_GETANCHORHIGHLIGHT ,0),
1438 USM(TB_GETBUTTONTEXTW ,0),
1439 USM(TB_SAVERESTOREW ,0),
1440 USM(TB_ADDSTRINGW ,0),
1441 USM(TB_MAPACCELERATORA ,0),
1442 USM(TB_GETINSERTMARK ,0),
1443 USM(TB_SETINSERTMARK ,0),
1444 USM(TB_INSERTMARKHITTEST ,0),
1445 USM(TB_MOVEBUTTON ,0),
1446 USM(TB_GETMAXSIZE ,0),
1447 USM(TB_SETEXTENDEDSTYLE ,0),
1448 USM(TB_GETEXTENDEDSTYLE ,0),
1449 USM(TB_GETPADDING ,0),
1450 USM(TB_SETPADDING ,0),
1451 USM(TB_SETINSERTMARKCOLOR ,0),
1452 USM(TB_GETINSERTMARKCOLOR ,0),
1453 USM(TB_MAPACCELERATORW ,0),
1454 USM(TB_GETSTRINGW ,0),
1455 USM(TB_GETSTRINGA ,0),
1456 USM(TB_UNKWN45D ,8),
1457 USM(TB_UNKWN45E ,0),
1458 USM(TB_UNKWN460 ,0),
1459 USM(TB_UNKWN463 ,8),
1460 USM(TB_UNKWN464 ,0),
1463 static const USER_MSG tooltips_array[] = {
1464 USM(TTM_ACTIVATE ,0),
1465 USM(TTM_SETDELAYTIME ,0),
1466 USM(TTM_ADDTOOLA ,0),
1467 USM(TTM_DELTOOLA ,0),
1468 USM(TTM_NEWTOOLRECTA ,0),
1469 USM(TTM_RELAYEVENT ,0),
1470 USM(TTM_GETTOOLINFOA ,0),
1471 USM(TTM_HITTESTA ,0),
1472 USM(TTM_GETTEXTA ,0),
1473 USM(TTM_UPDATETIPTEXTA ,0),
1474 USM(TTM_GETTOOLCOUNT ,0),
1475 USM(TTM_ENUMTOOLSA ,0),
1476 USM(TTM_GETCURRENTTOOLA ,0),
1477 USM(TTM_WINDOWFROMPOINT ,0),
1478 USM(TTM_TRACKACTIVATE ,0),
1479 USM(TTM_TRACKPOSITION ,0),
1480 USM(TTM_SETTIPBKCOLOR ,0),
1481 USM(TTM_SETTIPTEXTCOLOR ,0),
1482 USM(TTM_GETDELAYTIME ,0),
1483 USM(TTM_GETTIPBKCOLOR ,0),
1484 USM(TTM_GETTIPTEXTCOLOR ,0),
1485 USM(TTM_SETMAXTIPWIDTH ,0),
1486 USM(TTM_GETMAXTIPWIDTH ,0),
1487 USM(TTM_SETMARGIN ,0),
1488 USM(TTM_GETMARGIN ,0),
1491 USM(TTM_GETBUBBLESIZE ,0),
1492 USM(TTM_ADDTOOLW ,0),
1493 USM(TTM_DELTOOLW ,0),
1494 USM(TTM_NEWTOOLRECTW ,0),
1495 USM(TTM_GETTOOLINFOW ,0),
1496 USM(TTM_SETTOOLINFOW ,0),
1497 USM(TTM_HITTESTW ,0),
1498 USM(TTM_GETTEXTW ,0),
1499 USM(TTM_UPDATETIPTEXTW ,0),
1500 USM(TTM_ENUMTOOLSW ,0),
1501 USM(TTM_GETCURRENTTOOLW ,0),
1504 static const USER_MSG comboex_array[] = {
1505 USM(CBEM_INSERTITEMA ,0),
1506 USM(CBEM_SETIMAGELIST ,0),
1507 USM(CBEM_GETIMAGELIST ,0),
1508 USM(CBEM_GETITEMA ,0),
1509 USM(CBEM_SETITEMA ,0),
1510 USM(CBEM_GETCOMBOCONTROL ,0),
1511 USM(CBEM_GETEDITCONTROL ,0),
1512 USM(CBEM_SETEXSTYLE ,0),
1513 USM(CBEM_GETEXTENDEDSTYLE ,0),
1514 USM(CBEM_HASEDITCHANGED ,0),
1515 USM(CBEM_INSERTITEMW ,0),
1516 USM(CBEM_SETITEMW ,0),
1517 USM(CBEM_GETITEMW ,0),
1518 USM(CBEM_SETEXTENDEDSTYLE ,0),
1521 static const USER_MSG propsht_array[] = {
1522 USM(PSM_SETCURSEL ,0),
1523 USM(PSM_REMOVEPAGE ,0),
1524 USM(PSM_ADDPAGE ,0),
1525 USM(PSM_CHANGED ,0),
1526 USM(PSM_RESTARTWINDOWS ,0),
1527 USM(PSM_REBOOTSYSTEM ,0),
1528 USM(PSM_CANCELTOCLOSE ,0),
1529 USM(PSM_QUERYSIBLINGS ,0),
1530 USM(PSM_UNCHANGED ,0),
1532 USM(PSM_SETTITLEA ,0),
1533 USM(PSM_SETWIZBUTTONS ,0),
1534 USM(PSM_PRESSBUTTON ,0),
1535 USM(PSM_SETCURSELID ,0),
1536 USM(PSM_SETFINISHTEXTA ,0),
1537 USM(PSM_GETTABCONTROL ,0),
1538 USM(PSM_ISDIALOGMESSAGE ,0),
1539 USM(PSM_GETCURRENTPAGEHWND ,0),
1540 USM(PSM_SETTITLEW ,0),
1541 USM(PSM_SETFINISHTEXTW ,0),
1543 const WCHAR PropSheetInfoStr[] =
1544 {'P','r','o','p','e','r','t','y','S','h','e','e','t','I','n','f','o',0 };
1546 static const USER_MSG updown_array[] = {
1547 USM(UDM_SETRANGE ,0),
1548 USM(UDM_GETRANGE ,0),
1551 USM(UDM_SETBUDDY ,0),
1552 USM(UDM_GETBUDDY ,0),
1553 USM(UDM_SETACCEL ,0),
1554 USM(UDM_GETACCEL ,0),
1555 USM(UDM_SETBASE ,0),
1556 USM(UDM_GETBASE ,0),
1557 USM(UDM_SETRANGE32 ,0),
1558 USM(UDM_GETRANGE32 ,0),
1559 USM(UDM_SETPOS32 ,0),
1560 USM(UDM_GETPOS32 ,0),
1566 static CONTROL_CLASS cc_array[] = {
1567 {WC_COMBOBOXEXW, comboex_array, 0},
1568 {WC_PROPSHEETW, propsht_array, 0},
1569 {REBARCLASSNAMEW, rebar_array, 0},
1570 {TOOLBARCLASSNAMEW, toolbar_array, 0},
1571 {TOOLTIPS_CLASSW, tooltips_array, 0},
1572 {UPDOWN_CLASSW, updown_array, 0},
1576 /************************************************************************/
1579 /* WM_NOTIFY function codes display */
1583 const char *name; /* name of notify message */
1584 UINT value; /* notify code value */
1585 UINT len; /* length of extra space to dump */
1588 #define SPNFY(a,b) { #a ,a,sizeof(b)-sizeof(NMHDR)}
1590 /* Array MUST be in descending order by the 'value' field */
1591 /* (since value is UNSIGNED, 0xffffffff is largest and */
1592 /* 0xfffffffe is smaller). A binary search is used to */
1593 /* locate the correct 'value'. */
1594 static const SPY_NOTIFY spnfy_array[] = {
1595 /* common 0U to 0U-99U */
1596 SPNFY(NM_OUTOFMEMORY, NMHDR),
1597 SPNFY(NM_CLICK, NMHDR),
1598 SPNFY(NM_DBLCLK, NMHDR),
1599 SPNFY(NM_RETURN, NMHDR),
1600 SPNFY(NM_RCLICK, NMHDR),
1601 SPNFY(NM_RDBLCLK, NMHDR),
1602 SPNFY(NM_SETFOCUS, NMHDR),
1603 SPNFY(NM_KILLFOCUS, NMHDR),
1604 SPNFY(NM_CUSTOMDRAW, NMCUSTOMDRAW),
1605 SPNFY(NM_HOVER, NMHDR),
1606 SPNFY(NM_NCHITTEST, NMMOUSE),
1607 SPNFY(NM_KEYDOWN, NMKEY),
1608 SPNFY(NM_RELEASEDCAPTURE, NMHDR),
1609 SPNFY(NM_SETCURSOR, NMMOUSE),
1610 SPNFY(NM_CHAR, NMCHAR),
1611 SPNFY(NM_TOOLTIPSCREATED, NMTOOLTIPSCREATED),
1612 /* Listview 0U-100U to 0U-199U */
1613 SPNFY(LVN_ITEMCHANGING, NMLISTVIEW),
1614 SPNFY(LVN_ITEMCHANGED, NMLISTVIEW),
1615 SPNFY(LVN_INSERTITEM, NMLISTVIEW),
1616 SPNFY(LVN_DELETEITEM, NMLISTVIEW),
1617 SPNFY(LVN_DELETEALLITEMS, NMLISTVIEW),
1618 SPNFY(LVN_BEGINLABELEDITA, NMLVDISPINFOA),
1619 SPNFY(LVN_ENDLABELEDITA, NMLVDISPINFOA),
1620 SPNFY(LVN_COLUMNCLICK, NMLISTVIEW),
1621 SPNFY(LVN_BEGINDRAG, NMLISTVIEW),
1622 SPNFY(LVN_BEGINRDRAG, NMLISTVIEW),
1623 SPNFY(LVN_ODCACHEHINT, NMLVCACHEHINT),
1624 SPNFY(LVN_ITEMACTIVATE, NMITEMACTIVATE),
1625 SPNFY(LVN_ODSTATECHANGED, NMLVODSTATECHANGE),
1626 SPNFY(LVN_HOTTRACK, NMLISTVIEW),
1627 SPNFY(LVN_GETDISPINFOA, NMLVDISPINFOA),
1628 SPNFY(LVN_SETDISPINFOA, NMLVDISPINFOA),
1629 SPNFY(LVN_ODFINDITEMA, NMLVFINDITEMA),
1630 SPNFY(LVN_KEYDOWN, NMLVKEYDOWN),
1631 SPNFY(LVN_MARQUEEBEGIN, NMLISTVIEW),
1632 SPNFY(LVN_GETINFOTIPA, NMLVGETINFOTIPA),
1633 SPNFY(LVN_GETINFOTIPW, NMLVGETINFOTIPW),
1634 SPNFY(LVN_BEGINLABELEDITW, NMLVDISPINFOW),
1635 SPNFY(LVN_ENDLABELEDITW, NMLVDISPINFOW),
1636 SPNFY(LVN_GETDISPINFOW, NMLVDISPINFOW),
1637 SPNFY(LVN_SETDISPINFOW, NMLVDISPINFOW),
1638 SPNFY(LVN_ODFINDITEMW, NMLVFINDITEMW),
1639 /* PropertySheet 0U-200U to 0U-299U */
1640 SPNFY(PSN_SETACTIVE, PSHNOTIFY),
1641 SPNFY(PSN_KILLACTIVE, PSHNOTIFY),
1642 SPNFY(PSN_APPLY, PSHNOTIFY),
1643 SPNFY(PSN_RESET, PSHNOTIFY),
1644 SPNFY(PSN_HELP, PSHNOTIFY),
1645 SPNFY(PSN_WIZBACK, PSHNOTIFY),
1646 SPNFY(PSN_WIZNEXT, PSHNOTIFY),
1647 SPNFY(PSN_WIZFINISH, PSHNOTIFY),
1648 SPNFY(PSN_QUERYCANCEL, PSHNOTIFY),
1649 SPNFY(PSN_GETOBJECT, NMOBJECTNOTIFY),
1650 /* SPNFY(PSN_QUERYINITIALFOCUS, .PSHNOTIFY), NIY */
1651 /* SPNFY(PSN_TRANSLATEACCELERATOR, .PSHNOTIFY), NIY */
1652 /* Header 0U-300U to 0U-399U */
1653 SPNFY(HDN_ITEMCHANGINGA, NMHDR),
1654 SPNFY(HDN_ITEMCHANGEDA, NMHDR),
1655 SPNFY(HDN_ITEMCLICKA, NMHDR),
1656 SPNFY(HDN_ITEMDBLCLICKA, NMHDR),
1657 SPNFY(HDN_DIVIDERDBLCLICKA, NMHDR),
1658 SPNFY(HDN_BEGINTRACKA, NMHDR),
1659 SPNFY(HDN_ENDTRACKA, NMHDR),
1660 SPNFY(HDN_GETDISPINFOA, NMHDR),
1661 SPNFY(HDN_BEGINDRAG, NMHDR),
1662 SPNFY(HDN_ENDDRAG, NMHDR),
1663 SPNFY(HDN_ITEMCHANGINGW, NMHDR),
1664 SPNFY(HDN_ITEMCHANGEDW, NMHDR),
1665 SPNFY(HDN_ITEMCLICKW, NMHDR),
1666 SPNFY(HDN_ITEMDBLCLICKW, NMHDR),
1667 SPNFY(HDN_DIVIDERDBLCLICKW, NMHDR),
1668 SPNFY(HDN_BEGINTRACKW, NMHDR),
1669 SPNFY(HDN_ENDTRACKW, NMHDR),
1670 SPNFY(HDN_GETDISPINFOW, NMHDR),
1671 /* Treeview 0U-400U to 0U-499U */
1672 SPNFY(TVN_SELCHANGINGA, NMTREEVIEWA),
1673 SPNFY(TVN_SELCHANGEDA, NMTREEVIEWA),
1674 SPNFY(TVN_GETDISPINFOA, NMTVDISPINFOA),
1675 SPNFY(TVN_SETDISPINFOA, NMTVDISPINFOA),
1676 SPNFY(TVN_ITEMEXPANDINGA, NMTREEVIEWA),
1677 SPNFY(TVN_ITEMEXPANDEDA, NMTREEVIEWA),
1678 SPNFY(TVN_BEGINDRAGA, NMTREEVIEWA),
1679 SPNFY(TVN_BEGINRDRAGA, NMTREEVIEWA),
1680 SPNFY(TVN_DELETEITEMA, NMTREEVIEWA),
1681 SPNFY(TVN_BEGINLABELEDITA, NMTVDISPINFOA),
1682 SPNFY(TVN_ENDLABELEDITA, NMTVDISPINFOA),
1683 SPNFY(TVN_KEYDOWN, NMTVKEYDOWN),
1684 SPNFY(TVN_SELCHANGINGW, NMTREEVIEWW),
1685 SPNFY(TVN_SELCHANGEDW, NMTREEVIEWW),
1686 SPNFY(TVN_GETDISPINFOW, NMTVDISPINFOW),
1687 SPNFY(TVN_SETDISPINFOW, NMTVDISPINFOW),
1688 SPNFY(TVN_ITEMEXPANDINGW, NMTREEVIEWW),
1689 SPNFY(TVN_ITEMEXPANDEDW, NMTREEVIEWW),
1690 SPNFY(TVN_BEGINDRAGW, NMTREEVIEWW),
1691 SPNFY(TVN_BEGINRDRAGW, NMTREEVIEWW),
1692 SPNFY(TVN_DELETEITEMW, NMTREEVIEWW),
1693 SPNFY(TVN_BEGINLABELEDITW, NMTVDISPINFOW),
1694 SPNFY(TVN_ENDLABELEDITW, NMTVDISPINFOW),
1695 /* Tooltips 0U-520U to 0U-549U */
1696 SPNFY(TTN_GETDISPINFOA, NMHDR),
1697 SPNFY(TTN_SHOW, NMHDR),
1698 SPNFY(TTN_POP, NMHDR),
1699 SPNFY(TTN_GETDISPINFOW, NMHDR),
1700 /* Tab 0U-550U to 0U-580U */
1701 SPNFY(TCN_KEYDOWN, NMHDR),
1702 SPNFY(TCN_SELCHANGE, NMHDR),
1703 SPNFY(TCN_SELCHANGING, NMHDR),
1704 SPNFY(TCN_GETOBJECT, NMHDR),
1705 /* Common Dialog 0U-601U to 0U-699U */
1706 SPNFY(CDN_INITDONE, OFNOTIFYA),
1707 SPNFY(CDN_SELCHANGE, OFNOTIFYA),
1708 SPNFY(CDN_FOLDERCHANGE, OFNOTIFYA),
1709 SPNFY(CDN_SHAREVIOLATION, OFNOTIFYA),
1710 SPNFY(CDN_HELP, OFNOTIFYA),
1711 SPNFY(CDN_FILEOK, OFNOTIFYA),
1712 SPNFY(CDN_TYPECHANGE, OFNOTIFYA),
1713 /* Toolbar 0U-700U to 0U-720U */
1714 SPNFY(TBN_GETBUTTONINFOA, NMTOOLBARA),
1715 SPNFY(TBN_BEGINDRAG, NMTOOLBARA),
1716 SPNFY(TBN_ENDDRAG, NMTOOLBARA),
1717 SPNFY(TBN_BEGINADJUST, NMHDR),
1718 SPNFY(TBN_ENDADJUST, NMHDR),
1719 SPNFY(TBN_RESET, NMHDR),
1720 SPNFY(TBN_QUERYINSERT, NMTOOLBARA),
1721 SPNFY(TBN_QUERYDELETE, NMTOOLBARA),
1722 SPNFY(TBN_TOOLBARCHANGE, NMHDR),
1723 SPNFY(TBN_CUSTHELP, NMHDR),
1724 SPNFY(TBN_DROPDOWN, NMTOOLBARA),
1725 SPNFY(TBN_GETOBJECT, NMOBJECTNOTIFY),
1726 SPNFY(TBN_HOTITEMCHANGE, NMTBHOTITEM),
1727 SPNFY(TBN_DRAGOUT, NMTOOLBARA),
1728 SPNFY(TBN_DELETINGBUTTON, NMTOOLBARA),
1729 SPNFY(TBN_GETDISPINFOA, NMTBDISPINFOA),
1730 SPNFY(TBN_GETDISPINFOW, NMTBDISPINFOW),
1731 SPNFY(TBN_GETINFOTIPA, NMTBGETINFOTIPA),
1732 SPNFY(TBN_GETINFOTIPW, NMTBGETINFOTIPW),
1733 SPNFY(TBN_GETBUTTONINFOW, NMTOOLBARW),
1734 /* Up/Down 0U-721U to 0U-740U */
1735 SPNFY(UDN_DELTAPOS, NMHDR),
1736 /* Month Calendar 0U-750U to 0U-759U */
1737 /* ******************* WARNING ***************************** */
1738 /* The following appear backwards but needs to be this way. */
1739 /* The reason is that MS (and us) define the MCNs as */
1741 /* instead of the way ALL other notifications are */
1743 /* The only place that this is important is in this list */
1745 /* Also since the same error was made with the DTN_ items, */
1746 /* they overlay the MCN_ and need to be inserted in the */
1747 /* other section of the table so that it is in order for */
1748 /* the binary search. */
1750 /* Thank you MS for your obvious quality control!! */
1751 /* ******************* WARNING ***************************** */
1752 /* Date/Time 0U-760U to 0U-799U */
1753 /* SPNFY(MCN_SELECT, NMHDR), */
1754 /* SPNFY(MCN_GETDAYSTATE, NMHDR), */
1755 /* SPNFY(MCN_SELCHANGE, NMHDR), */
1756 /* ******************* WARNING ***************************** */
1757 /* The following appear backwards but needs to be this way. */
1758 /* The reason is that MS (and us) define the MCNs as */
1760 /* instead of the way ALL other notifications are */
1762 /* The only place that this is important is in this list */
1763 /* ******************* WARNING ***************************** */
1764 SPNFY(DTN_FORMATQUERYW, NMHDR),
1765 SPNFY(DTN_FORMATW, NMHDR),
1766 SPNFY(DTN_WMKEYDOWNW, NMHDR),
1767 SPNFY(DTN_USERSTRINGW, NMHDR),
1768 SPNFY(MCN_SELECT, NMHDR),
1769 SPNFY(MCN_GETDAYSTATE, NMHDR),
1770 SPNFY(MCN_SELCHANGE, NMHDR),
1771 SPNFY(DTN_CLOSEUP, NMHDR),
1772 SPNFY(DTN_DROPDOWN, NMHDR),
1773 SPNFY(DTN_FORMATQUERYA, NMHDR),
1774 SPNFY(DTN_FORMATA, NMHDR),
1775 SPNFY(DTN_WMKEYDOWNA, NMHDR),
1776 SPNFY(DTN_USERSTRINGA, NMHDR),
1777 SPNFY(DTN_DATETIMECHANGE, NMHDR),
1778 /* ComboBoxEx 0U-800U to 0U-830U */
1779 SPNFY(CBEN_GETDISPINFOA, NMCOMBOBOXEXA),
1780 SPNFY(CBEN_INSERTITEM, NMCOMBOBOXEXA),
1781 SPNFY(CBEN_DELETEITEM, NMCOMBOBOXEXA),
1782 SPNFY(CBEN_BEGINEDIT, NMHDR),
1783 SPNFY(CBEN_ENDEDITA, NMCBEENDEDITA),
1784 SPNFY(CBEN_ENDEDITW, NMCBEENDEDITW),
1785 SPNFY(CBEN_GETDISPINFOW, NMCOMBOBOXEXW),
1786 SPNFY(CBEN_DRAGBEGINA, NMCBEDRAGBEGINA),
1787 SPNFY(CBEN_DRAGBEGINW, NMCBEDRAGBEGINW),
1788 /* Rebar 0U-831U to 0U-859U */
1789 SPNFY(RBN_HEIGHTCHANGE, NMHDR),
1790 SPNFY(RBN_GETOBJECT, NMOBJECTNOTIFY),
1791 SPNFY(RBN_LAYOUTCHANGED, NMHDR),
1792 SPNFY(RBN_AUTOSIZE, NMRBAUTOSIZE),
1793 SPNFY(RBN_BEGINDRAG, NMREBAR),
1794 SPNFY(RBN_ENDDRAG, NMREBAR),
1795 SPNFY(RBN_DELETINGBAND, NMREBAR),
1796 SPNFY(RBN_DELETEDBAND, NMREBAR),
1797 SPNFY(RBN_CHILDSIZE, NMREBARCHILDSIZE),
1798 /* IP Adderss 0U-860U to 0U-879U */
1799 SPNFY(IPN_FIELDCHANGED, NMHDR),
1800 /* Status bar 0U-880U to 0U-899U */
1801 SPNFY(SBN_SIMPLEMODECHANGE, NMHDR),
1802 /* Pager 0U-900U to 0U-950U */
1803 SPNFY(PGN_SCROLL, NMPGSCROLL),
1804 SPNFY(PGN_CALCSIZE, NMPGCALCSIZE),
1806 static const SPY_NOTIFY *end_spnfy_array; /* ptr to last good entry in array */
1810 static BOOL16 SPY_Exclude[SPY_MAX_MSGNUM+1];
1811 static BOOL16 SPY_ExcludeDWP = 0;
1813 #define SPY_EXCLUDE(msg) \
1814 (SPY_Exclude[(msg) > SPY_MAX_MSGNUM ? SPY_MAX_MSGNUM : (msg)])
1819 UINT msgnum; /* message number */
1820 HWND msg_hwnd; /* window handle for message */
1821 WPARAM wParam; /* message parameter */
1822 LPARAM lParam; /* message parameter */
1823 INT data_len; /* length of data to dump */
1824 char msg_name[60]; /* message name (see SPY_GetMsgName) */
1825 WCHAR wnd_class[60]; /* window class name (full) */
1826 WCHAR wnd_name[16]; /* window name for message */
1829 /* This is defined so that the external entry point can return the addr */
1830 static SPY_INSTANCE ext_sp_e;
1832 static int indent_tls_index;
1834 /***********************************************************************
1837 inline static int get_indent_level(void)
1839 return (int)TlsGetValue( indent_tls_index );
1843 /***********************************************************************
1846 inline static void set_indent_level( int level )
1848 TlsSetValue( indent_tls_index, (void *)level );
1852 /***********************************************************************
1853 * SPY_GetMsgInternal
1855 static const char *SPY_GetMsgInternal( UINT msg )
1857 if (msg <= SPY_MAX_MSGNUM)
1858 return MessageTypeNames[msg];
1860 if (msg >= LVM_FIRST && msg <= LVM_FIRST + SPY_MAX_LVMMSGNUM)
1861 return LVMMessageTypeNames[msg-LVM_FIRST];
1863 if (msg >= TV_FIRST && msg <= TV_FIRST + SPY_MAX_TVMSGNUM)
1864 return TVMessageTypeNames[msg-TV_FIRST];
1866 if (msg >= HDM_FIRST && msg <= HDM_FIRST + SPY_MAX_HDMMSGNUM)
1867 return HDMMessageTypeNames[msg-HDM_FIRST];
1869 if (msg >= TCM_FIRST && msg <= TCM_FIRST + SPY_MAX_TCMMSGNUM)
1870 return TCMMessageTypeNames[msg-TCM_FIRST];
1872 if (msg >= PGM_FIRST && msg <= PGM_FIRST + SPY_MAX_PGMMSGNUM)
1873 return PGMMessageTypeNames[msg-PGM_FIRST];
1875 if (msg >= CCM_FIRST && msg <= CCM_FIRST + SPY_MAX_CCMMSGNUM)
1876 return CCMMessageTypeNames[msg-CCM_FIRST];
1878 if (msg >= WM_WINE_DESTROYWINDOW && msg <= WM_WINE_DESTROYWINDOW + SPY_MAX_WINEMSGNUM)
1879 return WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW];
1884 /***********************************************************************
1887 const USER_MSG *SPY_Bsearch_Msg( const USER_MSG *first, const USER_MSG *last, UINT code)
1890 const USER_MSG *test;
1892 while (last >= first) {
1893 count = 1 + last - first;
1896 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
1897 code, first->value, first->name, last->value, last->name, last->len);
1899 if (first->value == code) return first;
1900 if (last->value == code) return last;
1904 test = first + count;
1906 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
1907 first, last, test, test->value, code, count);
1909 if (test->value == code) return test;
1910 if (test->value > code)
1918 /***********************************************************************
1921 * Get message name and other information for dumping
1923 static void SPY_GetMsgStuff( SPY_INSTANCE *sp_e )
1926 const char *msg_name = SPY_GetMsgInternal( sp_e->msgnum );
1933 if (sp_e->msgnum >= 0xc000)
1935 if (GlobalGetAtomNameA( sp_e->msgnum, sp_e->msg_name+1, sizeof(sp_e->msg_name)-2 ))
1937 sp_e->msg_name[0] = '\"';
1938 strcat( sp_e->msg_name, "\"" );
1943 TRACE("looking class %s\n", sp_e->wnd_class);
1946 while (cc_array[i].classname &&
1947 strcmpW(cc_array[i].classname, sp_e->wnd_class) !=0) i++;
1949 if (cc_array[i].classname)
1952 TRACE("process class %s, first %p, last %p\n",
1953 debugstr_w(cc_array[i].classname), cc_array[i].classmsg,
1954 cc_array[i].lastmsg);
1956 p = SPY_Bsearch_Msg (cc_array[i].classmsg, cc_array[i].lastmsg,
1959 strncpy (sp_e->msg_name, p->name, sizeof(sp_e->msg_name)-1);
1960 sp_e->data_len = p->len;
1964 sprintf( sp_e->msg_name, "%04x", sp_e->msgnum );
1968 strncpy(sp_e->msg_name, msg_name, sizeof(sp_e->msg_name)-1);
1969 sp_e->msg_name[sizeof(sp_e->msg_name)-1] = 0;
1973 /***********************************************************************
1976 * Sets the value of "wnd_name" and "wnd_class" members of the
1977 * instance structure.
1980 void SPY_GetWndName( SPY_INSTANCE *sp_e )
1985 /* save and restore error code over the next call */
1986 save_error = GetLastError();
1987 /* special code to detect a property sheet dialog */
1988 if ((GetClassLongW(sp_e->msg_hwnd, GCW_ATOM) == (LONG)WC_DIALOGW) &&
1989 (GetPropW(sp_e->msg_hwnd, PropSheetInfoStr))) {
1990 strcpyW(sp_e->wnd_class, WC_PROPSHEETW);
1993 GetClassNameW(sp_e->msg_hwnd, sp_e->wnd_class, sizeof(sp_e->wnd_class)/sizeof(WCHAR));
1995 SetLastError(save_error);
1997 len = InternalGetWindowText(sp_e->msg_hwnd, sp_e->wnd_name, sizeof(sp_e->wnd_name)/sizeof(WCHAR));
1998 if(!len) /* get class name */
2000 LPWSTR dst = sp_e->wnd_name;
2001 LPWSTR src = sp_e->wnd_class;
2002 int n = sizeof(sp_e->wnd_name)/sizeof(WCHAR) - 3;
2004 while ((n-- > 0) && *src) *dst++ = *src++;
2010 /***********************************************************************
2013 * **** External function ****
2017 const char *SPY_GetMsgName( UINT msg, HWND hWnd )
2019 ext_sp_e.msgnum = msg;
2020 ext_sp_e.msg_hwnd = hWnd;
2021 ext_sp_e.lParam = 0;
2022 ext_sp_e.wParam = 0;
2023 SPY_GetWndName(&ext_sp_e);
2024 SPY_GetMsgStuff(&ext_sp_e);
2025 return ext_sp_e.msg_name;
2028 /***********************************************************************
2031 const char *SPY_GetVKeyName(WPARAM wParam)
2033 const char *vk_key_name;
2035 if(wParam <= SPY_MAX_VKKEYSNUM && VK_KeyNames[wParam])
2036 vk_key_name = VK_KeyNames[wParam];
2038 vk_key_name = "VK_???";
2043 /***********************************************************************
2044 * SPY_Bsearch_Notify
2046 const SPY_NOTIFY *SPY_Bsearch_Notify( const SPY_NOTIFY *first, const SPY_NOTIFY *last, UINT code)
2049 const SPY_NOTIFY *test;
2051 while (last >= first) {
2052 count = 1 + last - first;
2055 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
2056 code, first->value, first->name, last->value, last->name, last->len);
2058 if (first->value == code) return first;
2059 if (last->value == code) return last;
2063 test = first + count;
2065 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
2066 first, last, test, test->value, code, count);
2068 if (test->value == code) return test;
2069 if (test->value < code)
2077 /***********************************************************************
2080 void SPY_DumpMem (LPCSTR header, UINT *q, INT len)
2084 for(i=0; i<len-12; i+=16) {
2085 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2086 header, i, *q, *(q+1), *(q+2), *(q+3));
2089 switch ((len - i + 3) & (~3)) {
2091 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2092 header, i, *q, *(q+1), *(q+2), *(q+3));
2095 TRACE("%s [%04x] %08x %08x %08x\n",
2096 header, i, *q, *(q+1), *(q+2));
2099 TRACE("%s [%04x] %08x %08x\n",
2100 header, i, *q, *(q+1));
2103 TRACE("%s [%04x] %08x\n",
2111 /***********************************************************************
2114 void SPY_DumpStructure (SPY_INSTANCE *sp_e, BOOL enter)
2116 switch (sp_e->msgnum)
2118 case LVM_INSERTITEMW:
2119 case LVM_INSERTITEMA:
2127 LPLVITEMA item = (LPLVITEMA) sp_e->lParam;
2129 SPY_DumpMem ("LVITEM", (UINT*)item, sizeof(LVITEMA));
2133 case TCM_INSERTITEMW:
2134 case TCM_INSERTITEMA:
2142 TCITEMA *item = (TCITEMA *) sp_e->lParam;
2144 SPY_DumpMem ("TCITEM", (UINT*)item, sizeof(TCITEMA));
2148 case TCM_ADJUSTRECT:
2149 case LVM_GETITEMRECT:
2150 case LVM_GETSUBITEMRECT:
2152 LPRECT rc = (LPRECT) sp_e->lParam;
2154 TRACE("lParam rect (%ld,%ld)-(%ld,%ld)\n",
2155 rc->left, rc->top, rc->right, rc->bottom);
2159 case LVM_SETITEMPOSITION32:
2162 case LVM_GETITEMPOSITION:
2165 LPPOINT point = (LPPOINT) sp_e->lParam;
2167 TRACE("lParam point x=%ld, y=%ld\n", point->x, point->y);
2172 if (!enter && (sp_e->msgnum == SBM_SETRANGE)) break;
2173 TRACE("min=%d max=%d\n", (INT)sp_e->wParam, (INT)sp_e->lParam);
2176 if ((enter && (sp_e->msgnum == SBM_GETRANGE)) ||
2177 (!enter && (sp_e->msgnum == SBM_SETRANGE))) break;
2179 LPINT ptmin = (LPINT) sp_e->wParam;
2180 LPINT ptmax = (LPINT) sp_e->lParam;
2182 TRACE("min=%d max=%d\n", *ptmin, *ptmax);
2184 TRACE("min=%d max=n/a\n", *ptmin);
2186 TRACE("min=n/a max=%d\n", *ptmax);
2192 DRAWITEMSTRUCT *lpdis = (DRAWITEMSTRUCT*) sp_e->lParam;
2193 TRACE("DRAWITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2194 lpdis->CtlType, lpdis->CtlID);
2195 TRACE("itemID=0x%08x itemAction=0x%08x itemState=0x%08x\n",
2196 lpdis->itemID, lpdis->itemAction, lpdis->itemState);
2197 TRACE("hWnd=%p hDC=%p (%ld,%ld)-(%ld,%ld) itemData=0x%08lx\n",
2198 lpdis->hwndItem, lpdis->hDC, lpdis->rcItem.left,
2199 lpdis->rcItem.top, lpdis->rcItem.right,
2200 lpdis->rcItem.bottom, lpdis->itemData);
2203 case WM_MEASUREITEM:
2205 MEASUREITEMSTRUCT *lpmis = (MEASUREITEMSTRUCT*) sp_e->lParam;
2206 TRACE("MEASUREITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2207 lpmis->CtlType, lpmis->CtlID);
2208 TRACE("itemID=0x%08x itemWidth=0x%08x itemHeight=0x%08x\n",
2209 lpmis->itemID, lpmis->itemWidth, lpmis->itemHeight);
2210 TRACE("itemData=0x%08lx\n", lpmis->itemData);
2215 TRACE("cx=%d cy=%d\n", LOWORD(sp_e->lParam), HIWORD(sp_e->lParam));
2217 case WM_WINDOWPOSCHANGED:
2219 case WM_WINDOWPOSCHANGING:
2221 WINDOWPOS *lpwp = (WINDOWPOS *)sp_e->lParam;
2222 TRACE("WINDOWPOS hwnd=%p, after=%p, at (%d,%d) w=%d h=%d, flags=0x%08x\n",
2223 lpwp->hwnd, lpwp->hwndInsertAfter, lpwp->x, lpwp->y,
2224 lpwp->cx, lpwp->cy, lpwp->flags);
2227 case WM_STYLECHANGED:
2229 case WM_STYLECHANGING:
2231 LPSTYLESTRUCT ss = (LPSTYLESTRUCT) sp_e->lParam;
2232 TRACE("STYLESTRUCT: StyleOld=0x%08lx, StyleNew=0x%08lx\n",
2233 ss->styleOld, ss->styleNew);
2238 RECT *rc = (RECT *)sp_e->lParam;
2239 TRACE("Rect (%ld,%ld)-(%ld,%ld)\n",
2240 rc->left, rc->top, rc->right, rc->bottom);
2244 /* if (!enter) break; */
2246 NMHDR * pnmh = (NMHDR*) sp_e->lParam;
2248 const SPY_NOTIFY *p;
2249 WCHAR from_class[60];
2252 p = SPY_Bsearch_Notify (&spnfy_array[0], end_spnfy_array,
2255 TRACE("NMHDR hwndFrom=%p idFrom=0x%08x code=%s<0x%08x>, extra=0x%x\n",
2256 pnmh->hwndFrom, pnmh->idFrom, p->name, pnmh->code, p->len);
2259 /* for CUSTOMDRAW, dump all the data for TOOLBARs */
2260 if (pnmh->code == NM_CUSTOMDRAW) {
2261 /* save and restore error code over the next call */
2262 save_error = GetLastError();
2263 GetClassNameW(pnmh->hwndFrom, from_class,
2264 sizeof(from_class)/sizeof(WCHAR));
2265 SetLastError(save_error);
2266 if (strcmpW(TOOLBARCLASSNAMEW, from_class) == 0)
2267 dumplen = sizeof(NMTBCUSTOMDRAW)-sizeof(NMHDR);
2270 q = (UINT *)(pnmh + 1);
2271 SPY_DumpMem ("NM extra", q, (INT)dumplen);
2275 TRACE("NMHDR hwndFrom=%p idFrom=0x%08x code=0x%08x\n",
2276 pnmh->hwndFrom, pnmh->idFrom, pnmh->code);
2279 if (sp_e->data_len > 0)
2280 SPY_DumpMem ("MSG lParam", (UINT *)sp_e->lParam, sp_e->data_len);
2285 /***********************************************************************
2288 void SPY_EnterMessage( INT iFlag, HWND hWnd, UINT msg,
2289 WPARAM wParam, LPARAM lParam )
2294 if (!TRACE_ON(message) || SPY_EXCLUDE(msg)) return;
2297 sp_e.msg_hwnd = hWnd;
2298 sp_e.lParam = lParam;
2299 sp_e.wParam = wParam;
2300 SPY_GetWndName(&sp_e);
2301 SPY_GetMsgStuff(&sp_e);
2302 indent = get_indent_level();
2304 /* each SPY_SENDMESSAGE must be complemented by call to SPY_ExitMessage */
2307 case SPY_DISPATCHMESSAGE16:
2308 TRACE("%*s(%04x) %-16s message [%04x] %s dispatched wp=%04x lp=%08lx\n",
2309 indent, "", HWND_16(hWnd),
2310 debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name, wParam, lParam);
2313 case SPY_DISPATCHMESSAGE:
2314 TRACE("%*s(%p) %-16s message [%04x] %s dispatched wp=%08x lp=%08lx\n",
2315 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2316 sp_e.msg_name, wParam, lParam);
2319 case SPY_SENDMESSAGE16:
2320 case SPY_SENDMESSAGE:
2323 DWORD tid = GetWindowThreadProcessId( hWnd, NULL );
2325 if (tid == GetCurrentThreadId()) strcpy( taskName, "self" );
2326 else sprintf( taskName, "tid %04lx", GetCurrentThreadId() );
2328 if (iFlag == SPY_SENDMESSAGE16)
2329 TRACE("%*s(%04x) %-16s message [%04x] %s sent from %s wp=%04x lp=%08lx\n",
2330 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2331 sp_e.msg_name, taskName, wParam, lParam );
2333 { TRACE("%*s(%p) %-16s message [%04x] %s sent from %s wp=%08x lp=%08lx\n",
2334 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2335 sp_e.msg_name, taskName, wParam, lParam );
2336 SPY_DumpStructure(&sp_e, TRUE);
2341 case SPY_DEFWNDPROC16:
2342 if( SPY_ExcludeDWP ) return;
2343 TRACE("%*s(%04x) DefWindowProc16: %s [%04x] wp=%04x lp=%08lx\n",
2344 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, wParam, lParam );
2347 case SPY_DEFWNDPROC:
2348 if( SPY_ExcludeDWP ) return;
2349 TRACE("%*s(%p) DefWindowProc32: %s [%04x] wp=%08x lp=%08lx\n",
2350 indent, "", hWnd, sp_e.msg_name,
2351 msg, wParam, lParam );
2354 set_indent_level( indent + SPY_INDENT_UNIT );
2358 /***********************************************************************
2361 void SPY_ExitMessage( INT iFlag, HWND hWnd, UINT msg, LRESULT lReturn,
2362 WPARAM wParam, LPARAM lParam )
2367 if (!TRACE_ON(message) || SPY_EXCLUDE(msg) ||
2368 (SPY_ExcludeDWP && (iFlag == SPY_RESULT_DEFWND16 || iFlag == SPY_RESULT_DEFWND)) )
2372 sp_e.msg_hwnd = hWnd;
2373 sp_e.lParam = lParam;
2374 sp_e.wParam = wParam;
2375 SPY_GetWndName(&sp_e);
2376 SPY_GetMsgStuff(&sp_e);
2378 if ((indent = get_indent_level()))
2380 indent -= SPY_INDENT_UNIT;
2381 set_indent_level( indent );
2386 case SPY_RESULT_DEFWND16:
2387 TRACE(" %*s(%04x) DefWindowProc16: %s [%04x] returned %08lx\n",
2388 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, lReturn );
2391 case SPY_RESULT_DEFWND:
2392 TRACE(" %*s(%p) DefWindowProc32: %s [%04x] returned %08lx\n",
2393 indent, "", hWnd, sp_e.msg_name, msg, lReturn );
2396 case SPY_RESULT_OK16:
2397 TRACE(" %*s(%04x) %-16s message [%04x] %s returned %08lx\n",
2398 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2399 sp_e.msg_name, lReturn );
2403 TRACE(" %*s(%p) %-16s message [%04x] %s returned %08lx\n",
2404 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2405 sp_e.msg_name, lReturn );
2406 SPY_DumpStructure(&sp_e, FALSE);
2409 case SPY_RESULT_INVALIDHWND16:
2410 WARN(" %*s(%04x) %-16s message [%04x] %s HAS INVALID HWND\n",
2411 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name );
2414 case SPY_RESULT_INVALIDHWND:
2415 WARN(" %*s(%p) %-16s message [%04x] %s HAS INVALID HWND\n",
2416 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2423 /***********************************************************************
2430 const SPY_NOTIFY *p;
2434 if (!TRACE_ON(message)) return TRUE;
2436 indent_tls_index = TlsAlloc();
2437 if(!RegOpenKeyA(HKEY_LOCAL_MACHINE, "Software\\Wine\\Wine\\Config\\Debug", &hkey))
2439 DWORD type, count = sizeof(buffer);
2442 if (!RegQueryValueExA(hkey, "SpyInclude", 0, &type, buffer, &count) &&
2443 strcmp( buffer, "INCLUDEALL" ))
2445 TRACE("Include=%s\n", buffer );
2446 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2447 SPY_Exclude[i] = (MessageTypeNames[i] && !strstr(buffer,MessageTypeNames[i]));
2450 count = sizeof(buffer);
2452 if (!RegQueryValueExA(hkey, "SpyExclude", 0, &type, buffer, &count))
2454 TRACE("Exclude=%s\n", buffer );
2455 if (!strcmp( buffer, "EXCLUDEALL" ))
2456 for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = TRUE;
2458 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2459 SPY_Exclude[i] = (MessageTypeNames[i] && strstr(buffer,MessageTypeNames[i]));
2463 count = sizeof(buffer);
2464 if(!RegQueryValueExA(hkey, "SpyExcludeDWP", 0, &type, buffer, &count))
2465 SPY_ExcludeDWP = atoi(buffer);
2470 /* find last good entry in spy notify array and save addr for b-search */
2471 p = &spnfy_array[0];
2474 if ((UINT)p->value > (UINT)j) {
2475 ERR("Notify message array out of order\n");
2476 ERR(" between values [%08x] %s and [%08x] %s\n",
2477 j, (p-1)->name, p->value, p->name);
2484 end_spnfy_array = p;
2486 /* find last good entry in each common control message array
2487 * and save addr for b-search.
2490 while (cc_array[i].classname) {
2492 j = 0x0400; /* minimum entry in array */
2493 q = cc_array[i].classmsg;
2495 if (q->value <= j) {
2496 ERR("Class message array out of order for class %s\n",
2497 debugstr_w(cc_array[i].classname));
2498 ERR(" between values [%04x] %s and [%04x] %s\n",
2499 j, (q-1)->name, q->value, q->name);
2506 cc_array[i].lastmsg = (USER_MSG *)q;