3v4l.org

run code in 300+ PHP versions simultaneously
<?php trait CastableBehavior { public static function getFromContext($obj) { foreach (get_object_vars($obj) as $key => $value) { $this->$key = $value; } } } interface UserTypes { const USER = 1; const ADMIN = 2; const MODERATOR = 3; } class User { private $id; private $name; private $type; public function __construct($id, $name, $type) { $this->id = $id; $this->name = $name; $this->type = $type; } public function getID() { return $this->id; } public function getName() { return $this->name; } public function getType() { return $this->type; } } class Admin { use CastableBehavior; private $id; private $name; private $type; } $user = new User(2, 'John', UserTypes::ADMIN); if ($user->getType() === UserTypes::ADMIN) { $admin = Admin::getFromContext($foo); } var_dump($admin);
Output for 8.0.0 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
Warning: Undefined variable $foo in /in/XXb4i on line 50 Fatal error: Uncaught TypeError: get_object_vars(): Argument #1 ($object) must be of type object, null given in /in/XXb4i:4 Stack trace: #0 /in/XXb4i(4): get_object_vars(NULL) #1 /in/XXb4i(50): Admin::getFromContext(NULL) #2 {main} thrown in /in/XXb4i on line 4
Process exited with code 255.
Output for 5.4.0 - 5.4.45, 5.5.24 - 5.5.35, 5.6.7 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.25, 7.2.0 - 7.2.33, 7.3.0 - 7.3.31, 7.4.0 - 7.4.33
Notice: Undefined variable: foo in /in/XXb4i on line 50 Warning: get_object_vars() expects parameter 1 to be object, null given in /in/XXb4i on line 4 Warning: Invalid argument supplied for foreach() in /in/XXb4i on line 4 NULL
Output for 7.3.32 - 7.3.33
Warning: get_object_vars() expects parameter 1 to be object, null given in /in/XXb4i on line 4 Warning: Invalid argument supplied for foreach() in /in/XXb4i on line 4 NULL
Output for 4.4.2 - 4.4.9, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29
Parse error: syntax error, unexpected T_STRING in /in/XXb4i on line 2
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_STRING in /in/XXb4i on line 2
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error in /in/XXb4i on line 2
Process exited with code 255.

preferences:
196.72 ms | 401 KiB | 327 Q