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