Subject: Re: CVS commit: syssrc/sys/arch/pmax/pmax
To: Robert Elz <kre@munnari.OZ.AU>
From: John Nemeth <jnemeth@victoria.tc.ca>
List: source-changes
Date: 12/05/2001 06:57:59
On Apr 22,  6:29pm, Robert Elz wrote:
}     Date:        Fri, 30 Nov 2001 09:34:22 +0100
}     From:        Lennart Augustsson <lennart@augustsson.net>
} 
}   | > There's a number of places in the kernel where we assume that an
}   | > undefined flag == 0 in preprocessor expressions, some of them to test
}   | > if just one of the tokens is defined.  Is it actaully _abuse_ of the
}   | > preprocessor, or defined(!) behaviour?
}   | 
}   | Well, in the past it has always been abuse.
} 
} No it isn't
} 
} 	#undef thing
} 
} 	#if thing > 1
} 
} has always been interpreted as "#if 0 > 1"
} 
} I think K&R (2, #if didn't exist in K&R 1 I don't think) might have even
} said so, but my copy isn't here for me to check.

     I dug out my copy of K&R2.  In Section A12.5 (Conditional
Compilation) on page 232 it says, "Any identifiers remaining after
macro expansion are replaced by 0L."  So you are correct, it isn't
abuse.

}-- End of excerpt from Robert Elz