1 <chapter id="debugging">
2 <title>Debug Logging</title>
5 Written by &name-dimitrie-paun; <email>&email-dimitrie-paun;</email>, 28 Mar 1998
8 (Extracted from <filename>wine/documentation/debug-msgs</filename>)
13 The new debugging interface can be considered to be
14 stable, with the exception of the in-memory message
15 construction functions. However, there is still a lot of
16 work to be done to polish things up. To make my life
17 easier, please follow the guidelines described in this
24 Read this document before writing new code. DO NOT USE
25 <function>fprintf</function> (or
26 <function>printf</function>) to output things. Also, instead
27 of writing FIXMEs in the source, output a FIXME message if
31 At the end of the document, there is a "Style Guide" for
32 debugging messages. Please read it.
36 <sect1 id="dbg-classes">
37 <title>Debugging classes</title>
40 There are 4 types (or classes) of debugging messages:
44 <term><literal>FIXME</literal></term>
47 Messages in this class relate to behavior of Wine that
48 does not correspond to standard Windows behavior and
51 <para>Examples: stubs, semi-implemented features, etc.</para>
55 <term><literal>ERR</literal></term>
58 Messages in this class relate to serious errors in
59 Wine. This sort of messages are close to asserts --
60 that is, you should output an error message when the
61 code detects a condition which should not happen. In
62 other words, important things that are not warnings
63 (see below), are errors.
66 Examples: unexpected change in internal state, etc.
71 <term><literal>WARN</literal></term>
74 These are warning messages. You should report a
75 warning when something unwanted happen but the
76 function behaves properly. That is, output a warning
77 when you encounter something unexpected (ex: could not
78 open a file) but the function deals correctly with the
79 situation (that is, according to the docs). If you do
80 not deal correctly with it, output a fixme.
83 Examples: fail to access a resource required by the
89 <term><literal>TRACE</literal></term>
92 These are detailed debugging messages that are mainly
93 useful to debug a component. These are usually turned
97 Examples: everything else that does not fall in one of
98 the above mentioned categories and the user does not
99 need to know about it.
106 The user has the capability to turn on or off messages of a
107 particular type. You can expect the following patterns of
108 usage (but note that any combination is possible):
113 when you debug a component, all types
114 (<literal>TRACE</literal>, <literal>WARN</literal>,
115 <literal>ERR</literal>, <literal>FIXME</literal>) will
121 during the pre-alpha (maybe alpha) stage of Wine, most
122 likely the <literal>TRACE</literal> class will be
123 disabled by default, but all others
124 (<literal>WARN</literal>, <literal>ERR</literal>,
125 <literal>FIXME</literal>) will be enabled by default.
130 when Wine will become stable, most likely the
131 <literal>TRACE</literal> and <literal>WARN</literal>
132 classes will be disabled by default, but all
133 <literal>ERR</literal>s and <literal>FIXME</literal>s
139 in some installations that want the smallest footprint
140 and where the debug information is of no interest, all
141 classes may be disabled by default.
146 Of course, the user will have the runtime ability to
147 override these defaults. However, this ability may be turned
148 off and certain classes of messages may be completely
149 disabled at compile time to reduce the size of Wine.
153 <sect1 id="dbg-channels">
154 <title>Debugging channels</title>
157 Also, we divide the debugging messages on a component basis.
158 Each component is assigned a debugging channel. The
159 identifier of the channel must be a valid C identifier but
160 note that it may also be a reserved word like
161 <type>int</type> or <type>static</type>.
164 Examples of debugging channels:
165 <simplelist type="inline">
166 <member><literal>reg</literal></member>
167 <member><literal>updown</literal></member>
168 <member><literal>string</literal></member>
172 We will refer to a generic channel as <literal>xxx</literal>.
176 for those who know the old interface, the channel/type is
177 what followed the _ in the
178 <function>dprintf_xxx</function> statements. For example,
179 to output a message on the debugging channel
180 <literal>reg</literal> in the old interface you would had
184 dprintf_reg(stddeb, "Could not access key!\n");
187 In the new interface, we drop the
188 <literal>stddeb</literal> as it is implicit. However, we
189 add an orthogonal piece of information to the message: its
190 class. This is very important as it will allow us to
191 selectively turn on or off certain messages based on the
192 type of information they report. For this reason it is
193 essential to choose the right class for the message.
194 Anyhow, suppose we figured that this message should belong
195 in the <literal>WARN</literal> class, so in the new
196 interface, you write:
199 WARN(reg, "Could not access key!\n");
204 <sect1 id="dbg-using">
205 <title>How to use it</title>
208 So, to output a message (class <literal>YYY</literal>) on
209 channel <literal>xxx</literal>, do:
216 YYY(xxx, "<message>", ...);
219 Some examples from the code:
226 TRACE(crtdll, "CRTDLL_setbuf(file %p buf %p)", file, buf);
228 WARN(aspi, "Error opening device errno=%d", save_error);
231 If you need to declare a new debugging channel, use it in
232 your code and then do:
238 in the root directory of Wine. Note that this will result in
239 almost complete recompilation of Wine.
246 Please pay attention to which class you assign the
247 message. There are only 4 classes, so it is not hard.
248 The reason it is important to get it right is that too
249 much information is no information. For example, if
250 you put things into the <literal>WARN</literal> class
251 that should really be in the <literal>TRACE</literal>
252 class, the output will be too big and this will force
253 the user to turn warnings off. But this way he will
254 fail to see the important ones. Also, if you put
255 warnings into the <literal>TRACE</literal> class lets
256 say, he will most likely miss those because usually
257 the <literal>TRACE</literal> class is turned off. A
258 similar argument can be made if you mix any other two
264 All lines should end with a newline. If you can NOT
265 output everything that you want in the line with only
266 one statement, then you need to build the string in
267 memory. Please read the section below "In-memory
268 messages" on the preferred way to do it. PLEASE USE
269 THAT INTERFACE TO BUILD MESSAGES IN MEMORY. The reason
270 is that we are not sure that we like it and having
271 everything in one format will facilitate the
272 (automatic) translation to a better interface.
279 <sect1 id="dbg-checking">
280 <title>Are we debugging?</title>
283 To test whether the debugging output of class
284 <literal>yyy</literal> on channel <literal>xxx</literal> is
288 TRACE_ON to test if TRACE is enabled
289 WARN_ON to test if WARN is enabled
290 FIXME_ON to test if FIXME is enabled
291 ERR_ON to test if ERR is enabled
304 You should normally need to test only if
305 <literal>TRACE_ON</literal>. At present, none of the other
306 3 tests (except for <literal>ERR_ON</literal> which is
307 used only once!) are used in Wine.
312 <sect1 id="dbg-in-memory">
313 <title>In-memory messages</title>
316 If you NEED to build the message from multiple calls, you
317 need to build it in memory. To do that, you should use the
324 declare a string (where you are allowed to declare C
325 variables) as follows:
327 dbg_decl_str(name, len);
329 where <parameter>name</parameter> is the name of the
330 string (you should use the channel name on which you
331 are going to output it)
338 dsprintf(name, "<message>", ...);
340 which is just like a <function>sprintf</function>
341 function but instead of a C string as first parameter it
342 takes the name you used to declare it.
347 obtain a pointer to the string with: <function>dbg_str(name)</function>
352 reset the string (if you want to reuse it with):
361 Example (modified from the code):
367 LPINT16 p = (LPINT16)tabs;
368 dbg_decl_str(listbox, 256); /* declare the string */
370 for (i = 0; i < descr->nb_tabs; i++) {
371 descr->tabs[i] = *p++<<1;
372 if(TRACING(listbox)) /* write in it only if
373 dsprintf(listbox, "%hd ", descr->tabs[i]); /* we are gonna output it */
375 TRACE(listbox, "Listbox %04x: settabstops %s",
376 wnd->hwndSelf, dbg_str(listbox)); /* output the whole thing */
380 If you need to use it two times in the same scope do like
387 LPINT16 p = (LPINT16)tabs;
388 dbg_decl_str(listbox, 256); /* declare the string */
390 for (i = 0; i < descr->nb_tabs; i++) {
391 descr->tabs[i] = *p++<<1;
392 if(TRACING(listbox)) /* write in it only if
393 dsprintf(listbox, "%hd ", descr->tabs[i]); /* we are gonna output it */
395 TRACE(listbox, "Listbox %04x: settabstops %s\n",
396 wnd->hwndSelf, dbg_str(listbox)); /* output the whole thing */
398 dbg_reset_str(listbox); /* !!!reset the string!!! */
399 for (i = 0; i < descr->extrainfo_nr; i++) {
400 descr->extrainfo = *p+1;
401 if(TRACING(listbox)) /* write in it only if
402 dsprintf(listbox,"%3d ",descr->extrainfo); /* we are gonna output it */
405 TRACE(listbox, "Listbox %04x: extrainfo %s\n",
406 wnd->hwndSelf, dbg_str(listbox)); /* output the whole thing */
413 As I already stated, I do not think this will be the
414 ultimate interface for building in-memory debugging
415 messages. In fact, I do have better ideas which I hope to
416 have time to implement for the next release. For this
417 reason, please try not to use it. However, if you need to
418 output a line in more than one
419 <function>dprintf_xxx</function> calls, then USE THIS
420 INTERFACE. DO NOT use other methods. This way, I will
421 easily translate everything to the new interface (when it
422 will become available). So, if you need to use it, then
423 follow the following guidelines:
427 <para>wrap calls to <function>dsprintf</function> with a
434 Of course, if the call to
435 <function>dsprintf</function> is made from within a
436 function which you know is called only if
437 <function>YYY(xxx)</function> is true, for example if
438 you call it only like this:
442 print_some_debug_info();
445 then you need not (and should not) wrap calls to
446 <function>dsprintf</function> with the before
447 mentioned <function>if</function>.
452 name the string EXACTLY like the debugging channel on
453 which is going to be output. Please see the above
461 <sect1 id="dbg-resource-ids">
462 <title>Resource identifiers</title>
465 Resource identifiers can be either strings or numbers. To
466 make life a bit easier for outputting these beasts (and to
467 help you avoid the need to build the message in memory), I
468 introduced a new function called <function>debugres</function>.
471 The function is defined in <filename>debugstr.h</filename>
472 and has the following prototype:
475 LPSTR debugres(const void *id);
478 It takes a pointer to the resource id and returns a nicely
479 formatted string of the identifier. If the high word of the
480 pointer is <literal>0</literal>, then it assumes that the
481 identifier is a number and thus returns a string of the
488 where <literal>xxxx</literal> are 4 hex-digits representing
489 the low word of <parameter>id</parameter>.
492 If the high word of the pointer is not <literal>0</literal>,
493 then it assumes that the identifier is a string and thus
494 returns a string of the form:
500 Thus, to use it, do something on the following lines:
507 YYY(xxx, "resource is %s", debugres(myresource));
511 <sect1 id="dbg-param">
512 <title>The <parameter>--debugmsg</parameter> command line option</title>
515 So, the <parameter>--debugmsg</parameter> command line
516 option has been changed as follows:
521 the new syntax is: <parameter>--debugmsg
522 [yyy]#xxx[,[yyy1]#xxx1]*</parameter> where
523 <literal>#</literal> is either <literal>+</literal> or
529 when the optional class argument (<literal>yyy</literal>)
530 is not present, then the statement will
531 enable(<literal>+</literal>)/disable(<literal>-</literal>)
532 all messages for the given channel (<literal>xxx</literal>)
533 on all classes. For example:
536 --debugmsg +reg,-file
539 enables all messages on the <literal>reg</literal>
540 channel and disables all messages on the
541 <literal>file</literal> channel. This is same as the old
547 when the optional class argument (<literal>yyy</literal>)
548 is present, then the statement will enable
549 (<literal>+</literal>)/disable(<literal>-</literal>)
550 messages for the given channel (<literal>xxx</literal>)
551 only on the given class. For example:
554 --debugmsg trace+reg,warn-file
557 enables trace messages on the <literal>reg</literal>
558 channel and disables warning messages on the
559 <literal>file</literal> channel.
564 also, the pseudo-channel all is also supported and it
565 has the intuitive semantics:
568 --debugmsg +all -- enables all debug messages
569 --debugmsg -all -- disables all debug messages
570 --debugmsg yyy+all -- enables debug messages for class yyy on all
572 --debugmsg yyy-all -- disables debug messages for class yyy on all
579 --debugmsg warn-all -- disables all warning messages.
585 Also, note that at the moment:
589 <para>the <literal>FIXME</literal> and <literal>ERR</literal>
590 classes are enabled by default</para>
593 <para>the <literal>TRACE</literal> and
594 <literal>WARN</literal> classes are disabled by
600 <sect1 id="dbg-compiling">
601 <title>Compiling Out Debugging Messages</title>
604 To compile out the debugging messages, provide
605 <command>configure</command> with the following options:
608 --disable-debug -- turns off TRACE, WARN, and FIXME (and DUMP).
609 --disable-trace -- turns off TRACE only.
612 This will result in an executable that, when stripped, is
613 about 15%-20% smaller. Note, however, that you will not be
614 able to effectively debug Wine without these messages.
617 This feature has not been extensively tested--it may subtly
622 <sect1 id="dbg-notes">
623 <title>A Few Notes on Style</title>
626 This new scheme makes certain things more consistent but
627 there is still room for improvement by using a common style
628 of debug messages. Before I continue, let me note that the
629 output format is the following:
632 yyy:xxx:fff <message>
635 yyy = the class (fixme, err, warn, trace)
636 xxx = the channel (atom, win, font, etc)
637 fff = the function name
640 these fields are output automatically. All you have to
641 provide is the <message> part.
644 So here are some ideas:
649 <para>do NOT include the name of the function: it is included automatically</para>
653 if you want to output the parameters of the function, do
654 it as the first thing and include them in parentheses,
657 YYY(xxx, "(%d,%p,etc)...\n", par1, par2, ...);
663 for stubs, you should output a <literal>FIXME</literal>
664 message. I suggest this style:
666 FIXME(xxx, "(%x,%d...): stub\n", par1, par2, ...);
668 That is, you output the parameters, then a : and then a string
669 containing the word "stub". I've seen "empty stub", and others, but I
670 think that just "stub" suffices.
675 output 1 and ONLY 1 line per message. That is, the format
676 string should contain only 1 <literal>\n</literal> and it
677 should always appear at the end of the string. (there are
678 many reasons for this requirement, one of them is that
679 each debug macro adds things to the beginning of the line)
684 if you want to name a value, use <literal>=</literal> and
685 NOT <literal>:</literal>. That is, instead of saying:
687 FIXME(xxx, "(fd: %d, file: %s): stub\n", fd, name);
691 FIXME(xxx, "(fd=%d, file=%s): stub\n", fd, name);
693 use <literal>:</literal> to separate categories.
698 try to avoid the style:
700 FIXME(xxx, "(fd=%d, file=%s): stub\n", fd, name);
704 FIXME(xxx, "(fd=%d, file=%s): stub\n", fd, name);
706 The reason is that if you want to <command>grep</command>
707 for things, you would search for <literal>FIXME</literal>
708 but in the first case there is no additional information
709 available, where in the second one, there is (e.g. the word
715 if you output a string s that might contain control
716 characters, or if <parameter>s</parameter> may be
717 <literal>NULL</literal>, use
718 <function>debugstr_a</function> (for ASCII strings, or
719 <function>debugstr_w</function> for Unicode strings) to
720 convert <parameter>s</parameter> to a C string, like this:
722 HANDLE32 WINAPI YourFunc(LPCSTR s)
724 FIXME(xxx, "(%s): stub\n", debugstr_a(s));
731 if you want to output a resource identifier, use debugres to
732 convert it to a string first, like this:
734 HANDLE32 WINAPI YourFunc(LPCSTR res)
736 FIXME(xxx, "(res=%s): stub\n", debugres(s));
739 if the resource identifier is a <type>SEGPTR</type>, use
740 <function>PTR_SEG_TO_LIN</function> to get a
743 HRSRC16 WINAPI FindResource16( HMODULE16 hModule, SEGPTR name, SEGPTR type )
746 TRACE(resource, "module=%04x name=%s type=%s\n",
747 hModule, debugres(PTR_SEG_TO_LIN(name)),
748 debugres(PTR_SEG_TO_LIN(type)) );
756 for messages intended for the user (specifically those that
757 report errors in <filename>wine.conf</filename>), use the
758 <literal>MSG</literal> macro. Use it like a
759 <function>printf</function>:
761 MSG( "Definition of drive %d is incorrect!\n", drive );
763 However, note that there are <emphasis>very</emphasis> few
764 valid uses of this macro. Most messages are debugging
765 messages, so chances are you will not need to use this
766 macro. Grep the source to get an idea where it is
767 appropriate to use it.
772 For structure dumps, use the <function>DUMP</function>
773 macro. Use it like a <function>printf</function>, just like
774 the <literal>MSG</literal> macro. Similarly, there are only
775 a few valid uses of this macro. Grep the source to see when
784 <!-- Keep this comment at the end of the file
787 sgml-parent-document:("wine-doc.sgml" "set" "book" "part" "chapter" "")