X-Authentication-Warning: delorie.com: mailnull set sender to djgpp-bounces using -f
Message-ID: <3C2B5F81.F4FCC6FA@acm.org>
From: Eric Sosman <esosman AT acm DOT org>
X-Mailer: Mozilla 4.72 [en] (Win95; U)
X-Accept-Language: en
MIME-Version: 1.0
Newsgroups: comp.os.msdos.djgpp
Subject: Re: DJGPP: #define problems
References: <daed704d DOT 0112271423 DOT 309fcdeb AT posting DOT google DOT com>
Content-Type: text/plain; charset=us-ascii
Content-Transfer-Encoding: 7bit
Lines: 53
Date: Thu, 27 Dec 2001 22:49:59 GMT
NNTP-Posting-Host: 12.91.4.93
X-Complaints-To: abuse AT worldnet DOT att DOT net
X-Trace: bgtnsc06-news.ops.worldnet.att.net 1009493399 12.91.4.93 (Thu, 27 Dec 2001 22:49:59 GMT)
NNTP-Posting-Date: Thu, 27 Dec 2001 22:49:59 GMT
Organization: AT&T Worldnet
To: djgpp AT delorie DOT com
DJ-Gateway: from newsgroup comp.os.msdos.djgpp
Reply-To: djgpp AT delorie DOT com

Matt wrote:
> [...]
> #include <stdio.h>
> #define BASEVAL1    233
> #define BASEVAL2    BASEVAL1 + 29
> #define BASEVAL3    233
> #define BASEVAL4    BASEVAL1 + 57
> 
> int main(void)
> {
>    printf("baseval1 [233] = %d\n", BASEVAL1);
>    printf("baseval2 [262] = %d\n\n", BASEVAL2);
>    printf("baseval3 [233] = %d\n", BASEVAL3);
>    printf("baseval4 [290] = %d\n\n", BASEVAL4);
> 
>    /* up to this point the define's are ok but when the math is done
> on
>       the next line it seems to be treating the result as an unsigned
> char
>       data type. */
>    printf("baseval4 - baseval2 [28] = %d\n\n", BASEVAL4 - BASEVAL2);

    The #define doesn't perform any math at all; it simply arranges to
replace each subsequent appearance of the macro name with its
definition.
The expression `BASEVAL4 - BASEVAL2' becomes `BASEVAL1 + 57 - BASEVAL1 +
29'
which in turn becomes `233 + 57 - 233 + 29'.  No more macro names
remain,
so the compiler evaluates the resulting expression and (presumably) gets
86 as a result.

    This is one of the reasons people recommend surrounding non-atomic
macro definitions with parentheses, e.g.

	#define BASEVAL1 233
	#define BASEVAL2 (BASEVAL1 + 29)
	#define BASEVAL3 233
	#define BASEVAL4 (BASEVAL1 + 57)

The parentheses are part of the macro definition and hence part of the
replacement, so the first step in expanding `BASEVAL4 - BASEVAL2' is
`(BASEVAL1 + 57) - (BASEVAL1 + 29)', quite a different expression from
the one you originally obtained.  Another example where the parens
make a crucial difference is `2 * BASEVAL2', or `BASEVAL2 * BASEVAL4',
and so forth.

    By the way, did you really mean to define BASEVAL4 in terms of
BASEVAL1 rather than BASEVAL3?

-- 
Eric Sosman
esosman AT acm DOT org