Attention
TYPO3 v10 has reached end-of-life as of April 30th 2023 and is no longer being maintained. Use the version switcher on the top left of this page to select documentation for a supported version of TYPO3.
Need more time before upgrading? You can purchase Extended Long Term Support (ELTS) for TYPO3 v10 here: TYPO3 ELTS.
Autoloading¶
The autoloader takes care of finding classes in TYPO3. It is closely related to
\TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance()
which takes care of singleton
and XCLASS handling.
As a developer you should always instantiate classes either through
\TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance()
or use
Dependency Injection.
Autoloading Classes Since TYPO3 7.x¶
TYPO3 6.2 was still delivered with a couple of different autoloaders, that all had different approaches and rules to find a class. Since TYPO3 7.0, there is only a single autoloader left, the one of Composer. No matter if you run TYPO3 in Composer mode or not (Classic Mode), TYPO3 uses the Composer autoloader to resolve all class file locations.
Loading Classes Without Composer Mode¶
This means, you did not install TYPO3 via a require
statement inside your composer.json
. It's a regular old-school install where the TYPO3 source and the symlinks (typo3/index.php
) are setup manually. In this case, every time you install an extension, the autoloader scans the whole extension directory for classes. No matter if they follow any convention at all. There is just one rule. Put each class into its own file. The generated classmap is a huge array with a mapping of classnames to their location on the disk.
Example:
<?php
// autoload_classmap.php @generated by TYPO3
$typo3InstallDir = \TYPO3\CMS\Core\Core\Environment::getPublicPath();
return array(
'Schnitzler\\Templavoila\\Clipboard\\Clipboard' => $typo3InstallDir . 'typo3conf/ext/templavoila/Classes/Clipboard/Clipboard.php',
'tx_templavoila_pi1' => $typo3InstallDir . 'typo3conf/ext/templavoila/Compatibility/class.tx_templavoila_pi1.php',
...
);
This method is failsafe unless the autoload information cannot be written. In this case, check the Install Tool for warnings and make sure that typo3temp
is writable.
Troubleshooting:
If your classes cannot be found, try the following approaches.
Dump the class loading information manually with the following command:
php typo3/sysext/core/bin/typo3 dumpautoload
If that command itself fails, please (manually) uninstall the extension and simply try reinstalling it (via the Extension Manager).
If you are still not lucky, the issue is definitely on your side and you should double check the write permissions on
typo3temp
.
Loading Classes With Composer Mode¶
In composer mode, the autoloader checks for (classmap and PSR-4
) autoloading information inside your extensions' composer.json
. If you do not provide any information, the autoloader falls back to the classmap autoloading like in non composer mode.
Troubleshooting:
Dump the class loading information manually via
composer dumpautoload
and check that the autoload information is updated. Typically you would checkvendor/composer
to hold files likeautoload_classmap.php
andautoload_psr4.php
etc.
Example:
$ tree vendor/composer
.
├── ClassLoader.php
├── LICENSE
├── autoload_classmap.php
├── autoload_files.php
├── autoload_namespaces.php
├── autoload_psr4.php
├── autoload_real.php
├── autoload_static.php
├── include_paths.php
└── installed.json
Best Practices¶
If you didn't do so before, have a look at the
PSR-4
standard. It defines very good rules for naming classes and the files they reside in. Really, read the specs and start usingPSR-4
in your projects. It's unlikely that there will be any other more advanced standard in the near future in the PHP world.PSR-4
is the way to go and you should embrace it.Even if you do not use composer mode and the class mapping of the autoloader allows you to use whatever you want, stick to
PSR-4
. It's not only a very good standard to find classes, but it will also help organizing your code.PSR-4
is all about namespaces. No matter if you like namespaces or not, use them. Namespaces exist since PHP 5.3, so you will be able to use them in any modern TYPO3 project due to the minimum PHP requirements of TYPO3 itself.
Tip
PSR-4 is a standard that has been developed by the PHP Framework Interop Group (FIG). PSR-4 is an advanced standard for autoloading php classes and replaces PSR-0. If you want to know more about the PHP FIG in general and PSR-4 in specific, please visit https://www.php-fig.org/psr/psr-4/.