1
0
mirror of https://github.com/moparisthebest/curl synced 2025-01-11 05:58:01 -05:00

CODE_STYLE: mention return w/o parens, but sizeof with

... and remove the github markdown syntax so that it renders better on
the web site. Also, don't use back-ticks inlined to allow the CSS to
highlight source code better.
This commit is contained in:
Daniel Stenberg 2018-05-14 10:19:52 +02:00
parent 13505dcb55
commit 07b9826541
No known key found for this signature in database
GPG Key ID: 5CC908FDB71E12C2

View File

@ -9,8 +9,8 @@ style is more important than individual contributors having their own personal
tastes satisfied. tastes satisfied.
Our C code has a few style rules. Most of them are verified and upheld by the Our C code has a few style rules. Most of them are verified and upheld by the
`lib/checksrc.pl` script. Invoked with `make checksrc` or even by default by "lib/checksrc.pl" script. Invoked with "make checksrc" or even by default by
the build system when built after `./configure --enable-debug` has been used. the build system when built after "./configure --enable-debug" has been used.
It is normally not a problem for anyone to follow the guidelines, as you just It is normally not a problem for anyone to follow the guidelines, as you just
need to copy the style already used in the source code and there are no need to copy the style already used in the source code and there are no
@ -44,8 +44,8 @@ open brace.
## Comments ## Comments
Since we write C89 code, `//` comments are not allowed. They weren't Since we write C89 code, **//** comments are not allowed. They weren't
introduced in the C standard until C99. We use only `/*` and `*/` comments: introduced in the C standard until C99. We use only **/* comments */**.
/* this is a comment */ /* this is a comment */
@ -87,8 +87,8 @@ For functions the opening brace should be on a separate line:
## 'else' on the following line ## 'else' on the following line
When adding an `else` clause to a conditional expression using braces, we add When adding an **else** clause to a conditional expression using braces, we
it on a new line after the closing brace. Like this: add it on a new line after the closing brace. Like this:
if(age < 40) { if(age < 40) {
/* clearly a youngster */ /* clearly a youngster */
@ -149,8 +149,8 @@ and NEVER:
## Space around operators ## Space around operators
Please use spaces on both sides of operators in C expressions. Postfix `(), Please use spaces on both sides of operators in C expressions. Postfix **(),
[], ->, ., ++, --` and Unary `+, - !, ~, &` operators excluded they should [], ->, ., ++, --** and Unary **+, - !, ~, &** operators excluded they should
have no space. have no space.
Examples: Examples:
@ -167,63 +167,71 @@ Examples:
complement = ~bits; complement = ~bits;
empty = (!*string) ? TRUE : FALSE; empty = (!*string) ? TRUE : FALSE;
## No parentheses for return values
We use the 'return' statement without extra parentheses around the value:
int works(void)
{
return TRUE;
}
## Parentheses for sizeof arguments
When using the sizeof operator in code, we prefer it to be written with
parentheses around its argument:
int size = sizeof(int);
## Column alignment ## Column alignment
Some statements cannot be completed on a single line because the line would Some statements cannot be completed on a single line because the line would be
be too long, the statement too hard to read, or due to other style guidelines too long, the statement too hard to read, or due to other style guidelines
above. In such a case the statement will span multiple lines. above. In such a case the statement will span multiple lines.
If a continuation line is part of an expression or sub-expression then you If a continuation line is part of an expression or sub-expression then you
should align on the appropriate column so that it's easy to tell what part of should align on the appropriate column so that it's easy to tell what part of
the statement it is. Operators should not start continuation lines. In other the statement it is. Operators should not start continuation lines. In other
cases follow the 2-space indent guideline. Here are some examples from libcurl: cases follow the 2-space indent guideline. Here are some examples from
libcurl:
~~~c
if(Curl_pipeline_wanted(handle->multi, CURLPIPE_HTTP1) && if(Curl_pipeline_wanted(handle->multi, CURLPIPE_HTTP1) &&
(handle->set.httpversion != CURL_HTTP_VERSION_1_0) && (handle->set.httpversion != CURL_HTTP_VERSION_1_0) &&
(handle->set.httpreq == HTTPREQ_GET || (handle->set.httpreq == HTTPREQ_GET ||
handle->set.httpreq == HTTPREQ_HEAD)) handle->set.httpreq == HTTPREQ_HEAD))
/* didn't ask for HTTP/1.0 and a GET or HEAD */ /* didn't ask for HTTP/1.0 and a GET or HEAD */
return TRUE; return TRUE;
~~~
~~~c If no parenthesis, use the default indent:
case CURLOPT_KEEP_SENDING_ON_ERROR:
data->set.http_keep_sending_on_error = (0 != va_arg(param, long)) ?
TRUE : FALSE;
break;
~~~
~~~c
data->set.http_disable_hostname_check_before_authentication = data->set.http_disable_hostname_check_before_authentication =
(0 != va_arg(param, long)) ? TRUE : FALSE; (0 != va_arg(param, long)) ? TRUE : FALSE;
~~~
~~~c Function invoke with an open parenthesis:
if(option) {
result = parse_login_details(option, strlen(option),
(userp ? &user : NULL),
(passwdp ? &passwd : NULL),
NULL);
}
~~~
~~~c if(option) {
DEBUGF(infof(data, "Curl_pp_readresp_ %d bytes of trailing " result = parse_login_details(option, strlen(option),
"server response left\n", (userp ? &user : NULL),
(int)clipamount)); (passwdp ? &passwd : NULL),
~~~ NULL);
}
Align with the "current open" parenthesis:
DEBUGF(infof(data, "Curl_pp_readresp_ %d bytes of trailing "
"server response left\n",
(int)clipamount));
## Platform dependent code ## Platform dependent code
Use `#ifdef HAVE_FEATURE` to do conditional code. We avoid checking for Use **#ifdef HAVE_FEATURE** to do conditional code. We avoid checking for
particular operating systems or hardware in the #ifdef lines. The HAVE_FEATURE particular operating systems or hardware in the #ifdef lines. The HAVE_FEATURE
shall be generated by the configure script for unix-like systems and they are shall be generated by the configure script for unix-like systems and they are
hard-coded in the config-[system].h files for the others. hard-coded in the config-[system].h files for the others.
We also encourage use of macros/functions that possibly are empty or defined We also encourage use of macros/functions that possibly are empty or defined
to constants when libcurl is built without that feature, to make the code to constants when libcurl is built without that feature, to make the code
seamless. Like this style where the `magic()` function works differently seamless. Like this example where the **magic()** function works differently
depending on a build-time conditional: depending on a build-time conditional:
#ifdef HAVE_MAGIC #ifdef HAVE_MAGIC