3v4l.org

run code in 150+ php & hhvm versions
Bugs & Features
<?php class Trigger { var $me='hello'; function __construct() { $b = Expected::kill(); echo "\n==LINE8_VARDUMP==\n"; var_dump($b); return $b; } } class Expected { var $killerMessage=null; function __construct() { $this->killerMessage = 'Oops!'; return $this; } static function kill() { return new Expected; } } $obj = new Trigger; echo "\n==LINE21_VARDUMP==\n"; var_dump($obj); //-------------------------------------- //Current Output: //==LINE8_VARDUMP== //object(Expected)#2 (1) { // ["killerMessage"]=> // string(5) "Oops!" //} // //==LINE21_VARDUMP== //object(Trigger)#1 (1) { // ["me"]=> // string(5) "hello" //} // //Expected Output: //Both VARDUMP //object(Expected)#2 (1) { // ["killerMessage"]=> // string(5) "Oops!" //} ?>
Output for 5.1.3 - 5.6.28, hhvm-3.10.0 - 3.12.0, 7.0.0 - 7.1.0
==LINE8_VARDUMP== object(Expected)#2 (1) { ["killerMessage"]=> string(5) "Oops!" } ==LINE21_VARDUMP== object(Trigger)#1 (1) { ["me"]=> string(5) "hello" }
Output for 5.0.0 - 5.1.2
Strict Standards: var: Deprecated. Please use the public/private/protected modifiers in /in/Q57RF on line 4 Strict Standards: var: Deprecated. Please use the public/private/protected modifiers in /in/Q57RF on line 16 ==LINE8_VARDUMP== object(Expected)#2 (1) { ["killerMessage"]=> string(5) "Oops!" } ==LINE21_VARDUMP== object(Trigger)#1 (1) { ["me"]=> string(5) "hello" }
Output for 4.4.2 - 4.4.9
Parse error: syntax error, unexpected T_STATIC, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/Q57RF on line 18
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.4.1
Parse error: parse error, unexpected T_STATIC, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/Q57RF on line 18
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error, expecting `T_OLD_FUNCTION' or `T_FUNCTION' or `T_VAR' or `'}'' in /in/Q57RF on line 18
Process exited with code 255.