diff --git a/readme.md b/readme.md index 2f7da038..3bb05193 100644 --- a/readme.md +++ b/readme.md @@ -1,13 +1,19 @@ -Nette PHP Generator [![Latest Stable Version](https://poser.pugx.org/nette/php-generator/v/stable)](https://github.com/nette/php-generator/releases) [![Downloads this Month](https://img.shields.io/packagist/dm/nette/php-generator.svg)](https://packagist.org/packages/nette/php-generator) -=================== +[![Nette PHP Generator](https://github.com/nette/php-generator/assets/194960/8a2c83bd-daea-475f-994c-9c951de88501)](https://doc.nette.org/en/php-generator) + +[![Latest Stable Version](https://poser.pugx.org/nette/php-generator/v/stable)](https://github.com/nette/php-generator/releases) [![Downloads this Month](https://img.shields.io/packagist/dm/nette/php-generator.svg)](https://packagist.org/packages/nette/php-generator) Are you looking for a tool to generate PHP code for [classes](#classes), [functions](#global-functions), or complete [PHP files](#php-files)? +

+ ✅ Supports all the latest PHP features like [enums](#enums), [attributes](#attributes), etc.
✅ Allows you to easily modify [existing classes](#generating-from-existing-ones)
✅ Output compliant with [PSR-12 / PER coding style](#printer-and-psr-compliance)
✅ Highly mature, stable, and widely used library +

+ +  Installation ------------ @@ -18,8 +24,9 @@ Download and install the library using the [Composer](https://doc.nette.org/en/b composer require nette/php-generator ``` -For PHP compatibility, see the [table](#compatibility-table). Documentation even for older versions can be found on the [library's website](https://doc.nette.org/php-generator). +PhpGenerator 4.1 is compatible with PHP 8.0 to 8.3. Documentation can be found on the [library's website](https://doc.nette.org/php-generator). +  [Support Me](https://github.com/sponsors/dg) -------------------------------------------- @@ -30,6 +37,7 @@ Do you like PHP Generator? Are you looking forward to the new features? Thank you! +  Classes ------- @@ -175,6 +183,7 @@ $methodRecount = $methodCount->cloneWithName('recount'); $class->addMember($methodRecount); ``` +  Interfaces or Traits -------------------- @@ -210,6 +219,7 @@ class Demo } ``` +  Enums ----- @@ -247,6 +257,7 @@ $enum->addCase('Diamonds', '♦'); For each *case*, you can add a comment or [attributes](#attributes) using `addComment()` or `addAttribute()`. +  Anonymous Classes ----------------- @@ -272,6 +283,7 @@ $obj = new class ($val) { }; ``` +  Global Functions ---------------- @@ -298,6 +310,7 @@ function foo($a, $b) } ``` +  Anonymous Functions ------------------- @@ -325,6 +338,7 @@ function ($a, $b) use (&$c) { } ``` +  Short Arrow Functions --------------------- @@ -346,6 +360,7 @@ The result is: fn($a, $b) => $a + $b ``` +  Method and Function Signatures ------------------------------ @@ -386,6 +401,7 @@ function count(...$items) } ``` +  Method and Function Bodies -------------------------- @@ -476,6 +492,7 @@ function foo($a) } ``` +  Printer and PSR Compliance -------------------------- @@ -531,6 +548,7 @@ The standard `Printer` formats the code as we do throughout Nette. Since Nette w The major difference is the use of tabs instead of spaces. We know that by using tabs in our projects, we allow for width customization, which is [essential for people with visual impairments](https://doc.nette.org/en/contributing/coding-standard#toc-tabs-instead-of-spaces). An example of a minor difference is placing the curly brace on a separate line for functions and methods, always. The PSR recommendation seems illogical to us and [leads to reduced code clarity](https://doc.nette.org/en/contributing/coding-standard#toc-wrapping-and-braces). +  Types ----- @@ -549,6 +567,7 @@ $member->setType(null); // removes the type The same applies to the `setReturnType()` method. +  Literals -------- @@ -595,6 +614,7 @@ Literal::new(Demo::class, [$a, 'foo' => $b]); // generates for example: new Demo(10, foo: 20) ``` +  Attributes ---------- @@ -641,6 +661,7 @@ class Demo } ``` +  Namespace --------- @@ -687,6 +708,7 @@ echo $namespace->resolveName('Bar'); // 'Foo\Bar' echo $namespace->resolveName('range', $namespace::NameFunction); // 'iter\range' ``` +  Class Names Resolving --------------------- @@ -741,6 +763,7 @@ $printer->setTypeResolving(false); echo $printer->printNamespace($namespace); ``` +  PHP Files --------- @@ -790,6 +813,7 @@ function foo() **Please note:** No additional code can be added to the files outside of functions and classes. +  Generating from Existing Ones ----------------------------- @@ -818,6 +842,7 @@ $class = Nette\PhpGenerator\ClassType::from(Foo::class, withBodies: true); $function = Nette\PhpGenerator\GlobalFunction::from('foo', withBody: true); ``` +  Loading from PHP Files ---------------------- @@ -849,6 +874,7 @@ It requires `nikic/php-parser` to be installed. *(If you need to manipulate global code in files or individual statements in method bodies, it's better to use the `nikic/php-parser` library directly.)* +  Variable Dumping ---------------- @@ -862,15 +888,3 @@ $var = ['a', 'b', 123]; echo $dumper->dump($var); // outputs ['a', 'b', 123] ``` - - -Compatibility Table -------------------- - -- PhpGenerator 4.1 is compatible with PHP 8.0 to 8.3 -- PhpGenerator 4.0 is compatible with PHP 8.0 to 8.3 -- PhpGenerator 3.6 is compatible with PHP 7.2 to 8.2 -- PhpGenerator 3.2 – 3.5 is compatible with PHP 7.1 to 8.0 -- PhpGenerator 3.1 is compatible with PHP 7.1 to 7.3 -- PhpGenerator 3.0 is compatible with PHP 7.0 to 7.3 -- PhpGenerator 2.6 is compatible with PHP 5.6 to 7.3