- Always use Unix line endings.
- Lines should not be longer than 150 characters.
- Don't use PHP Short open tags, except the short echo tags.
- The PHP open tag should be on a line by itself.
- Use 4 spaces for indentation. NO TABS.
- Every scope change has a new 4 space indentation
- Every file should have a closing PHP tag
- All PHP files must end with a non-blank line, terminated with a single LF.
- When variables are assigned on multiple consecutive lines, the equals signs should be aligned.
- There should never be a space preceding a semicolon.
- Empty lines should not have whitespace.
- There should never be multiple successive empty lines.
- Lines should never end in whitespace.
- PHP language constructs must be followed by a single whitespace.
- The header section in every file is categorized in blocks. Each block needs to be grouped together and separated by an empty line from the next block.
- Blocks in the header section need to be in this order:
- Opening PHP tag
- File-level docblock
- Declare statements
- Namespace declaration
- Class-based use imports
- Function-based use imports
- Constant-based use imports
- There must not be a space before the colon of a function return type declaration.
- There must be one space after the colon of a function return type declaration.
- Arrays should always use the short syntax.
- Arrays spanning multiple lines need to have 1 value per line.
- Associative arrays spanning multiple lines needs to have their key, values and double arrows aligned. With at least one space on either side of the double arrow.
- In multi line arrays each line needs to end in a comma, including the last one.
- In multi line arrays the closing bracket needs to be on its own line, in line with the indentation of the start of the declaration.
- Single line arrays need one space separating each bracket from the values.
$items = [ 'item', 'more' ];
$config = [
'field' => 'fieldB',
'search' => '0',
'replace' => 'b',
];
- All constants names should be in all uppercase
- Use snake case naming for functions and variables, unless otherwise dictated by libraries or other external influences.
- Class naming should be in Pascal case.
- All files should have a file comment
- All classes should have a class comment
- All functions should have a function comment with a description, a list of parameters (with type, name and description) and a return, but no type hints in the function.
- In the argument list, there must not be a space before each comma, and there must be one space after each comma.
- Function declarations must follow the "BSD/Allman style". The function brace is on the line following the function declaration and is indented to the same column as the start of the function declaration.
- Functions must always have visibility defined (public, protected, private); abstract and final MUST be declared before the visibility; static MUST be declared after the visibility
- There must be an empty line before and after each function in a class.
- There must be a single space after the scope keyword.
- The closing bracket must be directly after the body.
- All function keywords must be lowercase.
- Closures must have one space between the
function
keyword and the opening bracket, one space before and after theuse
keyword and one space before the curly bracket of the body - If the closure body is empty, there must be no space between the curly brackets. If it is not empty there must be one space after the opening and before the closing curly bracket
- Arrow functions must have no space between the
fn
keyword and the opening bracket, and a space before and after the=>
- Make sure there are no spaces directly after the opening bracket or before the closing bracket.
- Each line in a multi-line IF statement must begin with a boolean operator
- First condition of a multi-line IF statement must directly follow the opening parenthesis.
- Closing parenthesis of a multi-line IF statement must be on a new line.
- Always use elseif over else if.
- All control structure keywords must be lowercase.
- Control structure bracket spacing should be according to psr-2/#5-control-structures
- Classes must have their opening bracket on a new line and not have it indented.
- There must be a single space after the scope keyword.
- All class keywords must be lowercase.
- There must be only one class declaration per file
- Use declarations should be according to PSR-2 psr-2/#3-namespace-and-use-declarations
- Use imports should be sorted alphabetically
- All classes from other namespaces should be referenced through use statements
- Classes from the same namespace should not be referenced through use statements
- Always have one space preceding and succeeding the concatenation symbol.
- There must be one space before and after a logical operator.
- All operators should have one space surrounding them.
- There should be one space after a cast operator.
- There should be no spaces between a variable and the increment/decrement operators.
- There should be no spaces after the spread operator.
- Some function aliases should not be used.
- Use count instead of sizeof
- Use unset instead of delete
- Functions that are deprecated in PHP should not be used.
- Only ever use include_once in conditionals and use require_once otherwise.
- Nullable type declarations must not have a space between the question mark and the type name.
- Use short versions of types:
- Use int instead of integer
- Use bool instead of boolean
- String concatenation should not be used if the string could be written as one string.
- Double quotes should only be used when required, always use single quotes instead.
- Never use the logical "and" and "or" operators.
- Never use the backtick operator.
- Classes must use a PHP5 style constructor.
- Class constants must have visibility declared.
- Empty functions should contain a //NO-OP comment.
- Use of call-time pass-by-reference is not allowed.
- Use of Yoda conditions is not allowed
- Guard clauses should be used where possible to return from functions early