<?php
class Autoloader1
{
public static function autoload ($class)
{
var_dump("Loading {$class} from " . __CLASS__);
spl_autoload_register(["Autoloader2", "autoload"]);
}
}
class Autoloader2
{
public static function autoload ($class)
{
var_dump("Loading {$class} from " . __CLASS__);exit;
}
}
spl_autoload_register(["Autoloader1", "autoload"]);
$r = new Foo();
string(28) "Loading Foo from Autoloader1"
string(28) "Loading Foo from Autoloader2"
Output for 8.3.5
Warning: PHP Startup: Unable to load dynamic library 'sodium.so' (tried: /usr/lib/php/8.3.5/modules/sodium.so (libsodium.so.23: cannot open shared object file: No such file or directory), /usr/lib/php/8.3.5/modules/sodium.so.so (/usr/lib/php/8.3.5/modules/sodium.so.so: cannot open shared object file: No such file or directory)) in Unknown on line 0
string(28) "Loading Foo from Autoloader1"
string(28) "Loading Foo from Autoloader2"
Output for 7.0.0 - 7.0.2
string(28) "Loading Foo from Autoloader1"
Fatal error: Uncaught Error: Class 'Foo' not found in /in/7gp1b:21
Stack trace:
#0 {main}
thrown in /in/7gp1b on line 21
Process exited with code 255.