Moved debug output up before calling the backend.
[wine/wine-kai.git] / windows / spy.c
blob7c5ae73c7d04c428981ffc51a17ca6094fce6b59
1 /*
2 * Message spying routines
4 * Copyright 1994, Bob Amstadt
5 * 1995, Alex Korobka
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
22 #include <stdlib.h>
23 #include <string.h>
24 #include <stdarg.h>
25 #include <stdio.h>
26 #include "windef.h"
27 #include "winbase.h"
28 #include "wingdi.h"
29 #include "winreg.h"
30 #include "wownt32.h"
31 #include "wine/unicode.h"
32 #include "win.h"
33 #include "wine/debug.h"
34 #include "message.h"
35 #include "winnls.h"
36 #include "commctrl.h"
38 WINE_DEFAULT_DEBUG_CHANNEL(message);
40 #define SPY_MAX_MSGNUM WM_USER
41 #define SPY_INDENT_UNIT 4 /* 4 spaces */
43 #define DEBUG_SPY 0
45 static const char * const MessageTypeNames[SPY_MAX_MSGNUM + 1] =
47 "WM_NULL", /* 0x00 */
48 "WM_CREATE",
49 "WM_DESTROY",
50 "WM_MOVE",
51 "wm_sizewait",
52 "WM_SIZE",
53 "WM_ACTIVATE",
54 "WM_SETFOCUS",
55 "WM_KILLFOCUS",
56 "WM_SETVISIBLE",
57 "WM_ENABLE",
58 "WM_SETREDRAW",
59 "WM_SETTEXT",
60 "WM_GETTEXT",
61 "WM_GETTEXTLENGTH",
62 "WM_PAINT",
63 "WM_CLOSE", /* 0x10 */
64 "WM_QUERYENDSESSION",
65 "WM_QUIT",
66 "WM_QUERYOPEN",
67 "WM_ERASEBKGND",
68 "WM_SYSCOLORCHANGE",
69 "WM_ENDSESSION",
70 "wm_systemerror",
71 "WM_SHOWWINDOW",
72 "WM_CTLCOLOR",
73 "WM_WININICHANGE",
74 "WM_DEVMODECHANGE",
75 "WM_ACTIVATEAPP",
76 "WM_FONTCHANGE",
77 "WM_TIMECHANGE",
78 "WM_CANCELMODE",
79 "WM_SETCURSOR", /* 0x20 */
80 "WM_MOUSEACTIVATE",
81 "WM_CHILDACTIVATE",
82 "WM_QUEUESYNC",
83 "WM_GETMINMAXINFO",
84 "wm_unused3",
85 "wm_painticon",
86 "WM_ICONERASEBKGND",
87 "WM_NEXTDLGCTL",
88 "wm_alttabactive",
89 "WM_SPOOLERSTATUS",
90 "WM_DRAWITEM",
91 "WM_MEASUREITEM",
92 "WM_DELETEITEM",
93 "WM_VKEYTOITEM",
94 "WM_CHARTOITEM",
95 "WM_SETFONT", /* 0x30 */
96 "WM_GETFONT",
97 "WM_SETHOTKEY",
98 "WM_GETHOTKEY",
99 "wm_filesyschange",
100 "wm_isactiveicon",
101 "wm_queryparkicon",
102 "WM_QUERYDRAGICON",
103 "wm_querysavestate",
104 "WM_COMPAREITEM",
105 "wm_testing",
106 NULL,
107 "wm_otherwindowcreated",
108 "wm_otherwindowdestroyed",
109 "wm_activateshellwindow",
110 NULL,
112 NULL, /* 0x40 */
113 "wm_compacting", NULL, NULL,
114 "WM_COMMNOTIFY", NULL,
115 "WM_WINDOWPOSCHANGING", /* 0x0046 */
116 "WM_WINDOWPOSCHANGED", /* 0x0047 */
117 "WM_POWER", NULL,
118 "WM_COPYDATA",
119 "WM_CANCELJOURNAL", NULL, NULL,
120 "WM_NOTIFY", NULL,
122 /* 0x0050 */
123 "WM_INPUTLANGCHANGEREQUEST",
124 "WM_INPUTLANGCHANGE",
125 "WM_TCARD",
126 "WM_HELP",
127 "WM_USERCHANGED",
128 "WM_NOTIFYFORMAT", NULL, NULL,
129 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
131 /* 0x0060 */
132 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
133 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
135 /* 0x0070 */
136 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
137 NULL, NULL, NULL,
138 "WM_CONTEXTMENU",
139 "WM_STYLECHANGING",
140 "WM_STYLECHANGED",
141 "WM_DISPLAYCHANGE",
142 "WM_GETICON",
144 "WM_SETICON", /* 0x0080 */
145 "WM_NCCREATE", /* 0x0081 */
146 "WM_NCDESTROY", /* 0x0082 */
147 "WM_NCCALCSIZE", /* 0x0083 */
148 "WM_NCHITTEST", /* 0x0084 */
149 "WM_NCPAINT", /* 0x0085 */
150 "WM_NCACTIVATE", /* 0x0086 */
151 "WM_GETDLGCODE", /* 0x0087 */
152 "WM_SYNCPAINT",
153 "WM_SYNCTASK", NULL, NULL, NULL, NULL, NULL, NULL,
155 /* 0x0090 */
156 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
157 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
159 /* 0x00A0 */
160 "WM_NCMOUSEMOVE", /* 0x00A0 */
161 "WM_NCLBUTTONDOWN", /* 0x00A1 */
162 "WM_NCLBUTTONUP", /* 0x00A2 */
163 "WM_NCLBUTTONDBLCLK", /* 0x00A3 */
164 "WM_NCRBUTTONDOWN", /* 0x00A4 */
165 "WM_NCRBUTTONUP", /* 0x00A5 */
166 "WM_NCRBUTTONDBLCLK", /* 0x00A6 */
167 "WM_NCMBUTTONDOWN", /* 0x00A7 */
168 "WM_NCMBUTTONUP", /* 0x00A8 */
169 "WM_NCMBUTTONDBLCLK", /* 0x00A9 */
170 NULL, NULL, NULL, NULL, NULL, NULL,
172 /* 0x00B0 - Win32 Edit controls */
173 "EM_GETSEL", /* 0x00b0 */
174 "EM_SETSEL", /* 0x00b1 */
175 "EM_GETRECT", /* 0x00b2 */
176 "EM_SETRECT", /* 0x00b3 */
177 "EM_SETRECTNP", /* 0x00b4 */
178 "EM_SCROLL", /* 0x00b5 */
179 "EM_LINESCROLL", /* 0x00b6 */
180 "EM_SCROLLCARET", /* 0x00b7 */
181 "EM_GETMODIFY", /* 0x00b8 */
182 "EM_SETMODIFY", /* 0x00b9 */
183 "EM_GETLINECOUNT", /* 0x00ba */
184 "EM_LINEINDEX", /* 0x00bb */
185 "EM_SETHANDLE", /* 0x00bc */
186 "EM_GETHANDLE", /* 0x00bd */
187 "EM_GETTHUMB", /* 0x00be */
188 NULL, /* 0x00bf */
190 NULL, /* 0x00c0 */
191 "EM_LINELENGTH", /* 0x00c1 */
192 "EM_REPLACESEL", /* 0x00c2 */
193 NULL, /* 0x00c3 */
194 "EM_GETLINE", /* 0x00c4 */
195 "EM_LIMITTEXT", /* 0x00c5 */
196 "EM_CANUNDO", /* 0x00c6 */
197 "EM_UNDO", /* 0x00c7 */
198 "EM_FMTLINES", /* 0x00c8 */
199 "EM_LINEFROMCHAR", /* 0x00c9 */
200 NULL, /* 0x00ca */
201 "EM_SETTABSTOPS", /* 0x00cb */
202 "EM_SETPASSWORDCHAR", /* 0x00cc */
203 "EM_EMPTYUNDOBUFFER", /* 0x00cd */
204 "EM_GETFIRSTVISIBLELINE", /* 0x00ce */
205 "EM_SETREADONLY", /* 0x00cf */
207 "EM_SETWORDBREAKPROC", /* 0x00d0 */
208 "EM_GETWORDBREAKPROC", /* 0x00d1 */
209 "EM_GETPASSWORDCHAR", /* 0x00d2 */
210 "EM_SETMARGINS", /* 0x00d3 */
211 "EM_GETMARGINS", /* 0x00d4 */
212 "EM_GETLIMITTEXT", /* 0x00d5 */
213 "EM_POSFROMCHAR", /* 0x00d6 */
214 "EM_CHARFROMPOS", /* 0x00d7 */
215 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
217 /* 0x00E0 - Win32 Scrollbars */
218 "SBM_SETPOS", /* 0x00e0 */
219 "SBM_GETPOS", /* 0x00e1 */
220 "SBM_SETRANGE", /* 0x00e2 */
221 "SBM_GETRANGE", /* 0x00e3 */
222 "SBM_ENABLE_ARROWS", /* 0x00e4 */
223 NULL,
224 "SBM_SETRANGEREDRAW", /* 0x00e6 */
225 NULL, NULL,
226 "SBM_SETSCROLLINFO", /* 0x00e9 */
227 "SBM_GETSCROLLINFO", /* 0x00ea */
228 NULL, NULL, NULL, NULL, NULL,
230 /* 0x00F0 - Win32 Buttons */
231 "BM_GETCHECK", /* 0x00f0 */
232 "BM_SETCHECK", /* 0x00f1 */
233 "BM_GETSTATE", /* 0x00f2 */
234 "BM_SETSTATE", /* 0x00f3 */
235 "BM_SETSTYLE", /* 0x00f4 */
236 "BM_CLICK", /* 0x00f5 */
237 "BM_GETIMAGE", /* 0x00f6 */
238 "BM_SETIMAGE", /* 0x00f7 */
239 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
241 "WM_KEYDOWN", /* 0x0100 */
242 "WM_KEYUP", /* 0x0101 */
243 "WM_CHAR", /* 0x0102 */
244 "WM_DEADCHAR", /* 0x0103 */
245 "WM_SYSKEYDOWN", /* 0x0104 */
246 "WM_SYSKEYUP", /* 0x0105 */
247 "WM_SYSCHAR", /* 0x0106 */
248 "WM_SYSDEADCHAR", /* 0x0107 */
249 "WM_KEYLAST", /* 0x0108 */
250 NULL,
251 "WM_CONVERTREQUEST",
252 "WM_CONVERTRESULT",
253 "WM_INTERIM",
254 "WM_IME_STARTCOMPOSITION", /* 0x010d */
255 "WM_IME_ENDCOMPOSITION", /* 0x010e */
256 "WM_IME_COMPOSITION", /* 0x010f */
258 "WM_INITDIALOG", /* 0x0110 */
259 "WM_COMMAND", /* 0x0111 */
260 "WM_SYSCOMMAND", /* 0x0112 */
261 "WM_TIMER", /* 0x0113 */
262 "WM_HSCROLL", /* 0x0114 */
263 "WM_VSCROLL", /* 0x0115 */
264 "WM_INITMENU", /* 0x0116 */
265 "WM_INITMENUPOPUP", /* 0x0117 */
266 "WM_SYSTIMER", /* 0x0118 */
267 NULL, NULL, NULL, NULL, NULL, NULL,
268 "WM_MENUSELECT", /* 0x011f */
270 "WM_MENUCHAR", /* 0x0120 */
271 "WM_ENTERIDLE", /* 0x0121 */
273 "WM_MENURBUTTONUP", /* 0x0122 */
274 "WM_MENUDRAG", /* 0x0123 */
275 "WM_MENUGETOBJECT", /* 0x0124 */
276 "WM_UNINITMENUPOPUP", /* 0x0125 */
277 "WM_MENUCOMMAND", /* 0x0126 */
278 "WM_CHANGEUISTATE", /* 0x0127 */
279 "WM_UPDATEUISTATE", /* 0x0128 */
280 "WM_QUERYUISTATE", /* 0x0129 */
282 NULL, NULL, NULL, NULL, NULL, NULL,
284 /* 0x0130 */
285 NULL,
286 "WM_LBTRACKPOINT", /* 0x0131 */
287 "WM_CTLCOLORMSGBOX", /* 0x0132 */
288 "WM_CTLCOLOREDIT", /* 0x0133 */
289 "WM_CTLCOLORLISTBOX", /* 0x0134 */
290 "WM_CTLCOLORBTN", /* 0x0135 */
291 "WM_CTLCOLORDLG", /* 0x0136 */
292 "WM_CTLCOLORSCROLLBAR", /* 0x0137 */
293 "WM_CTLCOLORSTATIC", /* 0x0138 */
294 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
296 /* 0x0140 - Win32 Comboboxes */
297 "CB_GETEDITSEL", /* 0x0140 */
298 "CB_LIMITTEXT", /* 0x0141 */
299 "CB_SETEDITSEL", /* 0x0142 */
300 "CB_ADDSTRING", /* 0x0143 */
301 "CB_DELETESTRING", /* 0x0144 */
302 "CB_DIR", /* 0x0145 */
303 "CB_GETCOUNT", /* 0x0146 */
304 "CB_GETCURSEL", /* 0x0147 */
305 "CB_GETLBTEXT", /* 0x0148 */
306 "CB_GETLBTEXTLEN", /* 0x0149 */
307 "CB_INSERTSTRING", /* 0x014a */
308 "CB_RESETCONTENT", /* 0x014b */
309 "CB_FINDSTRING", /* 0x014c */
310 "CB_SELECTSTRING", /* 0x014d */
311 "CB_SETCURSEL", /* 0x014e */
312 "CB_SHOWDROPDOWN", /* 0x014f */
314 "CB_GETITEMDATA", /* 0x0150 */
315 "CB_SETITEMDATA", /* 0x0151 */
316 "CB_GETDROPPEDCONTROLRECT", /* 0x0152 */
317 "CB_SETITEMHEIGHT", /* 0x0153 */
318 "CB_GETITEMHEIGHT", /* 0x0154 */
319 "CB_SETEXTENDEDUI", /* 0x0155 */
320 "CB_GETEXTENDEDUI", /* 0x0156 */
321 "CB_GETDROPPEDSTATE", /* 0x0157 */
322 "CB_FINDSTRINGEXACT", /* 0x0158 */
323 "CB_SETLOCALE", /* 0x0159 */
324 "CB_GETLOCALE", /* 0x015a */
325 "CB_GETTOPINDEX", /* 0x015b */
326 "CB_SETTOPINDEX", /* 0x015c */
327 "CB_GETHORIZONTALEXTENT", /* 0x015d */
328 "CB_SETHORIZONTALEXTENT", /* 0x015e */
329 "CB_GETDROPPEDWIDTH", /* 0x015f */
331 "CB_SETDROPPEDWIDTH", /* 0x0160 */
332 "CB_INITSTORAGE", /* 0x0161 */
333 NULL, NULL, NULL, NULL, NULL, NULL,
334 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
336 /* 0x0170 - Win32 Static controls */
337 "STM_SETICON", /* 0x0170 */
338 "STM_GETICON", /* 0x0171 */
339 "STM_SETIMAGE", /* 0x0172 */
340 "STM_GETIMAGE", /* 0x0173 */
341 NULL, NULL, NULL, NULL,
342 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
344 /* 0x0180 - Win32 Listboxes */
345 "LB_ADDSTRING", /* 0x0180 */
346 "LB_INSERTSTRING", /* 0x0181 */
347 "LB_DELETESTRING", /* 0x0182 */
348 "LB_SELITEMRANGEEX", /* 0x0183 */
349 "LB_RESETCONTENT", /* 0x0184 */
350 "LB_SETSEL", /* 0x0185 */
351 "LB_SETCURSEL", /* 0x0186 */
352 "LB_GETSEL", /* 0x0187 */
353 "LB_GETCURSEL", /* 0x0188 */
354 "LB_GETTEXT", /* 0x0189 */
355 "LB_GETTEXTLEN", /* 0x018a */
356 "LB_GETCOUNT", /* 0x018b */
357 "LB_SELECTSTRING", /* 0x018c */
358 "LB_DIR", /* 0x018d */
359 "LB_GETTOPINDEX", /* 0x018e */
360 "LB_FINDSTRING", /* 0x018f */
362 "LB_GETSELCOUNT", /* 0x0190 */
363 "LB_GETSELITEMS", /* 0x0191 */
364 "LB_SETTABSTOPS", /* 0x0192 */
365 "LB_GETHORIZONTALEXTENT", /* 0x0193 */
366 "LB_SETHORIZONTALEXTENT", /* 0x0194 */
367 "LB_SETCOLUMNWIDTH", /* 0x0195 */
368 "LB_ADDFILE", /* 0x0196 */
369 "LB_SETTOPINDEX", /* 0x0197 */
370 "LB_GETITEMRECT", /* 0x0198 */
371 "LB_GETITEMDATA", /* 0x0199 */
372 "LB_SETITEMDATA", /* 0x019a */
373 "LB_SELITEMRANGE", /* 0x019b */
374 "LB_SETANCHORINDEX", /* 0x019c */
375 "LB_GETANCHORINDEX", /* 0x019d */
376 "LB_SETCARETINDEX", /* 0x019e */
377 "LB_GETCARETINDEX", /* 0x019f */
379 "LB_SETITEMHEIGHT", /* 0x01a0 */
380 "LB_GETITEMHEIGHT", /* 0x01a1 */
381 "LB_FINDSTRINGEXACT", /* 0x01a2 */
382 "LB_CARETON", /* 0x01a3 */
383 "LB_CARETOFF", /* 0x01a4 */
384 "LB_SETLOCALE", /* 0x01a5 */
385 "LB_GETLOCALE", /* 0x01a6 */
386 "LB_SETCOUNT", /* 0x01a7 */
387 "LB_INITSTORAGE", /* 0x01a8 */
388 "LB_ITEMFROMPOINT", /* 0x01a9 */
389 NULL, NULL, NULL, NULL, NULL, NULL,
391 /* 0x01B0 */
392 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
393 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
395 /* 0x01C0 */
396 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
397 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
399 /* 0x01D0 */
400 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
401 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
403 /* 0x01E0 */
404 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
405 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
407 /* 0x01F0 */
408 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
409 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
411 "WM_MOUSEMOVE", /* 0x0200 */
412 "WM_LBUTTONDOWN", /* 0x0201 */
413 "WM_LBUTTONUP", /* 0x0202 */
414 "WM_LBUTTONDBLCLK", /* 0x0203 */
415 "WM_RBUTTONDOWN", /* 0x0204 */
416 "WM_RBUTTONUP", /* 0x0205 */
417 "WM_RBUTTONDBLCLK", /* 0x0206 */
418 "WM_MBUTTONDOWN", /* 0x0207 */
419 "WM_MBUTTONUP", /* 0x0208 */
420 "WM_MBUTTONDBLCLK", /* 0x0209 */
421 "WM_MOUSEWHEEL", /* 0x020A */
422 NULL, NULL, NULL, NULL, NULL,
424 "WM_PARENTNOTIFY", /* 0x0210 */
425 "WM_ENTERMENULOOP", /* 0x0211 */
426 "WM_EXITMENULOOP", /* 0x0212 */
427 "WM_NEXTMENU", /* 0x0213 */
428 "WM_SIZING",
429 "WM_CAPTURECHANGED",
430 "WM_MOVING", NULL,
431 "WM_POWERBROADCAST",
432 "WM_DEVICECHANGE", NULL, NULL, NULL, NULL, NULL, NULL,
434 "WM_MDICREATE", /* 0x0220 */
435 "WM_MDIDESTROY", /* 0x0221 */
436 "WM_MDIACTIVATE", /* 0x0222 */
437 "WM_MDIRESTORE", /* 0x0223 */
438 "WM_MDINEXT", /* 0x0224 */
439 "WM_MDIMAXIMIZE", /* 0x0225 */
440 "WM_MDITILE", /* 0x0226 */
441 "WM_MDICASCADE", /* 0x0227 */
442 "WM_MDIICONARRANGE", /* 0x0228 */
443 "WM_MDIGETACTIVE", /* 0x0229 */
445 "WM_DROPOBJECT",
446 "WM_QUERYDROPOBJECT",
447 "WM_BEGINDRAG",
448 "WM_DRAGLOOP",
449 "WM_DRAGSELECT",
450 "WM_DRAGMOVE",
452 /* 0x0230*/
453 "WM_MDISETMENU", /* 0x0230 */
454 "WM_ENTERSIZEMOVE", /* 0x0231 */
455 "WM_EXITSIZEMOVE", /* 0x0232 */
456 "WM_DROPFILES", /* 0x0233 */
457 "WM_MDIREFRESHMENU", NULL, NULL, NULL,
458 /* 0x0238*/
459 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
461 /* 0x0240 */
462 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
463 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
465 /* 0x0250 */
466 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
467 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
469 /* 0x0260 */
470 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
471 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
472 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
473 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
475 /* 0x0280 */
476 NULL, "WM_IME_SETCONTEXT", "WM_IME_NOTIFY", "WM_IME_CONTROL", "WM_IME_COMPOSITIONFULL", "WM_IME_SELECT", "WM_IME_CHAR", NULL,
477 "WM_IME_REQUEST", NULL, NULL, NULL, NULL, NULL, NULL, NULL,
478 "WM_IME_KEYDOWN", "WM_IME_KEYUP", NULL, NULL, NULL, NULL, NULL, NULL,
479 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
481 /* 0x02a0 */
482 NULL, "WM_MOUSEHOVER", NULL, "WM_MOUSELEAVE", NULL, NULL, NULL, NULL,
483 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,
487 /* 0x02c0 */
488 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
489 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
490 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
491 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
493 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
494 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
495 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
496 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
498 "WM_CUT", /* 0x0300 */
499 "WM_COPY",
500 "WM_PASTE",
501 "WM_CLEAR",
502 "WM_UNDO",
503 "WM_RENDERFORMAT",
504 "WM_RENDERALLFORMATS",
505 "WM_DESTROYCLIPBOARD",
506 "WM_DRAWCLIPBOARD",
507 "WM_PAINTCLIPBOARD",
508 "WM_VSCROLLCLIPBOARD",
509 "WM_SIZECLIPBOARD",
510 "WM_ASKCBFORMATNAME",
511 "WM_CHANGECBCHAIN",
512 "WM_HSCROLLCLIPBOARD",
513 "WM_QUERYNEWPALETTE", /* 0x030f*/
515 "WM_PALETTEISCHANGING",
516 "WM_PALETTECHANGED",
517 "WM_HOTKEY", /* 0x0312 */
518 NULL, NULL, NULL, NULL,
519 "WM_PRINT",
520 "WM_PRINTCLIENT",
521 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
523 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
524 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
525 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
526 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
528 /* 0x0340 */
529 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
530 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
531 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
532 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
534 "WM_QUERYAFXWNDPROC", /* 0x0360 */
535 "WM_SIZEPARENT", /* 0x0361 */
536 "WM_SETMESSAGESTRING", /* 0x0362 */
537 "WM_IDLEUPDATECMDUI", /* 0x0363 */
538 "WM_INITIALUPDATE", /* 0x0364 */
539 "WM_COMMANDHELP", /* 0x0365 */
540 "WM_HELPHITTEST", /* 0x0366 */
541 "WM_EXITHELPMODE", /* 0x0367 */
542 "WM_RECALCPARENT", /* 0x0368 */
543 "WM_SIZECHILD", /* 0x0369 */
544 "WM_KICKIDLE", /* 0x036A */
545 "WM_QUERYCENTERWND", /* 0x036B */
546 "WM_DISABLEMODAL", /* 0x036C */
547 "WM_FLOATSTATUS", /* 0x036D */
548 "WM_ACTIVATETOPLEVEL", /* 0x036E */
549 "WM_QUERY3DCONTROLS", /* 0x036F */
550 NULL,NULL,NULL,
551 "WM_SOCKET_NOTIFY", /* 0x0373 */
552 "WM_SOCKET_DEAD", /* 0x0374 */
553 "WM_POPMESSAGESTRING", /* 0x0375 */
554 "WM_OCC_LOADFROMSTREAM", /* 0x0376 */
555 "WM_OCC_LOADFROMSTORAGE", /* 0x0377 */
556 "WM_OCC_INITNEW", /* 0x0378 */
557 "WM_QUEUE_SENTINEL", /* 0x0379 */
558 "WM_OCC_LOADFROMSTREAM_EX", /* 0x037A */
559 "WM_OCC_LOADFROMSTORAGE_EX", /* 0x037B */
561 NULL,NULL,NULL,NULL,
563 "WM_PENWINFIRST", /* 0x0380 */
564 "WM_RCRESULT", /* 0x0381 */
565 "WM_HOOKRCRESULT", /* 0x0382 */
566 "WM_GLOBALRCCHANGE", /* 0x0383 */
567 "WM_SKB", /* 0x0384 */
568 "WM_HEDITCTL", /* 0x0385 */
569 NULL, NULL,
570 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
571 "WM_PENWINLAST", /* 0x038F */
573 "WM_COALESCE_FIRST", /* 0x0390 */
574 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
575 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
576 "WM_COALESCE_LAST", /* 0x039F */
578 /* 0x03a0 */
579 "MM_JOY1MOVE",
580 "MM_JOY2MOVE",
581 "MM_JOY1ZMOVE",
582 "MM_JOY2ZMOVE",
583 NULL, NULL, NULL, NULL,
584 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
586 /* 0x03b0 */
587 NULL, NULL, NULL, NULL, NULL,
588 "MM_JOY1BUTTONDOWN",
589 "MM_JOY2BUTTONDOWN",
590 "MM_JOY1BUTTONUP",
591 "MM_JOY2BUTTONUP",
592 "MM_MCINOTIFY",
593 NULL,
594 "MM_WOM_OPEN",
595 "MM_WOM_CLOSE",
596 "MM_WOM_DONE",
597 "MM_WIM_OPEN",
598 "MM_WIM_CLOSE",
600 /* 0x03c0 */
601 "MM_WIM_DATA",
602 "MM_MIM_OPEN",
603 "MM_MIM_CLOSE",
604 "MM_MIM_DATA",
605 "MM_MIM_LONGDATA",
606 "MM_MIM_ERROR",
607 "MM_MIM_LONGERROR",
608 "MM_MOM_OPEN",
609 "MM_MOM_CLOSE",
610 "MM_MOM_DONE",
611 NULL, NULL, NULL, NULL, NULL, NULL,
612 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
613 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
615 /* 0x03e0 */
616 "WM_DDE_INITIATE", /* 0x3E0 */
617 "WM_DDE_TERMINATE", /* 0x3E1 */
618 "WM_DDE_ADVISE", /* 0x3E2 */
619 "WM_DDE_UNADVISE", /* 0x3E3 */
620 "WM_DDE_ACK", /* 0x3E4 */
621 "WM_DDE_DATA", /* 0x3E5 */
622 "WM_DDE_REQUEST", /* 0x3E6 */
623 "WM_DDE_POKE", /* 0x3E7 */
624 "WM_DDE_EXECUTE", /* 0x3E8 */
625 NULL, NULL, NULL, NULL, NULL, NULL, NULL,
628 /* 0x03f0 */
629 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
630 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
632 "WM_USER" /* 0x0400 */
636 #define SPY_MAX_LVMMSGNUM 140
637 static const char * const LVMMessageTypeNames[SPY_MAX_LVMMSGNUM + 1] =
639 "LVM_GETBKCOLOR", /* 1000 */
640 "LVM_SETBKCOLOR",
641 "LVM_GETIMAGELIST",
642 "LVM_SETIMAGELIST",
643 "LVM_GETITEMCOUNT",
644 "LVM_GETITEMA",
645 "LVM_SETITEMA",
646 "LVM_INSERTITEMA",
647 "LVM_DELETEITEM",
648 "LVM_DELETEALLITEMS",
649 "LVM_GETCALLBACKMASK",
650 "LVM_SETCALLBACKMASK",
651 "LVM_GETNEXTITEM",
652 "LVM_FINDITEMA",
653 "LVM_GETITEMRECT",
654 "LVM_SETITEMPOSITION",
655 "LVM_GETITEMPOSITION",
656 "LVM_GETSTRINGWIDTHA",
657 "LVM_HITTEST",
658 "LVM_ENSUREVISIBLE",
659 "LVM_SCROLL",
660 "LVM_REDRAWITEMS",
661 "LVM_ARRANGE",
662 "LVM_EDITLABELA",
663 "LVM_GETEDITCONTROL",
664 "LVM_GETCOLUMNA",
665 "LVM_SETCOLUMNA",
666 "LVM_INSERTCOLUMNA",
667 "LVM_DELETECOLUMN",
668 "LVM_GETCOLUMNWIDTH",
669 "LVM_SETCOLUMNWIDTH",
670 "LVM_GETHEADER",
671 NULL,
672 "LVM_CREATEDRAGIMAGE",
673 "LVM_GETVIEWRECT",
674 "LVM_GETTEXTCOLOR",
675 "LVM_SETTEXTCOLOR",
676 "LVM_GETTEXTBKCOLOR",
677 "LVM_SETTEXTBKCOLOR",
678 "LVM_GETTOPINDEX",
679 "LVM_GETCOUNTPERPAGE",
680 "LVM_GETORIGIN",
681 "LVM_UPDATE",
682 "LVM_SETITEMSTATE",
683 "LVM_GETITEMSTATE",
684 "LVM_GETITEMTEXTA",
685 "LVM_SETITEMTEXTA",
686 "LVM_SETITEMCOUNT",
687 "LVM_SORTITEMS",
688 "LVM_SETITEMPOSITION32",
689 "LVM_GETSELECTEDCOUNT",
690 "LVM_GETITEMSPACING",
691 "LVM_GETISEARCHSTRINGA",
692 "LVM_SETICONSPACING",
693 "LVM_SETEXTENDEDLISTVIEWSTYLE",
694 "LVM_GETEXTENDEDLISTVIEWSTYLE",
695 "LVM_GETSUBITEMRECT",
696 "LVM_SUBITEMHITTEST",
697 "LVM_SETCOLUMNORDERARRAY",
698 "LVM_GETCOLUMNORDERARRAY",
699 "LVM_SETHOTITEM",
700 "LVM_GETHOTITEM",
701 "LVM_SETHOTCURSOR",
702 "LVM_GETHOTCURSOR",
703 "LVM_APPROXIMATEVIEWRECT",
704 "LVM_SETWORKAREAS",
705 "LVM_GETSELECTIONMARK",
706 "LVM_SETSELECTIONMARK",
707 "LVM_SETBKIMAGEA",
708 "LVM_GETBKIMAGEA",
709 "LVM_GETWORKAREAS",
710 "LVM_SETHOVERTIME",
711 "LVM_GETHOVERTIME",
712 "LVM_GETNUMBEROFWORKAREAS",
713 "LVM_SETTOOLTIPS",
714 "LVM_GETITEMW",
715 "LVM_SETITEMW",
716 "LVM_INSERTITEMW",
717 "LVM_GETTOOLTIPS",
718 NULL,
719 NULL,
720 NULL,
721 NULL,
722 "LVM_FINDITEMW",
723 NULL,
724 NULL,
725 NULL,
726 "LVM_GETSTRINGWIDTHW",
727 NULL,
728 NULL,
729 NULL,
730 NULL,
731 NULL,
732 NULL,
733 NULL,
734 "LVM_GETCOLUMNW",
735 "LVM_SETCOLUMNW",
736 "LVM_INSERTCOLUMNW",
737 NULL,
738 NULL,
739 NULL,
740 NULL,
741 NULL,
742 NULL,
743 NULL,
744 NULL,
745 NULL,
746 NULL,
747 NULL,
748 NULL,
749 NULL,
750 NULL,
751 NULL,
752 NULL,
753 NULL,
754 "LVM_GETITEMTEXTW",
755 "LVM_SETITEMTEXTW",
756 "LVM_GETISEARCHSTRINGW",
757 "LVM_EDITLABELW",
758 NULL,
759 NULL,
760 NULL,
761 NULL,
762 NULL,
763 NULL,
764 NULL,
765 NULL,
766 NULL,
767 NULL,
768 NULL,
769 NULL,
770 NULL,
771 NULL,
772 NULL,
773 NULL,
774 NULL,
775 NULL,
776 NULL,
777 NULL,
778 "LVM_SETBKIMAGEW",
779 "LVM_GETBKIMAGEW" /* 0x108B */
783 #define SPY_MAX_TVMSGNUM 65
784 static const char * const TVMessageTypeNames[SPY_MAX_TVMSGNUM + 1] =
786 "TVM_INSERTITEMA", /* 1100 */
787 "TVM_DELETEITEM",
788 "TVM_EXPAND",
789 NULL,
790 "TVM_GETITEMRECT",
791 "TVM_GETCOUNT",
792 "TVM_GETINDENT",
793 "TVM_SETINDENT",
794 "TVM_GETIMAGELIST",
795 "TVM_SETIMAGELIST",
796 "TVM_GETNEXTITEM",
797 "TVM_SELECTITEM",
798 "TVM_GETITEMA",
799 "TVM_SETITEMA",
800 "TVM_EDITLABELA",
801 "TVM_GETEDITCONTROL",
802 "TVM_GETVISIBLECOUNT",
803 "TVM_HITTEST",
804 "TVM_CREATEDRAGIMAGE",
805 "TVM_SORTCHILDREN",
806 "TVM_ENSUREVISIBLE",
807 "TVM_SORTCHILDRENCB",
808 "TVM_ENDEDITLABELNOW",
809 "TVM_GETISEARCHSTRINGA",
810 "TVM_SETTOOLTIPS",
811 "TVM_GETTOOLTIPS",
812 "TVM_SETINSERTMARK",
813 "TVM_SETITEMHEIGHT",
814 "TVM_GETITEMHEIGHT",
815 "TVM_SETBKCOLOR",
816 "TVM_SETTEXTCOLOR",
817 "TVM_GETBKCOLOR",
818 "TVM_GETTEXTCOLOR",
819 "TVM_SETSCROLLTIME",
820 "TVM_GETSCROLLTIME",
821 "TVM_UNKNOWN35",
822 "TVM_UNKNOWN36",
823 "TVM_SETINSERTMARKCOLOR",
824 "TVM_GETINSERTMARKCOLOR",
825 "TVM_GETITEMSTATE",
826 "TVM_SETLINECOLOR",
827 "TVM_GETLINECOLOR",
828 NULL,
829 NULL,
830 NULL,
831 NULL,
832 NULL,
833 NULL,
834 NULL,
835 NULL,
836 "TVM_INSERTITEMW",
837 NULL,
838 NULL,
839 NULL,
840 NULL,
841 NULL,
842 NULL,
843 NULL,
844 NULL,
845 NULL,
846 NULL,
847 NULL,
848 "TVM_GETITEMW",
849 "TVM_SETITEMW",
850 "TVM_GETISEARCHSTRINGW",
851 "TVM_EDITLABELW"
855 #define SPY_MAX_HDMMSGNUM 19
856 static const char * const HDMMessageTypeNames[SPY_MAX_HDMMSGNUM + 1] =
858 "HDM_GETITEMCOUNT", /* 1200 */
859 "HDM_INSERTITEMA",
860 "HDM_DELETEITEM",
861 "HDM_GETITEMA",
862 "HDM_SETITEMA",
863 "HDM_LAYOUT",
864 "HDM_HITTEST",
865 "HDM_GETITEMRECT",
866 "HDM_SETIMAGELIST",
867 "HDM_GETIMAGELIST",
868 "HDM_INSERTITEMW",
869 "HDM_GETITEMW",
870 "HDM_SETITEMW",
871 NULL,
872 NULL,
873 "HDM_ORDERTOINDEX",
874 "HDM_CREATEDRAGIMAGE",
875 "GETORDERARRAYINDEX",
876 "SETORDERARRAYINDEX",
877 "SETHOTDIVIDER"
881 #define SPY_MAX_TCMMSGNUM 62
882 static const char * const TCMMessageTypeNames[SPY_MAX_TCMMSGNUM + 1] =
884 NULL, /* 1300 */
885 NULL,
886 "TCM_SETIMAGELIST",
887 "TCM_GETIMAGELIST",
888 "TCM_GETITEMCOUNT",
889 "TCM_GETITEMA",
890 "TCM_SETITEMA",
891 "TCM_INSERTITEMA",
892 "TCM_DELETEITEM",
893 "TCM_DELETEALLITEMS",
894 "TCM_GETITEMRECT",
895 "TCM_GETCURSEL",
896 "TCM_SETCURSEL",
897 "TCM_HITTEST",
898 "TCM_SETITEMEXTRA",
899 NULL,
900 NULL,
901 NULL,
902 NULL,
903 NULL,
904 NULL,
905 NULL,
906 NULL,
907 NULL,
908 NULL,
909 NULL,
910 NULL,
911 NULL,
912 NULL,
913 NULL,
914 NULL,
915 NULL,
916 NULL,
917 NULL,
918 NULL,
919 NULL,
920 NULL,
921 NULL,
922 NULL,
923 NULL,
924 "TCM_ADJUSTRECT",
925 "TCM_SETITEMSIZE",
926 "TCM_REMOVEIMAGE",
927 "TCM_SETPADDING",
928 "TCM_GETROWCOUNT",
929 "TCM_GETTOOLTIPS",
930 "TCM_SETTOOLTIPS",
931 "TCM_GETCURFOCUS",
932 "TCM_SETCURFOCUS",
933 "TCM_SETMINTABWIDTH",
934 "TCM_DESELECTALL",
935 "TCM_HIGHLIGHTITEM",
936 "TCM_SETEXTENDEDSTYLE",
937 "TCM_GETEXTENDEDSTYLE",
938 NULL,
939 NULL,
940 NULL,
941 NULL,
942 NULL,
943 NULL,
944 "TCM_GETITEMW",
945 "TCM_SETITEMW",
946 "TCM_INSERTITEMW"
949 #define SPY_MAX_PGMMSGNUM 13
950 static const char * const PGMMessageTypeNames[SPY_MAX_PGMMSGNUM + 1] =
952 NULL, /* 1400 */
953 "PGM_SETCHILD",
954 "PGM_RECALCSIZE",
955 "PGM_FORWARDMOUSE",
956 "PGM_SETBKCOLOR",
957 "PGM_GETBKCOLOR",
958 "PGM_SETBORDER",
959 "PGM_GETBORDER",
960 "PGM_SETPOS",
961 "PGM_GETPOS",
962 "PGM_SETBUTTONSIZE",
963 "PGM_GETBUTTONSIZE",
964 "PGM_GETBUTTONSTATE",
965 "PGM_GETDROPTARGET"
969 #define SPY_MAX_CCMMSGNUM 9
970 static const char * const CCMMessageTypeNames[SPY_MAX_CCMMSGNUM + 1] =
972 NULL, /* 0x2000 */
973 "CCM_SETBKCOLOR",
974 "CCM_SETCOLORSCHEME",
975 "CCM_GETCOLORSCHEME",
976 "CCM_GETDROPTARGET",
977 "CCM_SETUNICODEFORMAT",
978 "CCM_GETUNICODEFORMAT",
979 "CCM_SETVERSION",
980 "CCM_GETVERSION",
981 "CCM_SETNOTIFYWINDOW"
984 #define SPY_MAX_WINEMSGNUM 6
985 static const char * const WINEMessageTypeNames[SPY_MAX_WINEMSGNUM + 1] =
987 "WM_WINE_DESTROYWINDOW",
988 "WM_WINE_SETWINDOWPOS",
989 "WM_WINE_SHOWWINDOW",
990 "WM_WINE_SETPARENT",
991 "WM_WINE_SETWINDOWLONG",
992 "WM_WINE_ENABLEWINDOW"
995 /* Virtual key names */
996 #define SPY_MAX_VKKEYSNUM 255
997 static const char * const VK_KeyNames[SPY_MAX_VKKEYSNUM + 1] =
999 NULL, /* 0x00 */
1000 "VK_LBUTTON", /* 0x01 */
1001 "VK_RBUTTON", /* 0x02 */
1002 "VK_CANCEL", /* 0x03 */
1003 "VK_MBUTTON", /* 0x04 */
1004 NULL, /* 0x05 */
1005 NULL, /* 0x06 */
1006 NULL, /* 0x07 */
1007 "VK_BACK", /* 0x08 */
1008 "VK_TAB", /* 0x09 */
1009 NULL, /* 0x0A */
1010 NULL, /* 0x0B */
1011 "VK_CLEAR", /* 0x0C */
1012 "VK_RETURN", /* 0x0D */
1013 NULL, /* 0x0E */
1014 NULL, /* 0x0F */
1015 "VK_SHIFT", /* 0x10 */
1016 "VK_CONTROL", /* 0x11 */
1017 "VK_MENU", /* 0x12 */
1018 "VK_PAUSE", /* 0x13 */
1019 "VK_CAPITAL", /* 0x14 */
1020 NULL, /* 0x15 */
1021 NULL, /* 0x16 */
1022 NULL, /* 0x17 */
1023 NULL, /* 0x18 */
1024 NULL, /* 0x19 */
1025 NULL, /* 0x1A */
1026 "VK_ESCAPE", /* 0x1B */
1027 NULL, /* 0x1C */
1028 NULL, /* 0x1D */
1029 NULL, /* 0x1E */
1030 NULL, /* 0x1F */
1031 "VK_SPACE", /* 0x20 */
1032 "VK_PRIOR", /* 0x21 */
1033 "VK_NEXT", /* 0x22 */
1034 "VK_END", /* 0x23 */
1035 "VK_HOME", /* 0x24 */
1036 "VK_LEFT", /* 0x25 */
1037 "VK_UP", /* 0x26 */
1038 "VK_RIGHT", /* 0x27 */
1039 "VK_DOWN", /* 0x28 */
1040 "VK_SELECT", /* 0x29 */
1041 "VK_PRINT", /* 0x2A */
1042 "VK_EXECUTE", /* 0x2B */
1043 "VK_SNAPSHOT", /* 0x2C */
1044 "VK_INSERT", /* 0x2D */
1045 "VK_DELETE", /* 0x2E */
1046 "VK_HELP", /* 0x2F */
1047 "VK_0", /* 0x30 */
1048 "VK_1", /* 0x31 */
1049 "VK_2", /* 0x32 */
1050 "VK_3", /* 0x33 */
1051 "VK_4", /* 0x34 */
1052 "VK_5", /* 0x35 */
1053 "VK_6", /* 0x36 */
1054 "VK_7", /* 0x37 */
1055 "VK_8", /* 0x38 */
1056 "VK_9", /* 0x39 */
1057 NULL, /* 0x3A */
1058 NULL, /* 0x3B */
1059 NULL, /* 0x3C */
1060 NULL, /* 0x3D */
1061 NULL, /* 0x3E */
1062 NULL, /* 0x3F */
1063 NULL, /* 0x40 */
1064 "VK_A", /* 0x41 */
1065 "VK_B", /* 0x42 */
1066 "VK_C", /* 0x43 */
1067 "VK_D", /* 0x44 */
1068 "VK_E", /* 0x45 */
1069 "VK_F", /* 0x46 */
1070 "VK_G", /* 0x47 */
1071 "VK_H", /* 0x48 */
1072 "VK_I", /* 0x49 */
1073 "VK_J", /* 0x4A */
1074 "VK_K", /* 0x4B */
1075 "VK_L", /* 0x4C */
1076 "VK_M", /* 0x4D */
1077 "VK_N", /* 0x4E */
1078 "VK_O", /* 0x4F */
1079 "VK_P", /* 0x50 */
1080 "VK_Q", /* 0x51 */
1081 "VK_R", /* 0x52 */
1082 "VK_S", /* 0x53 */
1083 "VK_T", /* 0x54 */
1084 "VK_U", /* 0x55 */
1085 "VK_V", /* 0x56 */
1086 "VK_W", /* 0x57 */
1087 "VK_X", /* 0x58 */
1088 "VK_Y", /* 0x59 */
1089 "VK_Z", /* 0x5A */
1090 "VK_LWIN", /* 0x5B */
1091 "VK_RWIN", /* 0x5C */
1092 "VK_APPS", /* 0x5D */
1093 NULL, /* 0x5E */
1094 NULL, /* 0x5F */
1095 "VK_NUMPAD0", /* 0x60 */
1096 "VK_NUMPAD1", /* 0x61 */
1097 "VK_NUMPAD2", /* 0x62 */
1098 "VK_NUMPAD3", /* 0x63 */
1099 "VK_NUMPAD4", /* 0x64 */
1100 "VK_NUMPAD5", /* 0x65 */
1101 "VK_NUMPAD6", /* 0x66 */
1102 "VK_NUMPAD7", /* 0x67 */
1103 "VK_NUMPAD8", /* 0x68 */
1104 "VK_NUMPAD9", /* 0x69 */
1105 "VK_MULTIPLY", /* 0x6A */
1106 "VK_ADD", /* 0x6B */
1107 "VK_SEPARATOR", /* 0x6C */
1108 "VK_SUBTRACT", /* 0x6D */
1109 "VK_DECIMAL", /* 0x6E */
1110 "VK_DIVIDE", /* 0x6F */
1111 "VK_F1", /* 0x70 */
1112 "VK_F2", /* 0x71 */
1113 "VK_F3", /* 0x72 */
1114 "VK_F4", /* 0x73 */
1115 "VK_F5", /* 0x74 */
1116 "VK_F6", /* 0x75 */
1117 "VK_F7", /* 0x76 */
1118 "VK_F8", /* 0x77 */
1119 "VK_F9", /* 0x78 */
1120 "VK_F10", /* 0x79 */
1121 "VK_F11", /* 0x7A */
1122 "VK_F12", /* 0x7B */
1123 "VK_F13", /* 0x7C */
1124 "VK_F14", /* 0x7D */
1125 "VK_F15", /* 0x7E */
1126 "VK_F16", /* 0x7F */
1127 "VK_F17", /* 0x80 */
1128 "VK_F18", /* 0x81 */
1129 "VK_F19", /* 0x82 */
1130 "VK_F20", /* 0x83 */
1131 "VK_F21", /* 0x84 */
1132 "VK_F22", /* 0x85 */
1133 "VK_F23", /* 0x86 */
1134 "VK_F24", /* 0x87 */
1135 NULL, /* 0x88 */
1136 NULL, /* 0x89 */
1137 NULL, /* 0x8A */
1138 NULL, /* 0x8B */
1139 NULL, /* 0x8C */
1140 NULL, /* 0x8D */
1141 NULL, /* 0x8E */
1142 NULL, /* 0x8F */
1143 "VK_NUMLOCK", /* 0x90 */
1144 "VK_SCROLL", /* 0x91 */
1145 NULL, /* 0x92 */
1146 NULL, /* 0x93 */
1147 NULL, /* 0x94 */
1148 NULL, /* 0x95 */
1149 NULL, /* 0x96 */
1150 NULL, /* 0x97 */
1151 NULL, /* 0x98 */
1152 NULL, /* 0x99 */
1153 NULL, /* 0x9A */
1154 NULL, /* 0x9B */
1155 NULL, /* 0x9C */
1156 NULL, /* 0x9D */
1157 NULL, /* 0x9E */
1158 NULL, /* 0x9F */
1159 "VK_LSHIFT", /* 0xA0 */
1160 "VK_RSHIFT", /* 0xA1 */
1161 "VK_LCONTROL", /* 0xA2 */
1162 "VK_RCONTROL", /* 0xA3 */
1163 "VK_LMENU", /* 0xA4 */
1164 "VK_RMENU", /* 0xA5 */
1165 NULL, /* 0xA6 */
1166 NULL, /* 0xA7 */
1167 NULL, /* 0xA8 */
1168 NULL, /* 0xA9 */
1169 NULL, /* 0xAA */
1170 NULL, /* 0xAB */
1171 NULL, /* 0xAC */
1172 NULL, /* 0xAD */
1173 NULL, /* 0xAE */
1174 NULL, /* 0xAF */
1175 NULL, /* 0xB0 */
1176 NULL, /* 0xB1 */
1177 NULL, /* 0xB2 */
1178 NULL, /* 0xB3 */
1179 NULL, /* 0xB4 */
1180 NULL, /* 0xB5 */
1181 NULL, /* 0xB6 */
1182 NULL, /* 0xB7 */
1183 NULL, /* 0xB8 */
1184 NULL, /* 0xB9 */
1185 "VK_OEM_1", /* 0xBA */
1186 "VK_OEM_PLUS", /* 0xBB */
1187 "VK_OEM_COMMA", /* 0xBC */
1188 "VK_OEM_MINUS", /* 0xBD */
1189 "VK_OEM_PERIOD", /* 0xBE */
1190 "VK_OEM_2", /* 0xBF */
1191 "VK_OEM_3", /* 0xC0 */
1192 NULL, /* 0xC1 */
1193 NULL, /* 0xC2 */
1194 NULL, /* 0xC3 */
1195 NULL, /* 0xC4 */
1196 NULL, /* 0xC5 */
1197 NULL, /* 0xC6 */
1198 NULL, /* 0xC7 */
1199 NULL, /* 0xC8 */
1200 NULL, /* 0xC9 */
1201 NULL, /* 0xCA */
1202 NULL, /* 0xCB */
1203 NULL, /* 0xCC */
1204 NULL, /* 0xCD */
1205 NULL, /* 0xCE */
1206 NULL, /* 0xCF */
1207 NULL, /* 0xD0 */
1208 NULL, /* 0xD1 */
1209 NULL, /* 0xD2 */
1210 NULL, /* 0xD3 */
1211 NULL, /* 0xD4 */
1212 NULL, /* 0xD5 */
1213 NULL, /* 0xD6 */
1214 NULL, /* 0xD7 */
1215 NULL, /* 0xD8 */
1216 NULL, /* 0xD9 */
1217 NULL, /* 0xDA */
1218 "VK_OEM_4", /* 0xDB */
1219 "VK_OEM_5", /* 0xDC */
1220 "VK_OEM_6", /* 0xDD */
1221 "VK_OEM_7", /* 0xDE */
1222 "VK_OEM_8", /* 0xDF */
1223 NULL, /* 0xE0 */
1224 "VK_OEM_AX", /* 0xE1 */
1225 "VK_OEM_102", /* 0xE2 */
1226 "VK_ICO_HELP", /* 0xE3 */
1227 "VK_ICO_00", /* 0xE4 */
1228 "VK_PROCESSKEY", /* 0xE5 */
1229 NULL, /* 0xE6 */
1230 NULL, /* 0xE7 */
1231 NULL, /* 0xE8 */
1232 NULL, /* 0xE9 */
1233 NULL, /* 0xEA */
1234 NULL, /* 0xEB */
1235 NULL, /* 0xEC */
1236 NULL, /* 0xED */
1237 NULL, /* 0xEE */
1238 NULL, /* 0xEF */
1239 NULL, /* 0xF0 */
1240 NULL, /* 0xF1 */
1241 NULL, /* 0xF2 */
1242 NULL, /* 0xF3 */
1243 NULL, /* 0xF4 */
1244 NULL, /* 0xF5 */
1245 "VK_ATTN", /* 0xF6 */
1246 "VK_CRSEL", /* 0xF7 */
1247 "VK_EXSEL", /* 0xF8 */
1248 "VK_EREOF", /* 0xF9 */
1249 "VK_PLAY", /* 0xFA */
1250 "VK_ZOOM", /* 0xFB */
1251 "VK_NONAME", /* 0xFC */
1252 "VK_PA1", /* 0xFD */
1253 "VK_OEM_CLEAR", /* 0xFE */
1254 NULL /* 0xFF */
1258 /************************************************************************/
1261 /* WM_USER+n message values for "common controls" */
1263 typedef struct
1265 const char *name; /* name of control message */
1266 UINT value; /* message number (0x0401-0x0fff */
1267 UINT len; /* length of space at lParam to dump */
1268 } USER_MSG;
1271 typedef struct
1273 const WCHAR *classname; /* class name to match */
1274 const USER_MSG *classmsg; /* pointer to first USER_MSG for class */
1275 USER_MSG *lastmsg; /* pointer to last USER_MSG for class */
1276 } CONTROL_CLASS;
1278 #define USM(a,b) { #a ,a,b}
1279 #define SZOF(a) sizeof(a)
1281 /* To dump memory at the lParam for any of these messages, */
1282 /* replace the "0" with a "SZOF(structure)", or with a */
1283 /* number. (First method prefered.) */
1285 static const USER_MSG rebar_array[] = {
1286 USM(RB_INSERTBANDA, 0),
1287 USM(RB_DELETEBAND, 0),
1288 USM(RB_GETBARINFO, 0),
1289 USM(RB_SETBARINFO, 0),
1290 USM(RB_GETBANDINFO, 0),
1291 USM(RB_SETBANDINFOA, 0),
1292 USM(RB_SETPARENT, 0),
1293 USM(RB_HITTEST, 0),
1294 USM(RB_GETRECT, 0),
1295 USM(RB_INSERTBANDW, 0),
1296 USM(RB_SETBANDINFOW, 0),
1297 USM(RB_GETBANDCOUNT, 0),
1298 USM(RB_GETROWCOUNT, 0),
1299 USM(RB_GETROWHEIGHT, 0),
1300 USM(RB_IDTOINDEX, 0),
1301 USM(RB_GETTOOLTIPS, 0),
1302 USM(RB_SETTOOLTIPS, 0),
1303 USM(RB_SETBKCOLOR, 0),
1304 USM(RB_GETBKCOLOR, 0),
1305 USM(RB_SETTEXTCOLOR, 0),
1306 USM(RB_GETTEXTCOLOR, 0),
1307 USM(RB_SIZETORECT, 0),
1308 USM(RB_BEGINDRAG, 0),
1309 USM(RB_ENDDRAG, 0),
1310 USM(RB_DRAGMOVE, 0),
1311 USM(RB_GETBARHEIGHT, 0),
1312 USM(RB_GETBANDINFOW, 0),
1313 USM(RB_GETBANDINFOA, 0),
1314 USM(RB_MINIMIZEBAND, 0),
1315 USM(RB_MAXIMIZEBAND, 0),
1316 USM(RB_GETBANDBORDERS, 0),
1317 USM(RB_SHOWBAND, 0),
1318 USM(RB_SETPALETTE, 0),
1319 USM(RB_GETPALETTE, 0),
1320 USM(RB_MOVEBAND, 0),
1321 {0,0,0} };
1323 static const USER_MSG toolbar_array[] = {
1324 USM(TB_ENABLEBUTTON ,0),
1325 USM(TB_CHECKBUTTON ,0),
1326 USM(TB_PRESSBUTTON ,0),
1327 USM(TB_HIDEBUTTON ,0),
1328 USM(TB_INDETERMINATE ,0),
1329 USM(TB_MARKBUTTON ,0),
1330 USM(TB_ISBUTTONENABLED ,0),
1331 USM(TB_ISBUTTONCHECKED ,0),
1332 USM(TB_ISBUTTONPRESSED ,0),
1333 USM(TB_ISBUTTONHIDDEN ,0),
1334 USM(TB_ISBUTTONINDETERMINATE ,0),
1335 USM(TB_ISBUTTONHIGHLIGHTED ,0),
1336 USM(TB_SETSTATE ,0),
1337 USM(TB_GETSTATE ,0),
1338 USM(TB_ADDBITMAP ,0),
1339 USM(TB_ADDBUTTONSA ,0),
1340 USM(TB_INSERTBUTTONA ,0),
1341 USM(TB_DELETEBUTTON ,0),
1342 USM(TB_GETBUTTON ,0),
1343 USM(TB_BUTTONCOUNT ,0),
1344 USM(TB_COMMANDTOINDEX ,0),
1345 USM(TB_SAVERESTOREA ,0),
1346 USM(TB_CUSTOMIZE ,0),
1347 USM(TB_ADDSTRINGA ,0),
1348 USM(TB_GETITEMRECT ,0),
1349 USM(TB_BUTTONSTRUCTSIZE ,0),
1350 USM(TB_SETBUTTONSIZE ,0),
1351 USM(TB_SETBITMAPSIZE ,0),
1352 USM(TB_AUTOSIZE ,0),
1353 USM(TB_GETTOOLTIPS ,0),
1354 USM(TB_SETTOOLTIPS ,0),
1355 USM(TB_SETPARENT ,0),
1356 USM(TB_SETROWS ,0),
1357 USM(TB_GETROWS ,0),
1358 USM(TB_GETBITMAPFLAGS ,0),
1359 USM(TB_SETCMDID ,0),
1360 USM(TB_CHANGEBITMAP ,0),
1361 USM(TB_GETBITMAP ,0),
1362 USM(TB_GETBUTTONTEXTA ,0),
1363 USM(TB_REPLACEBITMAP ,0),
1364 USM(TB_SETINDENT ,0),
1365 USM(TB_SETIMAGELIST ,0),
1366 USM(TB_GETIMAGELIST ,0),
1367 USM(TB_LOADIMAGES ,0),
1368 USM(TB_GETRECT ,0),
1369 USM(TB_SETHOTIMAGELIST ,0),
1370 USM(TB_GETHOTIMAGELIST ,0),
1371 USM(TB_SETDISABLEDIMAGELIST ,0),
1372 USM(TB_GETDISABLEDIMAGELIST ,0),
1373 USM(TB_SETSTYLE ,0),
1374 USM(TB_GETSTYLE ,0),
1375 USM(TB_GETBUTTONSIZE ,0),
1376 USM(TB_SETBUTTONWIDTH ,0),
1377 USM(TB_SETMAXTEXTROWS ,0),
1378 USM(TB_GETTEXTROWS ,0),
1379 USM(TB_GETOBJECT ,0),
1380 USM(TB_GETBUTTONINFOW ,0),
1381 USM(TB_SETBUTTONINFOW ,0),
1382 USM(TB_GETBUTTONINFOA ,0),
1383 USM(TB_SETBUTTONINFOA ,0),
1384 USM(TB_INSERTBUTTONW ,0),
1385 USM(TB_ADDBUTTONSW ,0),
1386 USM(TB_HITTEST ,0),
1387 USM(TB_SETDRAWTEXTFLAGS ,0),
1388 USM(TB_GETHOTITEM ,0),
1389 USM(TB_SETHOTITEM ,0),
1390 USM(TB_SETANCHORHIGHLIGHT ,0),
1391 USM(TB_GETANCHORHIGHLIGHT ,0),
1392 USM(TB_GETBUTTONTEXTW ,0),
1393 USM(TB_SAVERESTOREW ,0),
1394 USM(TB_ADDSTRINGW ,0),
1395 USM(TB_MAPACCELERATORA ,0),
1396 USM(TB_GETINSERTMARK ,0),
1397 USM(TB_SETINSERTMARK ,0),
1398 USM(TB_INSERTMARKHITTEST ,0),
1399 USM(TB_MOVEBUTTON ,0),
1400 USM(TB_GETMAXSIZE ,0),
1401 USM(TB_SETEXTENDEDSTYLE ,0),
1402 USM(TB_GETEXTENDEDSTYLE ,0),
1403 USM(TB_GETPADDING ,0),
1404 USM(TB_SETPADDING ,0),
1405 USM(TB_SETINSERTMARKCOLOR ,0),
1406 USM(TB_GETINSERTMARKCOLOR ,0),
1407 USM(TB_MAPACCELERATORW ,0),
1408 USM(TB_GETSTRINGW ,0),
1409 USM(TB_GETSTRINGA ,0),
1410 USM(TB_UNKWN45D ,8),
1411 USM(TB_UNKWN45E ,0),
1412 USM(TB_UNKWN460 ,0),
1413 USM(TB_UNKWN463 ,8),
1414 USM(TB_UNKWN464 ,0),
1415 {0,0,0} };
1417 static const USER_MSG tooltips_array[] = {
1418 USM(TTM_ACTIVATE ,0),
1419 USM(TTM_SETDELAYTIME ,0),
1420 USM(TTM_ADDTOOLA ,0),
1421 USM(TTM_DELTOOLA ,0),
1422 USM(TTM_NEWTOOLRECTA ,0),
1423 USM(TTM_RELAYEVENT ,0),
1424 USM(TTM_GETTOOLINFOA ,0),
1425 USM(TTM_HITTESTA ,0),
1426 USM(TTM_GETTEXTA ,0),
1427 USM(TTM_UPDATETIPTEXTA ,0),
1428 USM(TTM_GETTOOLCOUNT ,0),
1429 USM(TTM_ENUMTOOLSA ,0),
1430 USM(TTM_GETCURRENTTOOLA ,0),
1431 USM(TTM_WINDOWFROMPOINT ,0),
1432 USM(TTM_TRACKACTIVATE ,0),
1433 USM(TTM_TRACKPOSITION ,0),
1434 USM(TTM_SETTIPBKCOLOR ,0),
1435 USM(TTM_SETTIPTEXTCOLOR ,0),
1436 USM(TTM_GETDELAYTIME ,0),
1437 USM(TTM_GETTIPBKCOLOR ,0),
1438 USM(TTM_GETTIPTEXTCOLOR ,0),
1439 USM(TTM_SETMAXTIPWIDTH ,0),
1440 USM(TTM_GETMAXTIPWIDTH ,0),
1441 USM(TTM_SETMARGIN ,0),
1442 USM(TTM_GETMARGIN ,0),
1443 USM(TTM_POP ,0),
1444 USM(TTM_UPDATE ,0),
1445 USM(TTM_GETBUBBLESIZE ,0),
1446 USM(TTM_ADDTOOLW ,0),
1447 USM(TTM_DELTOOLW ,0),
1448 USM(TTM_NEWTOOLRECTW ,0),
1449 USM(TTM_GETTOOLINFOW ,0),
1450 USM(TTM_SETTOOLINFOW ,0),
1451 USM(TTM_HITTESTW ,0),
1452 USM(TTM_GETTEXTW ,0),
1453 USM(TTM_UPDATETIPTEXTW ,0),
1454 USM(TTM_ENUMTOOLSW ,0),
1455 USM(TTM_GETCURRENTTOOLW ,0),
1456 {0,0,0} };
1458 static const USER_MSG comboex_array[] = {
1459 USM(CBEM_INSERTITEMA ,0),
1460 USM(CBEM_SETIMAGELIST ,0),
1461 USM(CBEM_GETIMAGELIST ,0),
1462 USM(CBEM_GETITEMA ,0),
1463 USM(CBEM_SETITEMA ,0),
1464 USM(CBEM_GETCOMBOCONTROL ,0),
1465 USM(CBEM_GETEDITCONTROL ,0),
1466 USM(CBEM_SETEXSTYLE ,0),
1467 USM(CBEM_GETEXTENDEDSTYLE ,0),
1468 USM(CBEM_HASEDITCHANGED ,0),
1469 USM(CBEM_INSERTITEMW ,0),
1470 USM(CBEM_SETITEMW ,0),
1471 USM(CBEM_GETITEMW ,0),
1472 USM(CBEM_SETEXTENDEDSTYLE ,0),
1473 {0,0,0} };
1475 static const USER_MSG propsht_array[] = {
1476 USM(PSM_SETCURSEL ,0),
1477 USM(PSM_REMOVEPAGE ,0),
1478 USM(PSM_ADDPAGE ,0),
1479 USM(PSM_CHANGED ,0),
1480 USM(PSM_RESTARTWINDOWS ,0),
1481 USM(PSM_REBOOTSYSTEM ,0),
1482 USM(PSM_CANCELTOCLOSE ,0),
1483 USM(PSM_QUERYSIBLINGS ,0),
1484 USM(PSM_UNCHANGED ,0),
1485 USM(PSM_APPLY ,0),
1486 USM(PSM_SETTITLEA ,0),
1487 USM(PSM_SETWIZBUTTONS ,0),
1488 USM(PSM_PRESSBUTTON ,0),
1489 USM(PSM_SETCURSELID ,0),
1490 USM(PSM_SETFINISHTEXTA ,0),
1491 USM(PSM_GETTABCONTROL ,0),
1492 USM(PSM_ISDIALOGMESSAGE ,0),
1493 USM(PSM_GETCURRENTPAGEHWND ,0),
1494 USM(PSM_SETTITLEW ,0),
1495 USM(PSM_SETFINISHTEXTW ,0),
1496 {0,0,0} };
1497 const WCHAR PropSheetInfoStr[] =
1498 {'P','r','o','p','e','r','t','y','S','h','e','e','t','I','n','f','o',0 };
1500 static const USER_MSG updown_array[] = {
1501 USM(UDM_SETRANGE ,0),
1502 USM(UDM_GETRANGE ,0),
1503 USM(UDM_SETPOS ,0),
1504 USM(UDM_GETPOS ,0),
1505 USM(UDM_SETBUDDY ,0),
1506 USM(UDM_GETBUDDY ,0),
1507 USM(UDM_SETACCEL ,0),
1508 USM(UDM_GETACCEL ,0),
1509 USM(UDM_SETBASE ,0),
1510 USM(UDM_GETBASE ,0),
1511 USM(UDM_SETRANGE32 ,0),
1512 USM(UDM_GETRANGE32 ,0),
1513 USM(UDM_SETPOS32 ,0),
1514 USM(UDM_GETPOS32 ,0),
1515 {0,0,0} };
1517 #undef SZOF
1518 #undef USM
1520 static CONTROL_CLASS cc_array[] = {
1521 {WC_COMBOBOXEXW, comboex_array, 0},
1522 {WC_PROPSHEETW, propsht_array, 0},
1523 {REBARCLASSNAMEW, rebar_array, 0},
1524 {TOOLBARCLASSNAMEW, toolbar_array, 0},
1525 {TOOLTIPS_CLASSW, tooltips_array, 0},
1526 {UPDOWN_CLASSW, updown_array, 0},
1527 {0, 0, 0} };
1530 /************************************************************************/
1533 /* WM_NOTIFY function codes display */
1535 typedef struct
1537 const char *name; /* name of notify message */
1538 UINT value; /* notify code value */
1539 UINT len; /* length of extra space to dump */
1540 } SPY_NOTIFY;
1542 #define SPNFY(a,b) { #a ,a,sizeof(b)-sizeof(NMHDR)}
1544 /* Array MUST be in descending order by the 'value' field */
1545 /* (since value is UNSIGNED, 0xffffffff is largest and */
1546 /* 0xfffffffe is smaller). A binary search is used to */
1547 /* locate the correct 'value'. */
1548 static const SPY_NOTIFY spnfy_array[] = {
1549 /* common 0U to 0U-99U */
1550 SPNFY(NM_OUTOFMEMORY, NMHDR),
1551 SPNFY(NM_CLICK, NMHDR),
1552 SPNFY(NM_DBLCLK, NMHDR),
1553 SPNFY(NM_RETURN, NMHDR),
1554 SPNFY(NM_RCLICK, NMHDR),
1555 SPNFY(NM_RDBLCLK, NMHDR),
1556 SPNFY(NM_SETFOCUS, NMHDR),
1557 SPNFY(NM_KILLFOCUS, NMHDR),
1558 SPNFY(NM_CUSTOMDRAW, NMCUSTOMDRAW),
1559 SPNFY(NM_HOVER, NMHDR),
1560 SPNFY(NM_NCHITTEST, NMMOUSE),
1561 SPNFY(NM_KEYDOWN, NMKEY),
1562 SPNFY(NM_RELEASEDCAPTURE, NMHDR),
1563 SPNFY(NM_SETCURSOR, NMMOUSE),
1564 SPNFY(NM_CHAR, NMCHAR),
1565 SPNFY(NM_TOOLTIPSCREATED, NMTOOLTIPSCREATED),
1566 /* Listview 0U-100U to 0U-199U */
1567 SPNFY(LVN_ITEMCHANGING, NMLISTVIEW),
1568 SPNFY(LVN_ITEMCHANGED, NMLISTVIEW),
1569 SPNFY(LVN_INSERTITEM, NMLISTVIEW),
1570 SPNFY(LVN_DELETEITEM, NMLISTVIEW),
1571 SPNFY(LVN_DELETEALLITEMS, NMLISTVIEW),
1572 SPNFY(LVN_BEGINLABELEDITA, NMLVDISPINFOA),
1573 SPNFY(LVN_ENDLABELEDITA, NMLVDISPINFOA),
1574 SPNFY(LVN_COLUMNCLICK, NMLISTVIEW),
1575 SPNFY(LVN_BEGINDRAG, NMLISTVIEW),
1576 SPNFY(LVN_BEGINRDRAG, NMLISTVIEW),
1577 SPNFY(LVN_ODCACHEHINT, NMLVCACHEHINT),
1578 SPNFY(LVN_ITEMACTIVATE, NMITEMACTIVATE),
1579 SPNFY(LVN_ODSTATECHANGED, NMLVODSTATECHANGE),
1580 SPNFY(LVN_HOTTRACK, NMLISTVIEW),
1581 SPNFY(LVN_GETDISPINFOA, NMLVDISPINFOA),
1582 SPNFY(LVN_SETDISPINFOA, NMLVDISPINFOA),
1583 SPNFY(LVN_ODFINDITEMA, NMLVFINDITEMA),
1584 SPNFY(LVN_KEYDOWN, NMLVKEYDOWN),
1585 SPNFY(LVN_MARQUEEBEGIN, NMLISTVIEW),
1586 SPNFY(LVN_GETINFOTIPA, NMLVGETINFOTIPA),
1587 SPNFY(LVN_GETINFOTIPW, NMLVGETINFOTIPW),
1588 SPNFY(LVN_BEGINLABELEDITW, NMLVDISPINFOW),
1589 SPNFY(LVN_ENDLABELEDITW, NMLVDISPINFOW),
1590 SPNFY(LVN_GETDISPINFOW, NMLVDISPINFOW),
1591 SPNFY(LVN_SETDISPINFOW, NMLVDISPINFOW),
1592 SPNFY(LVN_ODFINDITEMW, NMLVFINDITEMW),
1593 /* PropertySheet 0U-200U to 0U-299U */
1594 SPNFY(PSN_SETACTIVE, PSHNOTIFY),
1595 SPNFY(PSN_KILLACTIVE, PSHNOTIFY),
1596 SPNFY(PSN_APPLY, PSHNOTIFY),
1597 SPNFY(PSN_RESET, PSHNOTIFY),
1598 SPNFY(PSN_HELP, PSHNOTIFY),
1599 SPNFY(PSN_WIZBACK, PSHNOTIFY),
1600 SPNFY(PSN_WIZNEXT, PSHNOTIFY),
1601 SPNFY(PSN_WIZFINISH, PSHNOTIFY),
1602 SPNFY(PSN_QUERYCANCEL, PSHNOTIFY),
1603 SPNFY(PSN_GETOBJECT, NMOBJECTNOTIFY),
1604 /* SPNFY(PSN_QUERYINITIALFOCUS, .PSHNOTIFY), NIY */
1605 /* SPNFY(PSN_TRANSLATEACCELERATOR, .PSHNOTIFY), NIY */
1606 /* Header 0U-300U to 0U-399U */
1607 SPNFY(HDN_ITEMCHANGINGA, NMHDR),
1608 SPNFY(HDN_ITEMCHANGEDA, NMHDR),
1609 SPNFY(HDN_ITEMCLICKA, NMHDR),
1610 SPNFY(HDN_ITEMDBLCLICKA, NMHDR),
1611 SPNFY(HDN_DIVIDERDBLCLICKA, NMHDR),
1612 SPNFY(HDN_BEGINTRACKA, NMHDR),
1613 SPNFY(HDN_ENDTRACKA, NMHDR),
1614 SPNFY(HDN_GETDISPINFOA, NMHDR),
1615 SPNFY(HDN_BEGINDRAG, NMHDR),
1616 SPNFY(HDN_ENDDRAG, NMHDR),
1617 SPNFY(HDN_ITEMCHANGINGW, NMHDR),
1618 SPNFY(HDN_ITEMCHANGEDW, NMHDR),
1619 SPNFY(HDN_ITEMCLICKW, NMHDR),
1620 SPNFY(HDN_ITEMDBLCLICKW, NMHDR),
1621 SPNFY(HDN_DIVIDERDBLCLICKW, NMHDR),
1622 SPNFY(HDN_BEGINTRACKW, NMHDR),
1623 SPNFY(HDN_ENDTRACKW, NMHDR),
1624 SPNFY(HDN_GETDISPINFOW, NMHDR),
1625 /* Treeview 0U-400U to 0U-499U */
1626 SPNFY(TVN_SELCHANGINGA, NMHDR),
1627 SPNFY(TVN_SELCHANGEDA, NMHDR),
1628 SPNFY(TVN_GETDISPINFOA, NMHDR),
1629 SPNFY(TVN_SETDISPINFOA, NMHDR),
1630 SPNFY(TVN_ITEMEXPANDINGA, NMHDR),
1631 SPNFY(TVN_ITEMEXPANDEDA, NMHDR),
1632 SPNFY(TVN_BEGINDRAGA, NMHDR),
1633 SPNFY(TVN_BEGINRDRAGA, NMHDR),
1634 SPNFY(TVN_DELETEITEMA, NMHDR),
1635 SPNFY(TVN_BEGINLABELEDITA, NMHDR),
1636 SPNFY(TVN_ENDLABELEDITA, NMHDR),
1637 SPNFY(TVN_KEYDOWN, NMHDR),
1638 SPNFY(TVN_SELCHANGINGW, NMHDR),
1639 SPNFY(TVN_SELCHANGEDW, NMHDR),
1640 SPNFY(TVN_GETDISPINFOW, NMHDR),
1641 SPNFY(TVN_SETDISPINFOW, NMHDR),
1642 SPNFY(TVN_ITEMEXPANDINGW, NMHDR),
1643 SPNFY(TVN_ITEMEXPANDEDW, NMHDR),
1644 SPNFY(TVN_BEGINDRAGW, NMHDR),
1645 SPNFY(TVN_BEGINRDRAGW, NMHDR),
1646 SPNFY(TVN_DELETEITEMW, NMHDR),
1647 SPNFY(TVN_BEGINLABELEDITW, NMHDR),
1648 SPNFY(TVN_ENDLABELEDITW, NMHDR),
1649 /* Tooltips 0U-520U to 0U-549U */
1650 SPNFY(TTN_GETDISPINFOA, NMHDR),
1651 SPNFY(TTN_SHOW, NMHDR),
1652 SPNFY(TTN_POP, NMHDR),
1653 SPNFY(TTN_GETDISPINFOW, NMHDR),
1654 /* Tab 0U-550U to 0U-580U */
1655 SPNFY(TCN_KEYDOWN, NMHDR),
1656 SPNFY(TCN_SELCHANGE, NMHDR),
1657 SPNFY(TCN_SELCHANGING, NMHDR),
1658 SPNFY(TCN_GETOBJECT, NMHDR),
1659 /* Common Dialog 0U-601U to 0U-699U */
1660 /* Toolbar 0U-700U to 0U-720U */
1661 SPNFY(TBN_GETBUTTONINFOA, NMTOOLBARA),
1662 SPNFY(TBN_BEGINDRAG, NMTOOLBARA),
1663 SPNFY(TBN_ENDDRAG, NMTOOLBARA),
1664 SPNFY(TBN_BEGINADJUST, NMHDR),
1665 SPNFY(TBN_ENDADJUST, NMHDR),
1666 SPNFY(TBN_RESET, NMHDR),
1667 SPNFY(TBN_QUERYINSERT, NMTOOLBARA),
1668 SPNFY(TBN_QUERYDELETE, NMTOOLBARA),
1669 SPNFY(TBN_TOOLBARCHANGE, NMHDR),
1670 SPNFY(TBN_CUSTHELP, NMHDR),
1671 SPNFY(TBN_DROPDOWN, NMTOOLBARA),
1672 SPNFY(TBN_GETOBJECT, NMOBJECTNOTIFY),
1673 SPNFY(TBN_HOTITEMCHANGE, NMTBHOTITEM),
1674 SPNFY(TBN_DRAGOUT, NMTOOLBARA),
1675 SPNFY(TBN_DELETINGBUTTON, NMTOOLBARA),
1676 SPNFY(TBN_GETDISPINFOA, NMTBDISPINFOA),
1677 SPNFY(TBN_GETDISPINFOW, NMTBDISPINFOW),
1678 SPNFY(TBN_GETINFOTIPA, NMTBGETINFOTIPA),
1679 SPNFY(TBN_GETINFOTIPW, NMTBGETINFOTIPW),
1680 SPNFY(TBN_GETBUTTONINFOW, NMTOOLBARW),
1681 /* Up/Down 0U-721U to 0U-740U */
1682 SPNFY(UDN_DELTAPOS, NMHDR),
1683 /* Month Calendar 0U-750U to 0U-759U */
1684 /* ******************* WARNING ***************************** */
1685 /* The following appear backwards but needs to be this way. */
1686 /* The reason is that MS (and us) define the MCNs as */
1687 /* MCN_FIRST + n */
1688 /* instead of the way ALL other notifications are */
1689 /* TBN_FIRST - n */
1690 /* The only place that this is important is in this list */
1691 /* */
1692 /* Also since the same error was made with the DTN_ items, */
1693 /* they overlay the MCN_ and need to be inserted in the */
1694 /* other section of the table so that it is in order for */
1695 /* the binary search. */
1696 /* */
1697 /* Thank you MS for your obvious quality control!! */
1698 /* ******************* WARNING ***************************** */
1699 /* Date/Time 0U-760U to 0U-799U */
1700 /* SPNFY(MCN_SELECT, NMHDR), */
1701 /* SPNFY(MCN_GETDAYSTATE, NMHDR), */
1702 /* SPNFY(MCN_SELCHANGE, NMHDR), */
1703 /* ******************* WARNING ***************************** */
1704 /* The following appear backwards but needs to be this way. */
1705 /* The reason is that MS (and us) define the MCNs as */
1706 /* DTN_FIRST + n */
1707 /* instead of the way ALL other notifications are */
1708 /* TBN_FIRST - n */
1709 /* The only place that this is important is in this list */
1710 /* ******************* WARNING ***************************** */
1711 SPNFY(DTN_FORMATQUERYW, NMHDR),
1712 SPNFY(DTN_FORMATW, NMHDR),
1713 SPNFY(DTN_WMKEYDOWNW, NMHDR),
1714 SPNFY(DTN_USERSTRINGW, NMHDR),
1715 SPNFY(MCN_SELECT, NMHDR),
1716 SPNFY(MCN_GETDAYSTATE, NMHDR),
1717 SPNFY(MCN_SELCHANGE, NMHDR),
1718 SPNFY(DTN_CLOSEUP, NMHDR),
1719 SPNFY(DTN_DROPDOWN, NMHDR),
1720 SPNFY(DTN_FORMATQUERYA, NMHDR),
1721 SPNFY(DTN_FORMATA, NMHDR),
1722 SPNFY(DTN_WMKEYDOWNA, NMHDR),
1723 SPNFY(DTN_USERSTRINGA, NMHDR),
1724 SPNFY(DTN_DATETIMECHANGE, NMHDR),
1725 /* ComboBoxEx 0U-800U to 0U-830U */
1726 SPNFY(CBEN_GETDISPINFOA, NMCOMBOBOXEXA),
1727 SPNFY(CBEN_INSERTITEM, NMCOMBOBOXEXA),
1728 SPNFY(CBEN_DELETEITEM, NMCOMBOBOXEXA),
1729 SPNFY(CBEN_BEGINEDIT, NMHDR),
1730 SPNFY(CBEN_ENDEDITA, NMCBEENDEDITA),
1731 SPNFY(CBEN_ENDEDITW, NMCBEENDEDITW),
1732 SPNFY(CBEN_GETDISPINFOW, NMCOMBOBOXEXW),
1733 SPNFY(CBEN_DRAGBEGINA, NMCBEDRAGBEGINA),
1734 SPNFY(CBEN_DRAGBEGINW, NMCBEDRAGBEGINW),
1735 /* Rebar 0U-831U to 0U-859U */
1736 SPNFY(RBN_HEIGHTCHANGE, NMHDR),
1737 SPNFY(RBN_GETOBJECT, NMOBJECTNOTIFY),
1738 SPNFY(RBN_LAYOUTCHANGED, NMHDR),
1739 SPNFY(RBN_AUTOSIZE, NMRBAUTOSIZE),
1740 SPNFY(RBN_BEGINDRAG, NMREBAR),
1741 SPNFY(RBN_ENDDRAG, NMREBAR),
1742 SPNFY(RBN_DELETINGBAND, NMREBAR),
1743 SPNFY(RBN_DELETEDBAND, NMREBAR),
1744 SPNFY(RBN_CHILDSIZE, NMREBARCHILDSIZE),
1745 /* IP Adderss 0U-860U to 0U-879U */
1746 SPNFY(IPN_FIELDCHANGED, NMHDR),
1747 /* Status bar 0U-880U to 0U-899U */
1748 SPNFY(SBN_SIMPLEMODECHANGE, NMHDR),
1749 /* Pager 0U-900U to 0U-950U */
1750 SPNFY(PGN_SCROLL, NMPGSCROLL),
1751 SPNFY(PGN_CALCSIZE, NMPGCALCSIZE),
1752 {0,0,0}};
1753 static const SPY_NOTIFY *end_spnfy_array; /* ptr to last good entry in array */
1754 #undef SPNFY
1757 static BOOL16 SPY_Exclude[SPY_MAX_MSGNUM+1];
1758 static BOOL16 SPY_ExcludeDWP = 0;
1760 #define SPY_EXCLUDE(msg) \
1761 (SPY_Exclude[(msg) > SPY_MAX_MSGNUM ? SPY_MAX_MSGNUM : (msg)])
1764 typedef struct
1766 UINT msgnum; /* message number */
1767 HWND msg_hwnd; /* window handle for message */
1768 WPARAM wParam; /* message parameter */
1769 LPARAM lParam; /* message parameter */
1770 INT data_len; /* length of data to dump */
1771 char msg_name[60]; /* message name (see SPY_GetMsgName) */
1772 WCHAR wnd_class[60]; /* window class name (full) */
1773 WCHAR wnd_name[16]; /* window name for message */
1774 } SPY_INSTANCE;
1776 /* This is defined so that the external entry point can return the addr */
1777 static SPY_INSTANCE ext_sp_e;
1779 static int indent_tls_index;
1781 /***********************************************************************
1782 * get_indent_level
1784 inline static int get_indent_level(void)
1786 return (int)TlsGetValue( indent_tls_index );
1790 /***********************************************************************
1791 * set_indent_level
1793 inline static void set_indent_level( int level )
1795 TlsSetValue( indent_tls_index, (void *)level );
1799 /***********************************************************************
1800 * SPY_GetMsgInternal
1802 static const char *SPY_GetMsgInternal( UINT msg )
1804 if (msg <= SPY_MAX_MSGNUM)
1806 if (!MessageTypeNames[msg]) return "???";
1807 return MessageTypeNames[msg];
1810 if (msg >= LVM_FIRST && msg <= LVM_FIRST + SPY_MAX_LVMMSGNUM)
1812 if (!LVMMessageTypeNames[msg-LVM_FIRST]) return "LVM_?";
1813 return LVMMessageTypeNames[msg-LVM_FIRST];
1816 if (msg >= TV_FIRST && msg <= TV_FIRST + SPY_MAX_TVMSGNUM)
1818 if (!TVMessageTypeNames[msg-TV_FIRST]) return "TV_?";
1819 return TVMessageTypeNames[msg-TV_FIRST];
1822 if (msg >= HDM_FIRST && msg <= HDM_FIRST + SPY_MAX_HDMMSGNUM)
1824 if (!HDMMessageTypeNames[msg-HDM_FIRST]) return "HDM_?";
1825 return HDMMessageTypeNames[msg-HDM_FIRST];
1828 if (msg >= TCM_FIRST && msg <= TCM_FIRST + SPY_MAX_TCMMSGNUM)
1830 if (!TCMMessageTypeNames[msg-TCM_FIRST]) return "TCM_?";
1831 return TCMMessageTypeNames[msg-TCM_FIRST];
1834 if (msg >= PGM_FIRST && msg <= PGM_FIRST + SPY_MAX_PGMMSGNUM)
1836 if (!PGMMessageTypeNames[msg-PGM_FIRST]) return "PGM_?";
1837 return PGMMessageTypeNames[msg-PGM_FIRST];
1840 if (msg >= CCM_FIRST && msg <= CCM_FIRST + SPY_MAX_CCMMSGNUM)
1842 if (!CCMMessageTypeNames[msg-CCM_FIRST]) return "???";
1843 return CCMMessageTypeNames[msg-CCM_FIRST];
1846 if (msg >= WM_WINE_DESTROYWINDOW && msg <= WM_WINE_DESTROYWINDOW + SPY_MAX_WINEMSGNUM)
1848 if (!WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW]) return "???";
1849 return WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW];
1851 return "";
1854 /***********************************************************************
1855 * SPY_Bsearch_Msg
1857 const USER_MSG *SPY_Bsearch_Msg( const USER_MSG *first, const USER_MSG *last, UINT code)
1859 INT count;
1860 const USER_MSG *test;
1862 while (last >= first) {
1863 count = 1 + last - first;
1864 if (count < 3) {
1865 #if DEBUG_SPY
1866 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
1867 code, first->value, first->name, last->value, last->name, last->len);
1868 #endif
1869 if (first->value == code) return first;
1870 if (last->value == code) return last;
1871 return NULL;
1873 count = count / 2;
1874 test = first + count;
1875 #if DEBUG_SPY
1876 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
1877 first, last, test, test->value, code, count);
1878 #endif
1879 if (test->value == code) return test;
1880 if (test->value > code)
1881 last = test - 1;
1882 else
1883 first = test + 1;
1885 return NULL;
1888 /***********************************************************************
1889 * SPY_GetMsgStuff
1891 * Get message name and other information for dumping
1893 static void SPY_GetMsgStuff( SPY_INSTANCE *sp_e )
1895 const USER_MSG *p;
1897 sp_e->msg_name[sizeof(sp_e->msg_name)-1] = 0;
1898 strncpy (sp_e->msg_name, SPY_GetMsgInternal( sp_e->msgnum ),
1899 sizeof(sp_e->msg_name)-1);
1901 sp_e->data_len = 0;
1902 if (!sp_e->msg_name[0])
1904 INT i = 0;
1906 if (sp_e->msgnum >= 0xc000)
1908 if (GlobalGetAtomNameA( sp_e->msgnum, sp_e->msg_name+1, sizeof(sp_e->msg_name)-2 ))
1910 sp_e->msg_name[0] = '\"';
1911 strcat( sp_e->msg_name, "\"" );
1912 return;
1915 #if DEBUG_SPY
1916 TRACE("looking class %s\n", sp_e->wnd_class);
1917 #endif
1919 while (cc_array[i].classname &&
1920 strcmpW(cc_array[i].classname, sp_e->wnd_class) !=0) i++;
1922 if (cc_array[i].classname)
1924 #if DEBUG_SPY
1925 TRACE("process class %s, first %p, last %p\n",
1926 debugstr_w(cc_array[i].classname), cc_array[i].classmsg,
1927 cc_array[i].lastmsg);
1928 #endif
1929 p = SPY_Bsearch_Msg (cc_array[i].classmsg, cc_array[i].lastmsg,
1930 sp_e->msgnum);
1931 if (p) {
1932 strncpy (sp_e->msg_name, p->name, sizeof(sp_e->msg_name)-1);
1933 sp_e->data_len = p->len;
1934 return;
1937 sprintf( sp_e->msg_name, "WM_USER+%04x", sp_e->msgnum - WM_USER );
1941 /***********************************************************************
1942 * SPY_GetWndName
1944 * Sets the value of "wnd_name" and "wnd_class" members of the
1945 * instance structure.
1948 void SPY_GetWndName( SPY_INSTANCE *sp_e )
1950 DWORD save_error;
1951 INT len;
1953 /* save and restore error code over the next call */
1954 save_error = GetLastError();
1955 /* special code to detect a property sheet dialog */
1956 if ((GetClassLongW(sp_e->msg_hwnd, GCW_ATOM) == (LONG)WC_DIALOGW) &&
1957 (GetPropW(sp_e->msg_hwnd, PropSheetInfoStr))) {
1958 strcpyW(sp_e->wnd_class, WC_PROPSHEETW);
1960 else {
1961 GetClassNameW(sp_e->msg_hwnd, sp_e->wnd_class, sizeof(sp_e->wnd_class)/sizeof(WCHAR));
1963 SetLastError(save_error);
1965 len = InternalGetWindowText(sp_e->msg_hwnd, sp_e->wnd_name, sizeof(sp_e->wnd_name)/sizeof(WCHAR));
1966 if(!len) /* get class name */
1968 LPWSTR dst = sp_e->wnd_name;
1969 LPWSTR src = sp_e->wnd_class;
1970 int n = sizeof(sp_e->wnd_name)/sizeof(WCHAR) - 3;
1971 *dst++ = '{';
1972 while ((n-- > 0) && *src) *dst++ = *src++;
1973 *dst++ = '}';
1974 *dst = 0;
1978 /***********************************************************************
1979 * SPY_GetMsgName
1981 * **** External function ****
1983 * Get message name
1985 const char *SPY_GetMsgName( UINT msg, HWND hWnd )
1987 ext_sp_e.msgnum = msg;
1988 ext_sp_e.msg_hwnd = hWnd;
1989 ext_sp_e.lParam = 0;
1990 ext_sp_e.wParam = 0;
1991 SPY_GetWndName(&ext_sp_e);
1992 SPY_GetMsgStuff(&ext_sp_e);
1993 return ext_sp_e.msg_name;
1996 /***********************************************************************
1997 * SPY_GetVKeyName
1999 const char *SPY_GetVKeyName(WPARAM wParam)
2001 const char *vk_key_name;
2003 if(wParam <= SPY_MAX_VKKEYSNUM && VK_KeyNames[wParam])
2004 vk_key_name = VK_KeyNames[wParam];
2005 else
2006 vk_key_name = "VK_???";
2008 return vk_key_name;
2011 /***********************************************************************
2012 * SPY_Bsearch_Notify
2014 const SPY_NOTIFY *SPY_Bsearch_Notify( const SPY_NOTIFY *first, const SPY_NOTIFY *last, UINT code)
2016 INT count;
2017 const SPY_NOTIFY *test;
2019 while (last >= first) {
2020 count = 1 + last - first;
2021 if (count < 3) {
2022 #if DEBUG_SPY
2023 TRACE("code=%d, f-value=%d, f-name=%s, l-value=%d, l-name=%s, l-len=%d,\n",
2024 code, first->value, first->name, last->value, last->name, last->len);
2025 #endif
2026 if (first->value == code) return first;
2027 if (last->value == code) return last;
2028 return NULL;
2030 count = count / 2;
2031 test = first + count;
2032 #if DEBUG_SPY
2033 TRACE("first=%p, last=%p, test=%p, t-value=%d, code=%d, count=%d\n",
2034 first, last, test, test->value, code, count);
2035 #endif
2036 if (test->value == code) return test;
2037 if (test->value < code)
2038 last = test - 1;
2039 else
2040 first = test + 1;
2042 return NULL;
2045 /***********************************************************************
2046 * SPY_DumpMem
2048 void SPY_DumpMem (LPCSTR header, UINT *q, INT len)
2050 int i;
2052 for(i=0; i<len-12; i+=16) {
2053 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2054 header, i, *q, *(q+1), *(q+2), *(q+3));
2055 q += 4;
2057 switch ((len - i + 3) & (~3)) {
2058 case 16:
2059 TRACE("%s [%04x] %08x %08x %08x %08x\n",
2060 header, i, *q, *(q+1), *(q+2), *(q+3));
2061 break;
2062 case 12:
2063 TRACE("%s [%04x] %08x %08x %08x\n",
2064 header, i, *q, *(q+1), *(q+2));
2065 break;
2066 case 8:
2067 TRACE("%s [%04x] %08x %08x\n",
2068 header, i, *q, *(q+1));
2069 break;
2070 case 4:
2071 TRACE("%s [%04x] %08x\n",
2072 header, i, *q);
2073 break;
2074 default:
2075 break;
2079 /***********************************************************************
2080 * SPY_DumpStructure
2082 void SPY_DumpStructure (SPY_INSTANCE *sp_e, BOOL enter)
2084 switch (sp_e->msgnum)
2086 case LVM_INSERTITEMW:
2087 case LVM_INSERTITEMA:
2088 case LVM_SETITEMW:
2089 case LVM_SETITEMA:
2090 if (!enter) break;
2091 /* fall through */
2092 case LVM_GETITEMW:
2093 case LVM_GETITEMA:
2095 LPLVITEMA item = (LPLVITEMA) sp_e->lParam;
2096 if (item) {
2097 SPY_DumpMem ("LVITEM", (UINT*)item, sizeof(LVITEMA));
2099 break;
2101 case TCM_INSERTITEMW:
2102 case TCM_INSERTITEMA:
2103 case TCM_SETITEMW:
2104 case TCM_SETITEMA:
2105 if (!enter) break;
2106 /* fall through */
2107 case TCM_GETITEMW:
2108 case TCM_GETITEMA:
2110 TCITEMA *item = (TCITEMA *) sp_e->lParam;
2111 if (item) {
2112 SPY_DumpMem ("TCITEM", (UINT*)item, sizeof(TCITEMA));
2114 break;
2116 case TCM_ADJUSTRECT:
2117 case LVM_GETITEMRECT:
2118 case LVM_GETSUBITEMRECT:
2120 LPRECT rc = (LPRECT) sp_e->lParam;
2121 if (rc) {
2122 TRACE("lParam rect (%ld,%ld)-(%ld,%ld)\n",
2123 rc->left, rc->top, rc->right, rc->bottom);
2125 break;
2127 case LVM_SETITEMPOSITION32:
2128 if (!enter) break;
2129 /* fall through */
2130 case LVM_GETITEMPOSITION:
2131 case LVM_GETORIGIN:
2133 LPPOINT point = (LPPOINT) sp_e->lParam;
2134 if (point) {
2135 TRACE("lParam point x=%ld, y=%ld\n", point->x, point->y);
2137 break;
2139 case SBM_SETRANGE:
2140 if (!enter && (sp_e->msgnum == SBM_SETRANGE)) break;
2141 TRACE("min=%d max=%d\n", (INT)sp_e->wParam, (INT)sp_e->lParam);
2142 break;
2143 case SBM_GETRANGE:
2144 if ((enter && (sp_e->msgnum == SBM_GETRANGE)) ||
2145 (!enter && (sp_e->msgnum == SBM_SETRANGE))) break;
2147 LPINT ptmin = (LPINT) sp_e->wParam;
2148 LPINT ptmax = (LPINT) sp_e->lParam;
2149 if (ptmin && ptmax)
2150 TRACE("min=%d max=%d\n", *ptmin, *ptmax);
2151 else if (ptmin)
2152 TRACE("min=%d max=n/a\n", *ptmin);
2153 else if (ptmax)
2154 TRACE("min=n/a max=%d\n", *ptmax);
2155 break;
2157 case WM_DRAWITEM:
2158 if (!enter) break;
2160 DRAWITEMSTRUCT *lpdis = (DRAWITEMSTRUCT*) sp_e->lParam;
2161 TRACE("DRAWITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2162 lpdis->CtlType, lpdis->CtlID);
2163 TRACE("itemID=0x%08x itemAction=0x%08x itemState=0x%08x\n",
2164 lpdis->itemID, lpdis->itemAction, lpdis->itemState);
2165 TRACE("hWnd=%p hDC=%p (%ld,%ld)-(%ld,%ld) itemData=0x%08lx\n",
2166 lpdis->hwndItem, lpdis->hDC, lpdis->rcItem.left,
2167 lpdis->rcItem.top, lpdis->rcItem.right,
2168 lpdis->rcItem.bottom, lpdis->itemData);
2170 break;
2171 case WM_MEASUREITEM:
2173 MEASUREITEMSTRUCT *lpmis = (MEASUREITEMSTRUCT*) sp_e->lParam;
2174 TRACE("MEASUREITEMSTRUCT: CtlType=0x%08x CtlID=0x%08x\n",
2175 lpmis->CtlType, lpmis->CtlID);
2176 TRACE("itemID=0x%08x itemWidth=0x%08x itemHeight=0x%08x\n",
2177 lpmis->itemID, lpmis->itemWidth, lpmis->itemHeight);
2178 TRACE("itemData=0x%08lx\n", lpmis->itemData);
2180 break;
2181 case WM_WINDOWPOSCHANGED:
2182 if (!enter) break;
2183 case WM_WINDOWPOSCHANGING:
2185 WINDOWPOS *lpwp = (WINDOWPOS *)sp_e->lParam;
2186 TRACE("WINDOWPOS hwnd=%p, after=%p, at (%d,%d) w=%d h=%d, flags=0x%08x\n",
2187 lpwp->hwnd, lpwp->hwndInsertAfter, lpwp->x, lpwp->y,
2188 lpwp->cx, lpwp->cy, lpwp->flags);
2190 break;
2191 case WM_STYLECHANGED:
2192 if (!enter) break;
2193 case WM_STYLECHANGING:
2195 LPSTYLESTRUCT ss = (LPSTYLESTRUCT) sp_e->lParam;
2196 TRACE("STYLESTRUCT: StyleOld=0x%08lx, StyleNew=0x%08lx\n",
2197 ss->styleOld, ss->styleNew);
2199 break;
2200 case WM_NCCALCSIZE:
2202 RECT *rc = (RECT *)sp_e->lParam;
2203 TRACE("Rect (%ld,%ld)-(%ld,%ld)\n",
2204 rc->left, rc->top, rc->right, rc->bottom);
2206 break;
2207 case WM_NOTIFY:
2208 /* if (!enter) break; */
2210 NMHDR * pnmh = (NMHDR*) sp_e->lParam;
2211 UINT *q, dumplen;
2212 const SPY_NOTIFY *p;
2213 WCHAR from_class[60];
2214 DWORD save_error;
2216 p = SPY_Bsearch_Notify (&spnfy_array[0], end_spnfy_array,
2217 pnmh->code);
2218 if (p) {
2219 TRACE("NMHDR hwndFrom=%p idFrom=0x%08x code=%s<0x%08x>, extra=0x%x\n",
2220 pnmh->hwndFrom, pnmh->idFrom, p->name, pnmh->code, p->len);
2221 dumplen = p->len;
2223 /* for CUSTOMDRAW, dump all the data for TOOLBARs */
2224 if (pnmh->code == NM_CUSTOMDRAW) {
2225 /* save and restore error code over the next call */
2226 save_error = GetLastError();
2227 GetClassNameW(pnmh->hwndFrom, from_class,
2228 sizeof(from_class)/sizeof(WCHAR));
2229 SetLastError(save_error);
2230 if (strcmpW(TOOLBARCLASSNAMEW, from_class) == 0)
2231 dumplen = sizeof(NMTBCUSTOMDRAW)-sizeof(NMHDR);
2233 if (dumplen > 0) {
2234 q = (UINT *)(pnmh + 1);
2235 SPY_DumpMem ("NM extra", q, (INT)dumplen);
2238 else
2239 TRACE("NMHDR hwndFrom=%p idFrom=0x%08x code=0x%08x\n",
2240 pnmh->hwndFrom, pnmh->idFrom, pnmh->code);
2242 default:
2243 if (sp_e->data_len > 0)
2244 SPY_DumpMem ("MSG lParam", (UINT *)sp_e->lParam, sp_e->data_len);
2245 break;
2249 /***********************************************************************
2250 * SPY_EnterMessage
2252 void SPY_EnterMessage( INT iFlag, HWND hWnd, UINT msg,
2253 WPARAM wParam, LPARAM lParam )
2255 SPY_INSTANCE sp_e;
2256 int indent;
2258 if (!TRACE_ON(message) || SPY_EXCLUDE(msg)) return;
2260 sp_e.msgnum = msg;
2261 sp_e.msg_hwnd = hWnd;
2262 sp_e.lParam = lParam;
2263 sp_e.wParam = wParam;
2264 SPY_GetWndName(&sp_e);
2265 SPY_GetMsgStuff(&sp_e);
2266 indent = get_indent_level();
2268 /* each SPY_SENDMESSAGE must be complemented by call to SPY_ExitMessage */
2269 switch(iFlag)
2271 case SPY_DISPATCHMESSAGE16:
2272 TRACE("%*s(%04x) %-16s message [%04x] %s dispatched wp=%04x lp=%08lx\n",
2273 indent, "", HWND_16(hWnd),
2274 debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name, wParam, lParam);
2275 break;
2277 case SPY_DISPATCHMESSAGE:
2278 TRACE("%*s(%p) %-16s message [%04x] %s dispatched wp=%08x lp=%08lx\n",
2279 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2280 sp_e.msg_name, wParam, lParam);
2281 break;
2283 case SPY_SENDMESSAGE16:
2284 case SPY_SENDMESSAGE:
2286 char taskName[20];
2287 DWORD tid = GetWindowThreadProcessId( hWnd, NULL );
2289 if (tid == GetCurrentThreadId()) strcpy( taskName, "self" );
2290 else sprintf( taskName, "tid %04lx", GetCurrentThreadId() );
2292 if (iFlag == SPY_SENDMESSAGE16)
2293 TRACE("%*s(%04x) %-16s message [%04x] %s sent from %s wp=%04x lp=%08lx\n",
2294 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2295 sp_e.msg_name, taskName, wParam, lParam );
2296 else
2297 { TRACE("%*s(%p) %-16s message [%04x] %s sent from %s wp=%08x lp=%08lx\n",
2298 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2299 sp_e.msg_name, taskName, wParam, lParam );
2300 SPY_DumpStructure(&sp_e, TRUE);
2303 break;
2305 case SPY_DEFWNDPROC16:
2306 if( SPY_ExcludeDWP ) return;
2307 TRACE("%*s(%04x) DefWindowProc16: %s [%04x] wp=%04x lp=%08lx\n",
2308 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, wParam, lParam );
2309 break;
2311 case SPY_DEFWNDPROC:
2312 if( SPY_ExcludeDWP ) return;
2313 TRACE("%*s(%p) DefWindowProc32: %s [%04x] wp=%08x lp=%08lx\n",
2314 indent, "", hWnd, sp_e.msg_name,
2315 msg, wParam, lParam );
2316 break;
2318 set_indent_level( indent + SPY_INDENT_UNIT );
2322 /***********************************************************************
2323 * SPY_ExitMessage
2325 void SPY_ExitMessage( INT iFlag, HWND hWnd, UINT msg, LRESULT lReturn,
2326 WPARAM wParam, LPARAM lParam )
2328 SPY_INSTANCE sp_e;
2329 int indent;
2331 if (!TRACE_ON(message) || SPY_EXCLUDE(msg) ||
2332 (SPY_ExcludeDWP && (iFlag == SPY_RESULT_DEFWND16 || iFlag == SPY_RESULT_DEFWND)) )
2333 return;
2335 sp_e.msgnum = msg;
2336 sp_e.msg_hwnd = hWnd;
2337 sp_e.lParam = lParam;
2338 sp_e.wParam = wParam;
2339 SPY_GetWndName(&sp_e);
2340 SPY_GetMsgStuff(&sp_e);
2342 if ((indent = get_indent_level()))
2344 indent -= SPY_INDENT_UNIT;
2345 set_indent_level( indent );
2348 switch(iFlag)
2350 case SPY_RESULT_DEFWND16:
2351 TRACE(" %*s(%04x) DefWindowProc16: %s [%04x] returned %08lx\n",
2352 indent, "", HWND_16(hWnd), sp_e.msg_name, msg, lReturn );
2353 break;
2355 case SPY_RESULT_DEFWND:
2356 TRACE(" %*s(%p) DefWindowProc32: %s [%04x] returned %08lx\n",
2357 indent, "", hWnd, sp_e.msg_name, msg, lReturn );
2358 break;
2360 case SPY_RESULT_OK16:
2361 TRACE(" %*s(%04x) %-16s message [%04x] %s returned %08lx\n",
2362 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg,
2363 sp_e.msg_name, lReturn );
2364 break;
2366 case SPY_RESULT_OK:
2367 TRACE(" %*s(%p) %-16s message [%04x] %s returned %08lx\n",
2368 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2369 sp_e.msg_name, lReturn );
2370 SPY_DumpStructure(&sp_e, FALSE);
2371 break;
2373 case SPY_RESULT_INVALIDHWND16:
2374 WARN(" %*s(%04x) %-16s message [%04x] %s HAS INVALID HWND\n",
2375 indent, "", HWND_16(hWnd), debugstr_w(sp_e.wnd_name), msg, sp_e.msg_name );
2376 break;
2378 case SPY_RESULT_INVALIDHWND:
2379 WARN(" %*s(%p) %-16s message [%04x] %s HAS INVALID HWND\n",
2380 indent, "", hWnd, debugstr_w(sp_e.wnd_name), msg,
2381 sp_e.msg_name );
2382 break;
2387 /***********************************************************************
2388 * SPY_Init
2390 int SPY_Init(void)
2392 int i, j;
2393 char buffer[1024];
2394 const SPY_NOTIFY *p;
2395 const USER_MSG *q;
2396 HKEY hkey;
2398 if (!TRACE_ON(message)) return TRUE;
2400 indent_tls_index = TlsAlloc();
2401 if(!RegOpenKeyA(HKEY_LOCAL_MACHINE, "Software\\Wine\\Wine\\Config\\Debug", &hkey))
2403 DWORD type, count = sizeof(buffer);
2405 buffer[0] = 0;
2406 if (!RegQueryValueExA(hkey, "SpyInclude", 0, &type, buffer, &count) &&
2407 strcmp( buffer, "INCLUDEALL" ))
2409 TRACE("Include=%s\n", buffer );
2410 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2411 SPY_Exclude[i] = (MessageTypeNames[i] && !strstr(buffer,MessageTypeNames[i]));
2414 count = sizeof(buffer);
2415 buffer[0] = 0;
2416 if (!RegQueryValueExA(hkey, "SpyExclude", 0, &type, buffer, &count))
2418 TRACE("Exclude=%s\n", buffer );
2419 if (!strcmp( buffer, "EXCLUDEALL" ))
2420 for (i = 0; i <= SPY_MAX_MSGNUM; i++) SPY_Exclude[i] = TRUE;
2421 else
2422 for (i = 0; i <= SPY_MAX_MSGNUM; i++)
2423 SPY_Exclude[i] = (MessageTypeNames[i] && strstr(buffer,MessageTypeNames[i]));
2426 SPY_ExcludeDWP = 0;
2427 count = sizeof(buffer);
2428 if(!RegQueryValueExA(hkey, "SpyExcludeDWP", 0, &type, buffer, &count))
2429 SPY_ExcludeDWP = atoi(buffer);
2431 RegCloseKey(hkey);
2434 /* find last good entry in spy notify array and save addr for b-search */
2435 p = &spnfy_array[0];
2436 j = 0xffffffff;
2437 while (p->name) {
2438 if ((UINT)p->value > (UINT)j) {
2439 ERR("Notify message array out of order\n");
2440 ERR(" between values [%08x] %s and [%08x] %s\n",
2441 j, (p-1)->name, p->value, p->name);
2442 break;
2444 j = p->value;
2445 p++;
2447 p--;
2448 end_spnfy_array = p;
2450 /* find last good entry in each common control message array
2451 * and save addr for b-search.
2453 i = 0;
2454 while (cc_array[i].classname) {
2456 j = 0x0400; /* minimum entry in array */
2457 q = cc_array[i].classmsg;
2458 while(q->name) {
2459 if (q->value <= j) {
2460 ERR("Class message array out of order for class %s\n",
2461 debugstr_w(cc_array[i].classname));
2462 ERR(" between values [%04x] %s and [%04x] %s\n",
2463 j, (q-1)->name, q->value, q->name);
2464 break;
2466 j = q->value;
2467 q++;
2469 q--;
2470 cc_array[i].lastmsg = (USER_MSG *)q;
2472 i++;
2475 return 1;