3v4l.org

run code in 300+ PHP versions simultaneously
<?php $url = ''; /** @var non-empty-string|null $s */ function take_non_empty_string_or_null(?string $s): void { echo (string) $s; } function take_any_string(string $s): void { echo $s; } function take_an_int_or_null(?int $s): void { echo (int) $s; } /** * @param array{path: string} $arr */ function take_url(array $arr): void { foreach($arr as $v) { if (null !== $v) { take_any_string($v); } } } var_dump(parse_url($url)); // array{} take_non_empty_string_or_null(parse_url($url, PHP_URL_SCHEME)); // null|non-empty-string take_non_empty_string_or_null(parse_url($url, PHP_URL_USER)); // null|non-empty-string take_non_empty_string_or_null(parse_url($url, PHP_URL_PASS)); // null|non-empty-string take_non_empty_string_or_null(parse_url($url, PHP_URL_HOST)); // null|non-empty-string take_an_int_or_null(parse_url($url, PHP_URL_PORT)); // null|int take_any_string(parse_url($url, PHP_URL_PORT)); // string take_non_empty_string_or_null(parse_url($url, PHP_URL_PATH)); // null|non-empty-string take_non_empty_string_or_null(parse_url($url, PHP_URL_QUERY)); // null|non-empty-string take_non_empty_string_or_null(parse_url($url, PHP_URL_FRAGMENT)); // null|non-empty-string
Output for git.master_jit, git.master, rfc.property-hooks
array(1) { ["path"]=> string(0) "" } 0 Fatal error: Uncaught TypeError: take_any_string(): Argument #1 ($s) must be of type string, null given, called in /in/KIeQB on line 35 and defined in /in/KIeQB:10 Stack trace: #0 /in/KIeQB(35): take_any_string(NULL) #1 {main} thrown in /in/KIeQB on line 10
Process exited with code 255.

This tab shows result from various feature-branches currently under review by the php developers. Contact me to have additional branches featured.

Active branches

Archived branches

Once feature-branches are merged or declined, they are no longer available. Their functionality (when merged) can be viewed from the main output page


preferences:
66.49 ms | 406 KiB | 5 Q