Fix the case of product and company names.
[wine] / windows / spy.c
1 /*
2  * Message spying routines
3  *
4  * Copyright 1994, Bob Amstadt
5  *           1995, Alex Korobka
6  *
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.
11  *
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.
16  *
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
20  */
21
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"
37
38 WINE_DEFAULT_DEBUG_CHANNEL(message);
39
40 #define SPY_MAX_MSGNUM   WM_USER
41 #define SPY_INDENT_UNIT  4  /* 4 spaces */
42
43 #define DEBUG_SPY 0
44
45 static const char * const MessageTypeNames[SPY_MAX_MSGNUM + 1] =
46 {
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,
111
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,
121
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,
130
131     /* 0x0060 */
132     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
133     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
134
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",
143
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,
154
155     /* 0x0090 */
156     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
157     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
158
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,
171
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 */
189
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 */
206
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,
216
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,
229
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,
240
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 */
257
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 */
269
270     "WM_MENUCHAR",              /* 0x0120 */
271     "WM_ENTERIDLE",             /* 0x0121 */
272
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 */
281
282     NULL, NULL, NULL, NULL, NULL, NULL,
283
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,
295
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 */
313
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 */
330
331     "CB_SETDROPPEDWIDTH",       /* 0x0160 */
332     "CB_INITSTORAGE",           /* 0x0161 */
333     NULL, NULL, NULL, NULL, NULL, NULL,
334     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
335
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,
343
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 */
361
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 */
378
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,
390
391     /* 0x01B0 */
392     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
393     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
394
395     /* 0x01C0 */
396     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
397     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
398
399     /* 0x01D0 */
400     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
401     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
402
403     /* 0x01E0 */
404     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
405     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
406
407     /* 0x01F0 */
408     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
409     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
410
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,
423
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,
433
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 */
444
445     "WM_DROPOBJECT",
446     "WM_QUERYDROPOBJECT",
447     "WM_BEGINDRAG",
448     "WM_DRAGLOOP",
449     "WM_DRAGSELECT",
450     "WM_DRAGMOVE",
451
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,
460
461     /* 0x0240 */
462     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
463     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
464
465     /* 0x0250 */
466     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
467     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
468
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,
474
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,
480
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,
486
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,
492
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,
497
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*/
514
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,
522
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,
527
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,
533
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 */
560
561     NULL,NULL,NULL,NULL,
562
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 */
572
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 */
577
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,
585
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",
599
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,
614
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,
626
627
628     /* 0x03f0 */
629     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
630     NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
631
632     "WM_USER"                   /* 0x0400 */
633 };
634
635
636 #define SPY_MAX_LVMMSGNUM   140
637 static const char * const LVMMessageTypeNames[SPY_MAX_LVMMSGNUM + 1] =
638 {
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 */
780 };
781
782
783 #define SPY_MAX_TVMSGNUM   65
784 static const char * const TVMessageTypeNames[SPY_MAX_TVMSGNUM + 1] =
785 {
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"
852 };
853
854
855 #define SPY_MAX_HDMMSGNUM   19
856 static const char * const HDMMessageTypeNames[SPY_MAX_HDMMSGNUM + 1] =
857 {
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"
878 };
879
880
881 #define SPY_MAX_TCMMSGNUM   62
882 static const char * const TCMMessageTypeNames[SPY_MAX_TCMMSGNUM + 1] =
883 {
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"
947 };
948
949 #define SPY_MAX_PGMMSGNUM   13
950 static const char * const PGMMessageTypeNames[SPY_MAX_PGMMSGNUM + 1] =
951 {
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"
966 };
967
968
969 #define SPY_MAX_CCMMSGNUM   9
970 static const char * const CCMMessageTypeNames[SPY_MAX_CCMMSGNUM + 1] =
971 {
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"
982 };
983
984 #define SPY_MAX_WINEMSGNUM   6
985 static const char * const WINEMessageTypeNames[SPY_MAX_WINEMSGNUM + 1] =
986 {
987     "WM_WINE_DESTROYWINDOW",
988     "WM_WINE_SETWINDOWPOS",
989     "WM_WINE_SHOWWINDOW",
990     "WM_WINE_SETPARENT",
991     "WM_WINE_SETWINDOWLONG",
992     "WM_WINE_ENABLEWINDOW"
993 };
994
995 /* Virtual key names */
996 #define SPY_MAX_VKKEYSNUM 255
997 static const char * const VK_KeyNames[SPY_MAX_VKKEYSNUM + 1] =
998 {
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 */
1255 };
1256
1257
1258 /************************************************************************/
1259
1260
1261 /* WM_USER+n message values for "common controls" */
1262
1263 typedef struct
1264 {
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;
1269
1270
1271 typedef struct
1272 {
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;
1277
1278 #define USM(a,b) { #a ,a,b}
1279 #define SZOF(a)  sizeof(a)
1280
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.)                         */
1284
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} };
1322
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} };
1416
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} };
1457
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} };
1474
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 };
1499
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} };
1516
1517 #undef SZOF
1518 #undef USM
1519
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} };
1528
1529
1530 /************************************************************************/
1531
1532
1533 /* WM_NOTIFY function codes display */
1534
1535 typedef struct
1536 {
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;
1541
1542 #define SPNFY(a,b) { #a ,a,sizeof(b)-sizeof(NMHDR)}
1543
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
1755
1756
1757 static BOOL16 SPY_Exclude[SPY_MAX_MSGNUM+1];
1758 static BOOL16 SPY_ExcludeDWP = 0;
1759
1760 #define SPY_EXCLUDE(msg) \
1761     (SPY_Exclude[(msg) > SPY_MAX_MSGNUM ? SPY_MAX_MSGNUM : (msg)])
1762
1763
1764 typedef struct
1765 {
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;
1775
1776 /* This is defined so that the external entry point can return the addr */
1777 static SPY_INSTANCE ext_sp_e;
1778
1779 static int indent_tls_index;
1780
1781 /***********************************************************************
1782  *           get_indent_level
1783  */
1784 inline static int get_indent_level(void)
1785 {
1786     return (int)TlsGetValue( indent_tls_index );
1787 }
1788
1789
1790 /***********************************************************************
1791  *           set_indent_level
1792  */
1793 inline static void set_indent_level( int level )
1794 {
1795     TlsSetValue( indent_tls_index, (void *)level );
1796 }
1797
1798
1799 /***********************************************************************
1800  *           SPY_GetMsgInternal
1801  */
1802 static const char *SPY_GetMsgInternal( UINT msg )
1803 {
1804     if (msg <= SPY_MAX_MSGNUM)
1805     {
1806         if (!MessageTypeNames[msg]) return "???";
1807         return MessageTypeNames[msg];
1808     }
1809
1810     if (msg >= LVM_FIRST && msg <= LVM_FIRST + SPY_MAX_LVMMSGNUM)
1811     {
1812         if (!LVMMessageTypeNames[msg-LVM_FIRST]) return "LVM_?";
1813         return LVMMessageTypeNames[msg-LVM_FIRST];
1814     }
1815
1816     if (msg >= TV_FIRST && msg <= TV_FIRST + SPY_MAX_TVMSGNUM)
1817     {
1818         if (!TVMessageTypeNames[msg-TV_FIRST]) return "TV_?";
1819         return TVMessageTypeNames[msg-TV_FIRST];
1820     }
1821
1822     if (msg >= HDM_FIRST && msg <= HDM_FIRST + SPY_MAX_HDMMSGNUM)
1823     {
1824         if (!HDMMessageTypeNames[msg-HDM_FIRST]) return "HDM_?";
1825         return HDMMessageTypeNames[msg-HDM_FIRST];
1826     }
1827
1828     if (msg >= TCM_FIRST && msg <= TCM_FIRST + SPY_MAX_TCMMSGNUM)
1829     {
1830         if (!TCMMessageTypeNames[msg-TCM_FIRST]) return "TCM_?";
1831         return TCMMessageTypeNames[msg-TCM_FIRST];
1832     }
1833
1834     if (msg >= PGM_FIRST && msg <= PGM_FIRST + SPY_MAX_PGMMSGNUM)
1835     {
1836         if (!PGMMessageTypeNames[msg-PGM_FIRST]) return "PGM_?";
1837         return PGMMessageTypeNames[msg-PGM_FIRST];
1838     }
1839
1840     if (msg >= CCM_FIRST && msg <= CCM_FIRST + SPY_MAX_CCMMSGNUM)
1841     {
1842         if (!CCMMessageTypeNames[msg-CCM_FIRST]) return "???";
1843         return CCMMessageTypeNames[msg-CCM_FIRST];
1844     }
1845
1846     if (msg >= WM_WINE_DESTROYWINDOW && msg <= WM_WINE_DESTROYWINDOW + SPY_MAX_WINEMSGNUM)
1847     {
1848         if (!WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW]) return "???";
1849         return WINEMessageTypeNames[msg-WM_WINE_DESTROYWINDOW];
1850     }
1851     return "";
1852 }
1853
1854 /***********************************************************************
1855  *           SPY_Bsearch_Msg
1856  */
1857 const USER_MSG *SPY_Bsearch_Msg( const USER_MSG *first, const USER_MSG *last, UINT code)
1858 {
1859     INT count;
1860     const USER_MSG *test;
1861
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;
1872         }
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;
1884     }
1885     return NULL;
1886 }
1887
1888 /***********************************************************************
1889  *           SPY_GetMsgStuff
1890  *
1891  *  Get message name and other information for dumping
1892  */
1893 static void SPY_GetMsgStuff( SPY_INSTANCE *sp_e )
1894 {
1895     const USER_MSG *p;
1896
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);
1900
1901     sp_e->data_len = 0;
1902     if (!sp_e->msg_name[0])
1903     {
1904         INT i = 0;
1905
1906         if (sp_e->msgnum >= 0xc000)
1907         {
1908             if (GlobalGetAtomNameA( sp_e->msgnum, sp_e->msg_name+1, sizeof(sp_e->msg_name)-2 ))
1909             {
1910                 sp_e->msg_name[0] = '\"';
1911                 strcat( sp_e->msg_name, "\"" );
1912                 return;
1913             }
1914         }
1915 #if DEBUG_SPY
1916         TRACE("looking class %s\n", sp_e->wnd_class);
1917 #endif
1918
1919         while (cc_array[i].classname &&
1920                strcmpW(cc_array[i].classname, sp_e->wnd_class) !=0) i++;
1921
1922         if (cc_array[i].classname)
1923         {
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;
1935             }
1936         }
1937         sprintf( sp_e->msg_name, "WM_USER+%04x", sp_e->msgnum - WM_USER );
1938     }
1939 }
1940
1941 /***********************************************************************
1942  *           SPY_GetWndName
1943  *
1944  *  Sets the value of "wnd_name" and "wnd_class" members of the
1945  *  instance structure.
1946  *
1947  */
1948 void SPY_GetWndName( SPY_INSTANCE *sp_e )
1949 {
1950     DWORD save_error;
1951     INT len;
1952
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);
1959     }
1960     else {
1961         GetClassNameW(sp_e->msg_hwnd, sp_e->wnd_class, sizeof(sp_e->wnd_class)/sizeof(WCHAR));
1962     }
1963     SetLastError(save_error);
1964
1965     len = InternalGetWindowText(sp_e->msg_hwnd, sp_e->wnd_name, sizeof(sp_e->wnd_name)/sizeof(WCHAR));
1966     if(!len) /* get class name */
1967     {
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;
1975     }
1976 }
1977
1978 /***********************************************************************
1979  *           SPY_GetMsgName
1980  *
1981  *  ****  External function  ****
1982  *
1983  *  Get message name
1984  */
1985 const char *SPY_GetMsgName( UINT msg, HWND hWnd )
1986 {
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;
1994 }
1995
1996 /***********************************************************************
1997  *           SPY_GetVKeyName
1998  */
1999 const char *SPY_GetVKeyName(WPARAM wParam)
2000 {
2001     const char *vk_key_name;
2002
2003     if(wParam <= SPY_MAX_VKKEYSNUM && VK_KeyNames[wParam])
2004         vk_key_name = VK_KeyNames[wParam];
2005     else
2006         vk_key_name = "VK_???";
2007
2008     return vk_key_name;
2009 }
2010
2011 /***********************************************************************
2012  *           SPY_Bsearch_Notify
2013  */
2014 const SPY_NOTIFY *SPY_Bsearch_Notify( const SPY_NOTIFY *first, const SPY_NOTIFY *last, UINT code)
2015 {
2016     INT count;
2017     const SPY_NOTIFY *test;
2018
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;
2029         }
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;
2041     }
2042     return NULL;
2043 }
2044
2045 /***********************************************************************
2046  *           SPY_DumpMem
2047  */
2048 void SPY_DumpMem (LPSTR header, UINT *q, INT len)
2049 {
2050     int i;
2051
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;
2056     }
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;
2076     }
2077 }
2078
2079 /***********************************************************************
2080  *           SPY_DumpStructure
2081  */
2082 void SPY_DumpStructure (SPY_INSTANCE *sp_e, BOOL enter)
2083 {
2084     switch (sp_e->msgnum)
2085         {
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:
2094             {
2095                 LPLVITEMA item = (LPLVITEMA) sp_e->lParam;
2096                 if (item) {
2097                     SPY_DumpMem ("LVITEM", (UINT*)item, sizeof(LVITEMA));
2098                 }
2099                 break;
2100             }
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:
2109             {
2110                 TCITEMA *item = (TCITEMA *) sp_e->lParam;
2111                 if (item) {
2112                     SPY_DumpMem ("TCITEM", (UINT*)item, sizeof(TCITEMA));
2113                 }
2114                 break;
2115             }
2116         case TCM_ADJUSTRECT:
2117         case LVM_GETITEMRECT:
2118         case LVM_GETSUBITEMRECT:
2119             {
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);
2124                 }
2125                 break;
2126             }
2127         case LVM_SETITEMPOSITION32:
2128             if (!enter) break;
2129             /* fall through */
2130         case LVM_GETITEMPOSITION:
2131         case LVM_GETORIGIN:
2132             {
2133                 LPPOINT point = (LPPOINT) sp_e->lParam;
2134                 if (point) {
2135                     TRACE("lParam point x=%ld, y=%ld\n", point->x, point->y);
2136                 }
2137                 break;
2138             }
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;
2146             {
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;
2156             }
2157         case WM_DRAWITEM:
2158             if (!enter) break;
2159             {
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);
2169             }
2170             break;
2171         case WM_MEASUREITEM:
2172             {
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);
2179             }
2180             break;
2181         case WM_WINDOWPOSCHANGED:
2182             if (!enter) break;
2183         case WM_WINDOWPOSCHANGING:
2184             {
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);
2189             }
2190             break;
2191         case WM_STYLECHANGED:
2192             if (!enter) break;
2193         case WM_STYLECHANGING:
2194             {
2195                 LPSTYLESTRUCT ss = (LPSTYLESTRUCT) sp_e->lParam;
2196                 TRACE("STYLESTRUCT: StyleOld=0x%08lx, StyleNew=0x%08lx\n",
2197                       ss->styleOld, ss->styleNew);
2198             }
2199             break;
2200         case WM_NCCALCSIZE:
2201             {
2202                 RECT *rc = (RECT *)sp_e->lParam;
2203                 TRACE("Rect (%ld,%ld)-(%ld,%ld)\n",
2204                       rc->left, rc->top, rc->right, rc->bottom);
2205             }
2206             break;
2207         case WM_NOTIFY:
2208             /* if (!enter) break; */
2209             {
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;
2215
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;
2222
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);
2232                     }
2233                     if (dumplen > 0) {
2234                         q = (UINT *)(pnmh + 1);
2235                         SPY_DumpMem ("NM extra", q, (INT)dumplen);
2236                     }
2237                 }
2238                 else
2239                     TRACE("NMHDR hwndFrom=%p idFrom=0x%08x code=0x%08x\n",
2240                           pnmh->hwndFrom, pnmh->idFrom, pnmh->code);
2241             }
2242         default:
2243             if (sp_e->data_len > 0)
2244                 SPY_DumpMem ("MSG lParam", (UINT *)sp_e->lParam, sp_e->data_len);
2245             break;
2246         }
2247
2248 }
2249 /***********************************************************************
2250  *           SPY_EnterMessage
2251  */
2252 void SPY_EnterMessage( INT iFlag, HWND hWnd, UINT msg,
2253                        WPARAM wParam, LPARAM lParam )
2254 {
2255     SPY_INSTANCE sp_e;
2256     int indent;
2257
2258     if (!TRACE_ON(message) || SPY_EXCLUDE(msg)) return;
2259
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();
2267
2268     /* each SPY_SENDMESSAGE must be complemented by call to SPY_ExitMessage */
2269     switch(iFlag)
2270     {
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;
2276
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;
2282
2283     case SPY_SENDMESSAGE16:
2284     case SPY_SENDMESSAGE:
2285         {
2286             char taskName[20];
2287             DWORD tid = GetWindowThreadProcessId( hWnd, NULL );
2288
2289             if (tid == GetCurrentThreadId()) strcpy( taskName, "self" );
2290             else sprintf( taskName, "tid %04lx", GetCurrentThreadId() );
2291
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);
2301             }
2302         }
2303         break;
2304
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;
2310
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;
2317     }
2318     set_indent_level( indent + SPY_INDENT_UNIT );
2319 }
2320
2321
2322 /***********************************************************************
2323  *           SPY_ExitMessage
2324  */
2325 void SPY_ExitMessage( INT iFlag, HWND hWnd, UINT msg, LRESULT lReturn,
2326                        WPARAM wParam, LPARAM lParam )
2327 {
2328     SPY_INSTANCE sp_e;
2329     int indent;
2330
2331     if (!TRACE_ON(message) || SPY_EXCLUDE(msg) ||
2332         (SPY_ExcludeDWP && (iFlag == SPY_RESULT_DEFWND16 || iFlag == SPY_RESULT_DEFWND)) )
2333         return;
2334
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);
2341
2342     if ((indent = get_indent_level()))
2343     {
2344         indent -= SPY_INDENT_UNIT;
2345         set_indent_level( indent );
2346     }
2347
2348     switch(iFlag)
2349     {
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;
2354
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;
2359
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;
2365
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;
2372
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;
2377
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;
2383    }
2384 }
2385
2386
2387 /***********************************************************************
2388  *           SPY_Init
2389  */
2390 int SPY_Init(void)
2391 {
2392     int i, j;
2393     char buffer[1024];
2394     const SPY_NOTIFY *p;
2395     const USER_MSG *q;
2396     HKEY hkey;
2397
2398     if (!TRACE_ON(message)) return TRUE;
2399
2400     indent_tls_index = TlsAlloc();
2401     if(!RegOpenKeyA(HKEY_LOCAL_MACHINE, "Software\\Wine\\Wine\\Config\\Debug", &hkey))
2402     {
2403         DWORD type, count = sizeof(buffer);
2404
2405         buffer[0] = 0;
2406         if (!RegQueryValueExA(hkey, "SpyInclude", 0, &type, buffer, &count) &&
2407             strcmp( buffer, "INCLUDEALL" ))
2408         {
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]));
2412         }
2413
2414         count = sizeof(buffer);
2415         buffer[0] = 0;
2416         if (!RegQueryValueExA(hkey, "SpyExclude", 0, &type, buffer, &count))
2417         {
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]));
2424         }
2425
2426         SPY_ExcludeDWP = 0;
2427         count = sizeof(buffer);
2428         if(!RegQueryValueExA(hkey, "SpyExcludeDWP", 0, &type, buffer, &count))
2429             SPY_ExcludeDWP = atoi(buffer);
2430
2431         RegCloseKey(hkey);
2432     }
2433
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;
2443         }
2444         j = p->value;
2445         p++;
2446     }
2447     p--;
2448     end_spnfy_array = p;
2449
2450     /* find last good entry in each common control message array
2451      *  and save addr for b-search.
2452      */
2453     i = 0;
2454     while (cc_array[i].classname) {
2455
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;
2465             }
2466             j = q->value;
2467             q++;
2468         }
2469         q--;
2470         cc_array[i].lastmsg = (USER_MSG *)q;
2471
2472         i++;
2473     }
2474
2475     return 1;
2476 }