58 lines
2.0 KiB
Plaintext
58 lines
2.0 KiB
Plaintext
|
|
||
|
Over time, I am moving all of the IPFilter code to what I consider a better
|
||
|
coding style than it had before. If you submit patches, I expect them to
|
||
|
conform as appropriate.
|
||
|
|
||
|
Function Comments
|
||
|
=================
|
||
|
Preceeding each and every function, a comment block like this should
|
||
|
be present:
|
||
|
|
||
|
/* ------------------------------------------------------------------------ */
|
||
|
/* Function: function-name */
|
||
|
/* Returns: return-type */
|
||
|
/* Parameters: param1(I) - param1 is an input parameter */
|
||
|
/* p2(O) - p2 is an output parameter passed as an arg */
|
||
|
/* par3(IO) - par3 is a parameter which is both input and */
|
||
|
/* output. Pointers to things which are used and */
|
||
|
/* then get a result stored in them qualify here. */
|
||
|
/* */
|
||
|
/* Description about what the function does. This comment should explain */
|
||
|
/* any gotchas or algorithms that are used which aren't obvious to the */
|
||
|
/* casual reader. It should not be an excuse to not use comments inside */
|
||
|
/* the function. */
|
||
|
/* ------------------------------------------------------------------------ */
|
||
|
|
||
|
|
||
|
Tab spacing
|
||
|
===========
|
||
|
Tabs are to be at 8 characters.
|
||
|
|
||
|
|
||
|
Conditions
|
||
|
==========
|
||
|
All expressions which evaluate to a boolean for a test condition, such as
|
||
|
in an if()/while() statement must involve a boolean operation. Since C
|
||
|
has no native boolean type, this means that one of <,>,<=,>=,==,!= must
|
||
|
be present. Implied boolean evaluations are out.
|
||
|
|
||
|
In code, the following is banned:
|
||
|
|
||
|
if (x)
|
||
|
if (!x)
|
||
|
while ((a = b))
|
||
|
|
||
|
and should be replaced by:
|
||
|
|
||
|
if (x != 0)
|
||
|
if (x == 0)
|
||
|
while ((a = b) != 0)
|
||
|
|
||
|
If pointers are involved, always compare with NULL, ie.:
|
||
|
|
||
|
if (x != NULL)
|
||
|
if (x == NULL)
|
||
|
while ((a = b) != NULL)
|
||
|
|
||
|
|