Skip to content

Code Style Guide: PHP

ginatrapani edited this page Sep 13, 2010 · 20 revisions

This is the Code Style guide for PHP. See the main Code Style Guide page for other languages.

Assume we’re using the Drupal PHP coding style unless otherwise noted here.

Always use <?php to delimit PHP code, not the shorthand, <?, as this is the most used and supported across PHP setups and the one PHP will continue supporting in the future.

Use PHP5 Conventions

When in doubt, use PHP5 (not PHP4) coding conventions.

  • Class constructors should be public function __construct(), not the PHP4-style class name. Use destructors when appropriate.
  • Explicitly declare visibility (public, private, protected) for member variables and methods.
  • Do NOT use PHP closing tags for files that contain only PHP code:

The ?> at the end of code files is purposely omitted. This includes for module and include files. … Removing it eliminates the possibility for unwanted whitespace at the end of files which can cause “header already sent” errors, XHTML/XML validation issues, and other problems.

Maximum Line Length: 120 characters

The maximum length of any line of code is 120 characters, unless it contains a string that should not have a break in it. (This differs from Drupal’s 80-character maximum length.)

Tip: Add a ruler to the 120 mark in Eclipse to see where you should break to the next line. See Developer Guide: Setting Up Eclipse PDT for how.

Include Docblocks on All New Code

Thinktank uses PHPDocumentor to ease code maintenance and auto-generate class documentation. Include PHPDoc-style “docblocks” in all of your PHP code. When writing your documentation, please use PHPDocumentor’s syntax.

Keyword case

Drupal style guide states use of uppercase value keywords (TRUE, FALSE, NULL), ThinkTank user lowercase.

MVC Architecture

ThinkTank implements the Model-View-Controller design pattern. All new PHP code should follow suit. Read more about ThinkTank’s MVC implementation.

Drupal conventions to take notice of

Some of these are inherited from PEAR:

  • When constructing multi line IFs, the boolean operator should be at the beginning of the line, not the end.
Clone this wiki locally