Merge pull request #4498

2887bff Update coding style and add .clang-format (Pieter Wuille)
This commit is contained in:
Wladimir J. van der Laan 2014-08-06 17:17:15 +02:00
commit 8833acc4c9
No known key found for this signature in database
GPG Key ID: 74810B012346C9A6
2 changed files with 82 additions and 45 deletions

View File

@ -1,29 +1,17 @@
Coding Coding
==================== ====================
Please be consistent with the existing coding style. Various coding styles have been used during the history of the codebase,
and the result is not very consistent. However, we're now trying to converge to
Block style: a single style, so please use it in new code. Old code will be converted
```c++ gradually.
bool Function(char* psz, int n) - Basic rules specified in src/.clang-format. Use a recent clang-format-3.5 to format automatically.
{ - Braces on new lines for namespaces, classes, functions, methods.
// Comment summarising what this section of code does - Braces on the same line for everything else.
for (int i = 0; i < n; i++) - 4 space indentation (no tabs) for every block except namespaces.
{ - No indentation for public/protected/private or for namespaces.
// When something fails, return early - No extra spaces inside parenthesis; don't do ( this )
if (!Something()) - No space after function names; one space after if, for and while.
return false;
...
}
// Success return is usually at the end
return true;
}
```
- ANSI/Allman block style
- 4 space indenting, no tabs
- No extra spaces inside parenthesis; please don't do ( this )
- No space after function names, one space after if, for and while
- Includes need to be ordered alphabetically, separate own and foreign headers with a new-line (example key.cpp): - Includes need to be ordered alphabetically, separate own and foreign headers with a new-line (example key.cpp):
```c++ ```c++
#include "key.h" #include "key.h"
@ -38,31 +26,29 @@ Block style:
class CAlpha; class CAlpha;
class CBeta; class CBeta;
``` ```
- When using namespace keyword use the following form:
Block style example:
```c++ ```c++
namespace Foo { namespace foo
{
class Class
{
bool Function(char* psz, int n)
{
// Comment summarising what this section of code does
for (int i = 0; i < n; i++) {
// When something fails, return early
if (!Something())
return false;
...
}
... // Success return is usually at the end
return true;
} // Foo }
}
}
``` ```
Variable names begin with the type in lowercase, like nSomeVariable.
Please don't put the first word of the variable name in lowercase like
someVariable.
Common types:
n integer number: short, unsigned short, int, unsigned int, int64, uint64, sometimes char if used as a number
d double, float
f flag
hash uint256
p pointer or array, one p for each level of indirection
psz pointer to null terminated string
str string object
v vector or similar list objects
map map or multimap
set set or multiset
bn CBigNum
Doxygen comments Doxygen comments
----------------- -----------------

51
src/.clang-format Normal file
View File

@ -0,0 +1,51 @@
AccessModifierOffset: -4
AlignEscapedNewlinesLeft: true
AlignTrailingComments: true
AllowAllParametersOfDeclarationOnNextLine: false
AllowShortBlocksOnASingleLine: false
AllowShortFunctionsOnASingleLine: All
AllowShortIfStatementsOnASingleLine: false
AllowShortLoopsOnASingleLine: false
AlwaysBreakBeforeMultilineStrings: false
AlwaysBreakTemplateDeclarations: true
BinPackParameters: false
BreakBeforeBinaryOperators: false
BreakBeforeBraces: Linux
BreakBeforeTernaryOperators: false
BreakConstructorInitializersBeforeComma: false
ColumnLimit: 0
CommentPragmas: '^ IWYU pragma:'
ConstructorInitializerAllOnOneLineOrOnePerLine: false
ConstructorInitializerIndentWidth: 4
ContinuationIndentWidth: 4
Cpp11BracedListStyle: true
DerivePointerAlignment: false
DisableFormat: false
ForEachMacros: [ foreach, Q_FOREACH, BOOST_FOREACH, BOOST_REVERSE_FOREACH ]
IndentCaseLabels: false
IndentFunctionDeclarationAfterType: false
IndentWidth: 4
KeepEmptyLinesAtTheStartOfBlocks: false
Language: Cpp
MaxEmptyLinesToKeep: 2
NamespaceIndentation: None
ObjCSpaceAfterProperty: false
ObjCSpaceBeforeProtocolList: false
PenaltyBreakBeforeFirstCallParameter: 1
PenaltyBreakComment: 300
PenaltyBreakFirstLessLess: 120
PenaltyBreakString: 1000
PenaltyExcessCharacter: 1000000
PenaltyReturnTypeOnItsOwnLine: 200
PointerAlignment: Left
SpaceBeforeAssignmentOperators: true
SpaceBeforeParens: ControlStatements
SpaceInEmptyParentheses: false
SpacesBeforeTrailingComments: 1
SpacesInAngles: false
SpacesInContainerLiterals: true
SpacesInCStyleCastParentheses: false
SpacesInParentheses: false
Standard: Cpp03
TabWidth: 8
UseTab: Never