2019-11-18 17:54:24 +13:00
---
title: Coding conventions
summary: The style guidelines we follow in all of our open source code
iconBrand: php
---
2011-02-07 19:48:44 +13:00
# Coding Conventions
This document provides guidelines for code formatting and documentation
to developers contributing to SilverStripe. It applies to all PHP files
2012-03-25 10:16:59 +13:00
in the framework/ and cms/ modules, as well as any supported additional modules.
2011-02-07 19:48:44 +13:00
Coding standards are an important aspect for every software project,
and facilitate collaboration by making code more consistent and readable.
If you are unsure about a specific standard, imitate existing SilverStripe code.
## File Formatting
### Indentation
Always use hard tabs rather then spaces for indentation, with one tab per nesting level.
### Maximum Line Length
2013-03-12 23:00:41 +13:00
The target line length is 100 columns with tabs being treated as four columns,
meaning developers should strive keep each line of their code
under 80 columns where possible and practical.
2011-02-07 19:48:44 +13:00
However, longer lines are acceptable in some circumstances.
2013-03-12 23:00:41 +13:00
The maximum length of any line of PHP code is 120 columns.
2011-02-07 19:48:44 +13:00
### Line Termination
Line termination follows the Unix text file convention. Lines must end with a single linefeed (LF) character.
Linefeed characters are represented as ordinal 10, or hexadecimal 0x0A.
Note: Do not use carriage returns (CR) as is the convention in Apple OS's (0x0D) or the carriage return -
linefeed combination (CRLF) as is standard for the Windows OS (0x0D, 0x0A).
## Naming Conventions
Class, function, variable and constant names may only contain alphanumeric characters and underscores.
### Classes
Class and filenames are in `UpperCamelCase` format:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
class MyClass {}
2019-11-18 17:54:24 +13:00
```
2013-03-12 23:00:41 +13:00
new word must be capitalized. Successive capitalized letters are used in
acronyms, e.g. a class `XMLImporter` is used while `XmlImporter` is not.
2011-02-07 19:48:44 +13:00
### Methods
Static methods should be in `lowercase_with_underscores()` format:
2019-11-18 17:54:24 +13:00
```php
2012-01-30 23:13:42 +01:00
public static function my_static_method() {}
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
This is because they go into the controller URL in the same format (eg, `home/successfullyinstalled` ).
Method names are allowed to contain underscores here, in order to allow URL parts with dashes
(`mypage\my-action` gets translated to `my_action()` automatically).
2019-11-18 17:54:24 +13:00
```php
2012-01-30 23:13:42 +01:00
public function mycontrolleraction() {}
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
Alternatively, `$this->getUpperCamelCase()` will work the same way in templates -
you can access both coding styles as `$UpperCamelCase` .
Other instance methods should be in `$this->lowerCamelCase()` format:
2019-11-18 17:54:24 +13:00
```php
2012-01-30 23:13:42 +01:00
public function myInstanceMethod() {}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
### Variables
Static variables should be `self::$lowercase_with_underscores`
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
self::$my_static_variable = 'foo';
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```php
2012-01-30 23:13:42 +01:00
$this->myMemberVariable = 'foo';
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
### Constants
All letters used in a constant name must be capitalized,
while all words in a constant name must be separated by underscore characters.
2019-11-18 17:54:24 +13:00
```php
2013-03-12 23:16:22 +13:00
const INTEREST_RATE = 0.19;
2011-02-07 19:48:44 +13:00
define('INTEREST_RATE', 0.19);
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
Defining constants in the global scope with the `define` function is permitted but strongly discouraged.
### File Naming and Directory Structure
Classes need to be in a file of the same name. Multiple classes are allowed to be contained in one file,
as long as the prefix of the class equals the filename, and is separated by an underscore from the remaining name.
For example `MyClass` and `MyClass_Controller` will both need to be placed into `MyClass.php` .
Example: `mysite/code/MyClass.php`
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
< ?php
class MyClass {}
class MyClass_Controller {}
class MyClass_OtherRelatedClass {}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
2015-02-27 16:09:15 -08:00
See [directory structure ](directory_structure ) for more information.
2011-02-07 19:48:44 +13:00
## Coding Style
### PHP Code Declaration
PHP code must always be delimited by the full-form, standard PHP tags:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
< ?php
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
Short tags are never allowed. For files containing only PHP code, the closing tag must always be omitted.
It is not required by PHP, and omitting it prevents the accidental injection of trailing white space into the response.
2013-03-12 23:00:41 +13:00
Files must end with an empty new line. This prevents problems arising from the end-of-file marker appearing where other
white space is expected.
2011-02-07 19:48:44 +13:00
### Strings
#### String Literals
When a string is literal (contains no variable substitutions), the apostrophe or "single quote" should always be used to demarcate the string:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$a = 'Example String';
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
When a literal string itself contains apostrophes, it is permitted to demarcate the string with quotation marks or "double quotes".
2019-11-18 17:54:24 +13:00
```php
2015-03-07 12:32:04 +00:00
$greeting = "They said 'hello'";
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
#### String Substitution
Variable substitution is permitted using either of these forms:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$greeting = "Hello $name, welcome back!";
$greeting = "Hello {$name}, welcome back!";
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$greeting = "Hello ${name}, welcome back!";
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
Strings must be concatenated using the "." operator. A space must always be added before and after the "." operator to improve readability:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$copyright = 'SilverStripe Ltd (' . $year . ')';
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
In these cases, each successive line should be padded with white space such that the "."; operator is aligned under the "=" operator:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$sql = 'SELECT "ID", "Name" FROM "Person" '
. 'WHERE "Name" = \'Susan\' '
. 'ORDER BY "Name" ASC ';
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
#### Numerically Indexed Arrays
Negative numbers are not permitted as indices.
An indexed array may start with any non-negative number, however all base indices besides 0 are discouraged.
When declaring indexed arrays with the Array function, a trailing space must be added after each comma delimiter to improve readability:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$sampleArray = array(1, 2, 3, 'Zend', 'Studio');
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
In this case, each successive line must be padded with spaces such that beginning of each line is aligned:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$sampleArray = array(1, 2, 3, 'Zend', 'Studio',
$a, $b, $c,
56.44, $d, 500);
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
If so, it should be padded at one indentation level greater than the line containing the array declaration,
and all successive lines should have the same indentation;
the closing paren should be on a line by itself at the same indentation level as the line containing the array declaration:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$sampleArray = array(
1, 2, 3, 'Zend', 'Studio',
$a, $b, $c,
56.44, $d, 500,
);
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
this minimizes the impact of adding new items on successive lines, and helps to ensure no parse errors occur due to a missing comma.
#### Associative Arrays
When declaring associative arrays with the `array` construct, breaking the statement into multiple lines is encouraged.
In this case, each successive line must be padded with white space such that both the keys and the values are aligned:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$sampleArray = array('firstKey' => 'firstValue',
'secondKey' => 'secondValue');
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
If so, it should be padded at one indentation level greater than the line containing the array declaration,
and all successive lines should have the same indentation; the closing paren should be on a line by itself at the
same indentation level as the line containing the array declaration.
For readability, the various "=>" assignment operators should be padded such that they align.
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
$sampleArray = array(
'firstKey' => 'firstValue',
'secondKey' => 'secondValue',
);
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
No method or function invocation is allowed to have spaces directly
before or after the opening parathesis, as well as no space before the closing parenthesis.
2019-11-18 17:54:24 +13:00
```php
2012-01-30 23:13:42 +01:00
public function foo($arg1, $arg2) {} // good
public function foo ( $arg1, $arg2 ) {} // bad
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
// good
2012-01-30 23:13:42 +01:00
public function foo() {
2011-02-07 19:48:44 +13:00
// ...
}
// bad
2012-01-30 23:13:42 +01:00
public function bar()
2011-02-07 19:48:44 +13:00
{
// ...
}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
Additional arguments to the function or method must be indented one additional level beyond the function or method declaration.
A line break should then occur before the closing argument paren,
which should then be placed on the same line as the opening brace of the function
or method with one space separating the two, and at the same indentation level as the function or method declaration.
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
public function bar($arg1, $arg2, $arg3,
$arg4, $arg5, $arg6
) {
// indented code
}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
apart from the last argument.
### Control Structures
#### if/else/elseif
No control structure is allowed to have spaces directly
2013-03-12 23:17:15 +13:00
before or after the opening parenthesis, as well as no space before the closing parenthesis.
2011-02-07 19:48:44 +13:00
The opening brace and closing brace are written on the same line as the conditional statement.
Any content within the braces must be indented using a tab.
2019-11-18 17:54:24 +13:00
```php
2013-03-12 23:16:22 +13:00
if($a != 2) {
2011-02-07 19:48:44 +13:00
$a = 2;
}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
you may break the conditional into multiple lines. In such a case, break the line prior to a logic operator,
and pad the line such that it aligns under the first character of the conditional clause.
The closing paren in the conditional will then be placed on a line with the opening brace,
with one space separating the two, at an indentation level equivalent to the opening control statement.
2019-11-18 17:54:24 +13:00
```php
2013-03-12 23:16:22 +13:00
if(($a == $b)
2011-02-07 19:48:44 +13:00
& & ($b == $c)
|| (Foo::CONST == $d)
) {
$a = $d;
}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
from the conditional during later revisions. For `if` statements that include `elseif` or `else` ,
the formatting conventions are similar to the `if` construct.
The following examples demonstrate proper formatting for `if` statements with `else` and/or `elseif` constructs:
2019-11-18 17:54:24 +13:00
```php
2013-03-12 23:16:22 +13:00
if($a != 2) {
2011-02-07 19:48:44 +13:00
$a = 2;
2013-03-12 23:16:22 +13:00
} elseif($a == 3) {
2011-02-07 19:48:44 +13:00
$a = 4;
} else {
$a = 7;
}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
// good
if($a == $b) doThis();
// bad
if($a == $b) doThis();
else doThat();
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
All content within the "switch" statement must be indented using tabs.
Content under each "case" statement must be indented using an additional tab.
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
switch($numPeople) {
case 1:
break;
case 2:
break;
default:
break;
}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
#### for/foreach/while
Loop constructs follow the same principles as "Control Structures: if/else/elseif".
### Separation of Logic and Presentation
Try to avoid using PHP's ability to mix HTML into the code.
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
// PHP code
2012-01-30 23:13:42 +01:00
public function getTitle() {
2011-02-07 19:48:44 +13:00
return "< h2 > Bad Example< / h2 > ";
}
// Template code
$Title
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
// PHP code
2012-01-30 23:13:42 +01:00
public function getTitle() {
2011-02-07 19:48:44 +13:00
return "Better Example";
}
// Template code
< h2 > $Title< / h2 >
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
Use [phpdoc ](http://phpdoc.org/ ) syntax before each definition (see [tutorial ](http://manual.phpdoc.org/HTMLSmartyConverter/HandS/phpDocumentor/tutorial_phpDocumentor.quickstart.pkg.html )
and [tag overview ](http://manual.phpdoc.org/HTMLSmartyConverter/HandS/phpDocumentor/tutorial_tags.pkg.html )).
* All class definitions and PHP files should have `@package` and `@subpackage` .
* Methods should include at least `@param` and `@return` .
* Include a blank line after the description.
* Use `{@link MyOtherClass}` and `{@link MyOtherClass->otherMethod}` for inline references.
* Denote preformatted code examples in `<code></code>` blocks.
* Always start block-level comments containing phpdoc with two asterisks (`/** ... */` ).
Example:
2019-11-18 17:54:24 +13:00
```php
2011-02-07 19:48:44 +13:00
/**
* My short description for this class.
* My longer description with
* multiple lines and richer formatting.
*
* Usage:
* < code >
* $c = new MyClass();
* $c->myMethod();
* </ code >
*
* @package custom
*/
class MyClass extends Class {
/**
* My Method.
* This method returns something cool. {@link MyParentMethod} has other cool stuff in it.
*
* @param string $colour The colour of cool things that you want
2012-06-23 00:32:43 +02:00
* @return DataList A list of everything cool
2011-02-07 19:48:44 +13:00
*/
public function myMethod($foo) {}
}
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
### Class Member Ordering
Put code into the classes in the following order (where applicable).
* Static variables
2012-01-30 23:13:42 +01:00
* Member variables
2011-02-07 19:48:44 +13:00
* Static methods
* Data-model definition static variables. (`$db` , `$has_one` , `$many_many` , etc)
* Commonly used methods like `getCMSFields()`
* Accessor methods (`getMyField()` and `setMyField()` )
* Controller action methods
2013-04-26 11:48:59 +02:00
* Template data-access methods (methods that will be called by a `$MethodName` or `<% loop $MethodName %>` construct in a template somewhere)
2011-02-07 19:48:44 +13:00
* Object methods
### SQL Format
2015-04-15 13:08:39 +10:00
If you have to use raw SQL, make sure your code works across databases. Make sure you escape your queries like below,
2013-06-21 10:32:08 +12:00
with the column or table name escaped with double quotes as below.
2019-11-18 17:54:24 +13:00
```php
2013-06-21 10:32:08 +12:00
MyClass::get()->where(array("\"Score\" > ?" => 50));
2019-11-18 17:54:24 +13:00
```
2013-06-21 10:32:08 +12:00
to a SQL query, where values placeholders are each replaced with a single unquoted question mark.
If it's absolutely necessary to use literal values in a query make sure that values
are single quoted.
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```php
2012-06-23 00:32:43 +02:00
MyClass::get()->where("\"Title\" = 'my title'");
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
### Secure Development
2016-01-14 23:59:53 +13:00
See [security ](/developer_guides/security ) for conventions related to handing security permissions.
2011-02-07 19:48:44 +13:00
## License
Parts of these coding conventions were adapted from [Zend Framework ](http://framework.zend.com/manual/en/coding-standard.overview.html ),
2012-03-25 10:16:59 +13:00
which are licensed under BSD (see [license ](http://framework.zend.com/license )).
2012-05-16 11:38:20 +02:00
## Related
2015-02-27 16:09:15 -08:00
* [Reference: CMS Architecture ](/developer_guides/customising_the_admin_interface/cms_architecture )