#define DEBUG... (using printf for debugging)

Travis Lee Winfrey travis at cs.columbia.edu
Sat May 5 02:19:10 AEST 1990


In article <40628 at cornell.UUCP>, 
>gordon at mimir.cs.cornell.edu (Jeffrey  Adam Gordon) writes:
>
>    I want to have a DEBUG flag which controls whether diagnostic printfs
>    are executed or not.

Well, another variation on the debug macro with two parentheses
is to have a first argument that specifies the current level of
interest.  This argument can be compared with whatever you need: a
module-specific #define, a module-specific variable, a global
variable.  The two biggest problems with this method are the complaints
from lint about constants appearing in an if-statement, and that some
compilers may not strip out the code when you don't want the output.

A sample follow.  Note that the numbers here range from 1 to 4 because
I define DEBUG on a per-module basis.  Some other people specify their
interest in debugging information in terms of percentages, i.e., show
me 50% of everything you have in this module.  that's not intuitive
for me.

(I'm sorry if anyone else has already described this particular
fillip; I looked through all the messages posted so far, as many of
the previous posters should have done.)

/* 
 * debugging macros.  the dprintf macro takes two arguments, a
 * debugging level (1, 2, 3, 4) and a list of ordinary printf
 * arguments in parentheses, e.g.,
 *	dprintf(1, ("proc_kill_module: sys_ptr is NULL!\n"));
 * 
 * debugging levels:
 *     level 1: ordinary unexpected events which the programmer may want
 *              to know, but a user will not.  all "oh no!" type
 * 		information should be marked with this.
 *     level 2: more detailed, usually per-module information that
 * 		will a programmer will not want to know *unless* he or
 * 		she is debugging that module.
 *     Level 3: more detailed than 2, usually per-procedure
 * 		debugging information.  debugging statements this
 * 		low-level will be removed once gross errors are
 * 		found and removed.
 *     Level 4: just a level for demarcating extremely low-level,
 * 		usually inner-loop information.  removed as level 3 messages.
 *              
 */
# ifdef DEBUG
#       define dprintf(dlevel,printfargs)  if (dlevel <= DEBUG ) \
						printf printfargs  
# else /* DEBUG */
#	define dprintf(a,b)
# endif /* DEBUG */
--

Arpa:	travis at cs.columbia.edu	Usenet: rutgers!columbia!travis



More information about the Comp.lang.c mailing list