File structure

TYPO3 files use the following structure:

  1. Opening PHP tag (including strict_types declaration)
  2. Copyright notice
  3. Namespace
  4. Namespace imports
  5. Class information block in phpDoc format
  6. PHP class
  7. Optional module execution code

The following sections discuss each of these parts.

Namespace

The namespace declaration of each PHP file in the TYPO3 Core shows where the file belongs inside TYPO3. The namespace starts with \TYPO3\CMS, then the extension name in UpperCamelCase, a backslash and then the name of the subfolder of Classes/, in which the file is located (if any). E.g. the file typo3/sysext/frontend/Classes/ContentObject/ContentObjectRenderer.php with the class ContentObjectRenderer is in the namespace \TYPO3\CMS\Frontend\ContentObject.

use statements can be added to this section.

Namespace imports

Necessary PHP classes should be imported like explained in the TYPO3 Coding Standards, (based on PER-CS1.0 / PSR-12 at the time of this writing, transitioning towards PER-CS2.0):

EXT:some_extension/Classes/SomeClass.php
use TYPO3\CMS\Core\Utility\GeneralUtility;
use TYPO3\CMS\Core\Utility\HttpUtility;
use TYPO3\CMS\Core\Cache\Backend\BackendInterface;
Copied!

Put one blank line before and after import statements. Also put one import statement per line.

Class information block

The class information block provides basic information about the class in the file. It should include a description of the class. Example:

EXT:some_extension/Classes/SomeClass.php
/**
 * This class provides XYZ plugin implementation.
 */
Copied!

PHP class

The PHP class follows the class information block. PHP code must be formatted as described in chapter "PHP syntax formatting".

The class name is expected to follow some conventions. It must be identical to the file name and must be written in upper camel case.

The PHP class declaration looks like the following:

EXT:some_extension/Classes/SomeClass.php
class SomeClass extends AbstractBackend implements BackendInterface
{
    // ...
}
Copied!

Optional module execution code

Module execution code instantiates the class and runs its method(s). Typically this code can be found in eID scripts and old Backend modules. Here is how it may look like:

EXT:some_extension/Classes/SomeClass.php
$someClass = GeneralUtility::makeInstance(SomeClass::class);
$someClass->main();
Copied!

This code must appear after the PHP class.