From df08855d80de49a57f17e4928e1a5e30a1d3f3e0 Mon Sep 17 00:00:00 2001 From: Fred Cox Date: Tue, 9 Jul 2019 16:39:24 +0300 Subject: [PATCH] Add some php examples using modern language features --- spec/visual/samples/php | 103 +++++++++++++++++++++++++++++++++++----- 1 file changed, 91 insertions(+), 12 deletions(-) diff --git a/spec/visual/samples/php b/spec/visual/samples/php index 79bc91bb8a..245fb5fab7 100644 --- a/spec/visual/samples/php +++ b/spec/visual/samples/php @@ -27,6 +27,89 @@ echo $ΔΔ; "thing {$thing->other_thing()}" +function &byref() { + $x = array(); + return $x; +} + +trait SomeTrait { + // Some visibility + const PUBLIC_CONST_A = 1; + public const PUBLIC_CONST_B = 2; + protected const PROTECTED_CONST = 3; + private const PRIVATE_CONST = 4; + + function afunc(string $arg, SomeInterface $arg2, callable $arg3, object $arg4): void { + echo "hello"; + if (1 <=> 1) { + echo "yep!"; + } + } +} + +interface SomeInterface { + function interfaceFunc(bool $arg): iterable; + function nullableTypes(?bool $arg): ?iterable; +} + +//Anonymous class example +$app->setLogger(new class implements Logger { + public function log(string $msg) { + echo $msg; + } +}); + +// some uses +use some\namespace\ClassA; +use some\namespace\ClassB; +use some\namespace\ClassC as C; + +use function some\namespace\fn_a; +use function some\namespace\fn_b; +use function some\namespace\fn_c; + +use const some\namespace\ConstA; +use const some\namespace\ConstB; +use const some\namespace\ConstC; + +// Grouped uses +use some\namespace\{ClassA, ClassB, ClassC as C}; +use function some\namespace\{fn_a, fn_b, fn_c}; +use const some\namespace\{ConstA, ConstB, ConstC}; + +namespace some\namespace; + +// A generator +$gen = (function() { + yield 1; + yield 2; + + return 3; +})(); + +// descructuring +// list() style +list($id1, $name1) = $data[0]; + +// [] style +[$id1, $name1] = $data[0]; + +// heredoc +$a = <<files as $name => $file) { // Get values $content = $file[0]; - + // File part // Reset file data $fd = ''; - + // Detect possible compressions // Use deflate if(function_exists('gzdeflate')) { @@ -209,7 +292,7 @@ class Zip extends Archive { // File data $fd .= $compressed_data; - + // Data descriptor $fd .= pack("V", crc32($content)); // crc-32 $fd .= pack("V", strlen($compressed_data)); // Compressed size @@ -291,11 +374,11 @@ class Zip extends Archive { // Return content? if(!$filename) return $data; - + // Write to file return file_put_contents($filename, $data); } - + /** * Load a zip file * @@ -323,7 +406,7 @@ class Zip extends Archive { // Read the zip return $this->load_string($content, $reset); } - + /** * Load a zip string * @@ -523,9 +606,5 @@ class Zip extends Archive { } } -function &byref() { - $x = array(); - return $x; -} ?>

it's html here at the end, too.