mirror of https://github.com/BOINC/boinc.git
177 lines
4.4 KiB
PHP
177 lines
4.4 KiB
PHP
|
<?php
|
||
|
require_once("docutil.php");
|
||
|
page_head("BOINC coding style");
|
||
|
echo "
|
||
|
<h2> All languages</h2>
|
||
|
<h3> Code factoring</h3>
|
||
|
<ul>
|
||
|
<li> if code is repeated, factor it out and make it into a function
|
||
|
<li> if a function becomes longer than 100 lines or so, split it up
|
||
|
<li> C++ .h files often contain both interface and implementation.
|
||
|
Clearly divide these.
|
||
|
</ul>
|
||
|
|
||
|
<h3> code documentation</h3>
|
||
|
<ul>
|
||
|
<li> every .C file has a comment at the top saying what's
|
||
|
in the file (and perhaps what isn't).
|
||
|
If a file is becoming 'landfill', split it up.
|
||
|
<li> every function is preceded by a comment saying what it does
|
||
|
<li> every struct/class is preceded by a comment saying what it is
|
||
|
</ul>
|
||
|
|
||
|
<h3> Naming</h3>
|
||
|
<ul>
|
||
|
<li> Names should be descriptive without being verbose
|
||
|
(local variables names may be short)
|
||
|
<li> Class names, #defined symbols, and type names are all upper case,
|
||
|
with underscores to separate words.
|
||
|
<li> Variable and function names are all lower case,
|
||
|
with underscores to separate words.
|
||
|
<li> no mixed case names
|
||
|
</ul>
|
||
|
|
||
|
<h3> Indentation</h3>
|
||
|
<ul>
|
||
|
<li> Each level of indentation is 4 spaces (not a tab).
|
||
|
<li> multi-line function call:
|
||
|
<pre>
|
||
|
func(
|
||
|
blah, blah, blah, blah, blah,
|
||
|
blah, blah, blah, blah, blah
|
||
|
);
|
||
|
</pre>
|
||
|
<li> switch statements: case labels are at same indent level as switch
|
||
|
<pre>
|
||
|
switch (foo) {
|
||
|
case 1:
|
||
|
...
|
||
|
break;
|
||
|
case 2:
|
||
|
...
|
||
|
break;
|
||
|
}
|
||
|
</pre>
|
||
|
</ul>
|
||
|
|
||
|
<h3> Constants</h3>
|
||
|
<ul>
|
||
|
There should be few numeric constants in code.
|
||
|
Generally they should be #defines
|
||
|
</ul>
|
||
|
|
||
|
<h3> Braces</h3>
|
||
|
<ul>
|
||
|
<li> Opening curly brace goes at end of line (not next line):
|
||
|
<pre>
|
||
|
if (foobar) {
|
||
|
...
|
||
|
} else if (blah) {
|
||
|
...
|
||
|
} else {
|
||
|
...
|
||
|
}
|
||
|
</pre>
|
||
|
<li> always use curly braces on multi-line if statements
|
||
|
<pre>
|
||
|
if (foo)
|
||
|
return blah; // WRONG
|
||
|
</pre>
|
||
|
<li> 1-line if() statments are OK:
|
||
|
<pre>
|
||
|
if (foo) return blah;
|
||
|
</pre>
|
||
|
</ul>
|
||
|
|
||
|
<h3> comments and #ifdefs</h3>
|
||
|
<ul>
|
||
|
<li> use // for all comments
|
||
|
<li> comment out blocks of code as follows:
|
||
|
<pre>
|
||
|
#if 0
|
||
|
...
|
||
|
#endif
|
||
|
</pre>
|
||
|
</ul>
|
||
|
|
||
|
<h2> C++ specific</h2>
|
||
|
<h3> Includes</h3>
|
||
|
<ul>
|
||
|
<li> A .C file should have the minimum set of #includes to get
|
||
|
that particular file to compile
|
||
|
(e.g. the includes needed by foo.C should be in foo.C, not foo.h)
|
||
|
<li> Includes should go from general (<stdio.h>) to specific (thisfile.h)
|
||
|
</ul>
|
||
|
<h3> extern declarations</h3>
|
||
|
<ul>
|
||
|
foo.h should have 'extern' declarations for all public
|
||
|
functions and variables in foo.C
|
||
|
There should be no 'extern' statements in .C files.
|
||
|
</ul>
|
||
|
|
||
|
<h3> Use of static</h3>
|
||
|
<ul>
|
||
|
<li> if a function or variable is used only in 1 file, declare it static.
|
||
|
</ul>
|
||
|
|
||
|
<h3> Things to avoid unless there's a truly compelling reason:</h3>
|
||
|
<ul>
|
||
|
<li> inline functions
|
||
|
<li> operator or function overloading
|
||
|
<li> templates
|
||
|
</ul>
|
||
|
<h3> Things to avoid</h3>
|
||
|
<ul>
|
||
|
<li> use typedef (not #define) to define types
|
||
|
<li> don't use memset() or memcpy() to initialize or copy classes
|
||
|
that are non-C compatible.
|
||
|
Write a default constructor and a copy constructor.
|
||
|
</ul>
|
||
|
<h3> error codes</h3>
|
||
|
<ul>
|
||
|
<li> (almost) all functions should return an integer error code.
|
||
|
Nonzero means error.
|
||
|
<li> All calls to functions that return an error code should
|
||
|
check the code. Generally they should return on error, e.g.:
|
||
|
<pre>
|
||
|
retval = blah();
|
||
|
if (retval) return retval;
|
||
|
</pre>
|
||
|
</ul>
|
||
|
|
||
|
<h3> structure definitions</h3>
|
||
|
<ul>
|
||
|
Define structures as follows:
|
||
|
<pre>
|
||
|
|
||
|
struct FOO {
|
||
|
...
|
||
|
};
|
||
|
</pre>
|
||
|
|
||
|
You can then declare variables as:
|
||
|
|
||
|
<pre>
|
||
|
FOO x;
|
||
|
</pre>
|
||
|
</ul>
|
||
|
|
||
|
|
||
|
<h2> PHP specific</h2>
|
||
|
|
||
|
<h3>Getting POST and GET data</h3>
|
||
|
Remember that hackers can pass arbitrary values in POST and GET,
|
||
|
and they can use this to do SQL injections and other exploits.
|
||
|
<ul>
|
||
|
<li> Do not access \$_POST or \$_GET directly.
|
||
|
<li> Use get_int(), get_str(), post_int() and post_str()
|
||
|
(from util.inc) to get POST and GET data.
|
||
|
<li> If a POST or GET value will be used in a SQL query,
|
||
|
use process_user_text() to escape it.
|
||
|
</ul>
|
||
|
";
|
||
|
|
||
|
page_tail();
|
||
|
|
||
|
?>
|