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