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

Dave Gotwisner dig at peritek.UUCP
Fri May 4 14:47:41 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.
> 
> The obvious way to do this is:
> 
> #ifdef DEBUG
> 	printf ("debugging information");
> #endif DEBUG
> 
> But its a pain to have to type the #ifdef ... #endif all the time, and
> its less readable than simply having:
>
> 	DEBUG ("debugging information");

Agreed.

> 
> Now, I can use the latter format if I
> 
> #define DEBUG printf
> 
> but then how do I turn DEBUG off?

Having read some of the other responses, I have yet to see the one I use:

#ifdef DEBUG
# define	Dprintf	printf
#else
# define	Dprintf if
#endif

This only needs to be included in a common header file,  then, if you do:

	Dprintf("Input value is %d\n", 10);

you get the following if DEBUG is defined:

	printf("Input value is %d\n", 10);

and the following if DEBUG is not defined:

	if ("Input value is %d\n", 10);

The semicolon will terminate the if, so, unless the debug printf has an
else immediatly after it, this will work.  There is some run time overhead
(unless your compiler optimizes "if (statement);" away because it never does
anything), but the overhead should be small.
-- 
------------------------------------------------------------------------------
Dave Gotwisner					UUCP:  ...!unisoft!peritek!dig
Peritek Corporation				       ...!vsi1!peritek!dig
5550 Redwood Road
Oakland, CA 94619				Phone: 1-415-531-6500



More information about the Comp.lang.c mailing list