Benutzer-Werkzeuge

Webseiten-Werkzeuge


dev:all:psr-0de

Dies ist eine alte Version des Dokuments!


im englischen Original von PHP-FIG PSR-0

Autoloading Standard

Im Folgenden werden die verbindlichen Anforderungen, die für die Interoperabilität der Autoloader eingehalten werden müssen beschrieben.

Verbindliches

  • Ein voll qualifizierter Namensraum und Klassenname muss die folgende Struktur haben: \<Vendor Name>\(<Namespace>\)*<Class Name>
  • Jeder Namensraum muss einen Top-Level Namensraum („Vendor Name“) haben.
  • Jeder Namensraum kann beliebig viele Unter-Namensräume definieren.
  • Jeder Namensraum-Trenner wird beim Laden vom Dateisystem in einen DIRECTORY_SEPARATOR konvertiert.
  • Jeder _ im Klassennamen wird zu einem DIRECTORY_SEPARATOR konvertiert. :!: Anpassung für WB: Der _ hat keine spezielle Bedeutung in der normalen Definition eines Namensraumes, bei Pseudo-Namensräumen (siehe PSR-1) wird er jedoch in einen DIRECTORY_SEPERATOR umgewandelt, was in diesem Fall Ordnernamen mit _ verbietet.
  • Der voll qualifizierte Namensraum und Klassennamen wird beim Zugriff auf das Dateisystem um die Endung .php ergänzt.
  • Alphabetische Zeichen (A-Z) in Vendornamen, Namensräumen und Klassen können jede beliebige Kombination aus Gross- und Kleinbuchstaben sein. :!: In PSR-1 wird dieses noch eingeschränkt!

Beispiele

  \Doctrine\Common\IsolatedClassLoader => /path/to/project/lib/vendor/Doctrine/Common/IsolatedClassLoader.php
  \Symfony\Core\Request                => /path/to/project/lib/vendor/Symfony/Core/Request.php
  \Zend\Acl                            => /path/to/project/lib/vendor/Zend/Acl.php
  \Zend\Mail\Message                   => /path/to/project/lib/vendor/Zend/Mail/Message.php

Unterstriche in Namensräumen and Klassennamen

  \namespace\package\Class_Name      => /path/to/project/lib/vendor/namespace/package/Class/Name.php
  \namespace\package_name\Class_Name => /path/to/project/lib/vendor/namespace/package_name/Class/Name.php

The standards we set here should be the lowest common denominator for painless autoloader interoperability. You can test that you are following these standards by utilizing this sample SplClassLoader implementation which is able to load PHP 5.3 classes.

dev/all/psr-0de.1407831510.txt.gz · Zuletzt geändert: 03.06.2015 15:50 (Externe Bearbeitung)