3v4l.org

run code in 300+ PHP versions simultaneously
<?php $errored = FALSE; set_error_handler(function ($errno, $errstr) use (&$errored) { $errored = TRUE; return TRUE; }); $excludedClasses = [ // These cause fatal errors on instantiation "Closure", "SQLite3", "Filter", "PDO" ]; var_dump( array_filter( get_declared_classes(), function ($className) use (&$errored, $excludedClasses) { $errored = FALSE; $class = new ReflectionClass($className); $constructor = $class->getMethod('__construct'); $constructor->setAccessible(true); if (!$class->isInstantiable() || $class->hasMethod('__construct') && $constructor->isPrivate()) { return FALSE; } foreach ($excludedClasses as $bannedClass) { if (substr($className, 0, strlen($bannedClass)) === $bannedClass) { return FALSE; } } if (!(new ReflectionClass($className))->hasMethod('__toString')) { try { $x = new $className; $x = (string)$x; return !$errored; } catch (Exception $e) { return FALSE; } } return FALSE; } ) );
Output for 8.2.0 - 8.2.18, 8.3.0 - 8.3.4, 8.3.6
Fatal error: Uncaught ReflectionException: Method Generator::__construct() does not exist in /in/5hmho:20 Stack trace: #0 /in/5hmho(20): ReflectionClass->getMethod('__construct') #1 [internal function]: {closure}('Generator') #2 /in/5hmho(15): array_filter(Array, Object(Closure)) #3 {main} thrown in /in/5hmho on line 20
Process exited with code 255.
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 Fatal error: Uncaught ReflectionException: Method Generator::__construct() does not exist in /in/5hmho:20 Stack trace: #0 /in/5hmho(20): ReflectionClass->getMethod('__construct') #1 [internal function]: {closure}('Generator') #2 /in/5hmho(15): array_filter(Array, Object(Closure)) #3 {main} thrown in /in/5hmho on line 20
Process exited with code 255.
Output for 8.0.0 - 8.0.30, 8.1.0 - 8.1.27
Fatal error: Uncaught ReflectionException: Method stdClass::__construct() does not exist in /in/5hmho:20 Stack trace: #0 /in/5hmho(20): ReflectionClass->getMethod('__construct') #1 [internal function]: {closure}('stdClass') #2 /in/5hmho(41): array_filter(Array, Object(Closure)) #3 {main} thrown in /in/5hmho on line 20
Process exited with code 255.
Output for 7.0.0 - 7.0.20, 7.1.0 - 7.1.20, 7.2.0 - 7.2.33, 7.3.16 - 7.3.33, 7.4.0 - 7.4.33
Fatal error: Uncaught ReflectionException: Method __construct does not exist in /in/5hmho:20 Stack trace: #0 /in/5hmho(20): ReflectionClass->getMethod('__construct') #1 [internal function]: {closure}('stdClass') #2 /in/5hmho(41): array_filter(Array, Object(Closure)) #3 {main} thrown in /in/5hmho on line 20
Process exited with code 255.
Output for 5.4.0 - 5.4.45, 5.5.24 - 5.5.35, 5.6.8 - 5.6.28
Fatal error: Uncaught exception 'ReflectionException' with message 'Method __construct does not exist' in /in/5hmho:20 Stack trace: #0 /in/5hmho(20): ReflectionClass->getMethod('__construct') #1 [internal function]: {closure}('stdClass') #2 /in/5hmho(42): array_filter(Array, Object(Closure)) #3 {main} thrown in /in/5hmho on line 20
Process exited with code 255.
Output for 5.3.0 - 5.3.29
Parse error: syntax error, unexpected '[' in /in/5hmho on line 7
Process exited with code 255.
Output for 4.4.2 - 4.4.9, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17
Parse error: syntax error, unexpected T_FUNCTION, expecting ')' in /in/5hmho on line 5
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1, 5.0.0 - 5.0.5
Parse error: parse error, unexpected T_FUNCTION, expecting ')' in /in/5hmho on line 5
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error, expecting `')'' in /in/5hmho on line 5
Process exited with code 255.

preferences:
251.1 ms | 401 KiB | 311 Q