Skip to content

Commit

Permalink
readme: added jumbo
Browse files Browse the repository at this point in the history
  • Loading branch information
dg committed May 16, 2024
1 parent 690b00d commit fe7afa9
Showing 1 changed file with 29 additions and 15 deletions.
44 changes: 29 additions & 15 deletions readme.md
Original file line number Diff line number Diff line change
@@ -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)?

<h2>

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

</h2>

 <!---->

Installation
------------
Expand All @@ -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)
--------------------------------------------
Expand All @@ -30,6 +37,7 @@ Do you like PHP Generator? Are you looking forward to the new features?

Thank you!

 <!---->

Classes
-------
Expand Down Expand Up @@ -175,6 +183,7 @@ $methodRecount = $methodCount->cloneWithName('recount');
$class->addMember($methodRecount);
```

 <!---->

Interfaces or Traits
--------------------
Expand Down Expand Up @@ -210,6 +219,7 @@ class Demo
}
```

 <!---->

Enums
-----
Expand Down Expand Up @@ -247,6 +257,7 @@ $enum->addCase('Diamonds', '♦');

For each *case*, you can add a comment or [attributes](#attributes) using `addComment()` or `addAttribute()`.

 <!---->

Anonymous Classes
-----------------
Expand All @@ -272,6 +283,7 @@ $obj = new class ($val) {
};
```

 <!---->

Global Functions
----------------
Expand All @@ -298,6 +310,7 @@ function foo($a, $b)
}
```

 <!---->

Anonymous Functions
-------------------
Expand Down Expand Up @@ -325,6 +338,7 @@ function ($a, $b) use (&$c) {
}
```

 <!---->

Short Arrow Functions
---------------------
Expand All @@ -346,6 +360,7 @@ The result is:
fn($a, $b) => $a + $b
```

 <!---->

Method and Function Signatures
------------------------------
Expand Down Expand Up @@ -386,6 +401,7 @@ function count(...$items)
}
```

 <!---->

Method and Function Bodies
--------------------------
Expand Down Expand Up @@ -476,6 +492,7 @@ function foo($a)
}
```

 <!---->

Printer and PSR Compliance
--------------------------
Expand Down Expand Up @@ -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
-----
Expand All @@ -549,6 +567,7 @@ $member->setType(null); // removes the type

The same applies to the `setReturnType()` method.

 <!---->

Literals
--------
Expand Down Expand Up @@ -595,6 +614,7 @@ Literal::new(Demo::class, [$a, 'foo' => $b]);
// generates for example: new Demo(10, foo: 20)
```

 <!---->

Attributes
----------
Expand Down Expand Up @@ -641,6 +661,7 @@ class Demo
}
```

 <!---->

Namespace
---------
Expand Down Expand Up @@ -687,6 +708,7 @@ echo $namespace->resolveName('Bar'); // 'Foo\Bar'
echo $namespace->resolveName('range', $namespace::NameFunction); // 'iter\range'
```

 <!---->

Class Names Resolving
---------------------
Expand Down Expand Up @@ -741,6 +763,7 @@ $printer->setTypeResolving(false);
echo $printer->printNamespace($namespace);
```

 <!---->

PHP Files
---------
Expand Down Expand Up @@ -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
-----------------------------
Expand Down Expand Up @@ -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
----------------------
Expand Down Expand Up @@ -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
----------------
Expand All @@ -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

0 comments on commit fe7afa9

Please sign in to comment.