cwssrl / code-generator
Forked Code Generator
1.0.6
2022-06-17 16:33 UTC
Requires
- php: ^7.2|^8.0
Requires (Dev)
- phpunit/phpunit: ^8.5
- squizlabs/php_codesniffer: ^3.5
This package is auto-updated.
Last update: 2024-10-17 22:27:16 UTC
README
Code generator is a PHP tool that provides an interface for generating code. Currently only PHP class generation is supported.
Installation
Require the package using composer composer require cwssrl/code-generator --dev
. Code generator is usually intended to be installed only in dev environment. Installation in prod environment is not recommended.
Usage example
<?php use Cws\CodeGenerator\Model\ArgumentModel; use Cws\CodeGenerator\Model\ClassModel; use Cws\CodeGenerator\Model\ConstantModel; use Cws\CodeGenerator\Model\ClassNameModel; use Cws\CodeGenerator\Model\DocBlockModel; use Cws\CodeGenerator\Model\MethodModel; use Cws\CodeGenerator\Model\NamespaceModel; use Cws\CodeGenerator\Model\PropertyModel; use Cws\CodeGenerator\Model\UseTraitModel; use Cws\CodeGenerator\Model\UseClassModel; use Cws\CodeGenerator\Model\VirtualMethodModel; use Cws\CodeGenerator\Model\VirtualPropertyModel; require 'vendor/autoload.php'; $phpClass = new ClassModel(); $phpClass->setNamespace(new NamespaceModel('NamespaceOfTheClass')); $name = new ClassNameModel('TestClass', 'BaseTestClass'); $name->addImplements('\\NamespaceOne\\InterfaceOne'); $phpClass->addUses(new UseClassModel('NamespaceTwo')); $name->addImplements('InterfaceTwo'); $phpClass->setName($name); $phpClass->addTrait(new UseTraitModel('TraitOne')); $phpClass->addTrait(new UseTraitModel('TraitTwo')); $phpClass->addConstant(new ConstantModel('CONST_ONE', 'value')); $phpClass->addConstant(new ConstantModel('CONST_TWO', 1)); $phpClass->addProperty(new PropertyModel('propertyOne')); $phpClass->addProperty(new PropertyModel('propertyTwo', 'protected')); $privateProperty = new PropertyModel('propertyThree', 'private', 'defaultValue'); $privateProperty->setDocBlock(new DocBlockModel('@var string')); $phpClass->addProperty($privateProperty); $phpClass->addProperty(new VirtualPropertyModel('virtualPropertyOne', 'int')); $phpClass->addProperty(new VirtualPropertyModel('virtualPropertyTwo', 'mixed')); $phpClass->addMethod(new MethodModel('methodOne')); $phpClass->addMethod(new MethodModel('methodTwo', 'protected')); $privateMethod = new MethodModel('methodThree', 'private'); $privateMethod->addArgument(new ArgumentModel('arg1')); $privateMethod->addArgument(new ArgumentModel('arg2', 'array', 'array()')); $privateMethod->setBody('return \'result\';'); $privateMethod->setDocBlock(new DocBlockModel('@var mixed arg1', '@var array arg2', '@return string')); $phpClass->addMethod($privateMethod); $phpClass->addMethod(new VirtualMethodModel('virtualMethodOne')); $virtualMethodTwo = new VirtualMethodModel('virtualMethodTwo', 'array'); $virtualMethodTwo->addArgument(new ArgumentModel('arg1', 'array')); $phpClass->addMethod($virtualMethodTwo); echo $phpClass->render();
Output
<?php namespace NamespaceOfTheClass; use NamespaceTwo; /** * @property int $virtualPropertyOne * @property mixed $virtualPropertyTwo * @method void virtualMethodOne() * @method array virtualMethodTwo(array $arg1) */ class TestClass extends BaseTestClass implements \NamespaceOne\InterfaceOne, InterfaceTwo { use TraitOne; use TraitTwo; const CONST_ONE = 'value'; const CONST_TWO = 1; public $propertyOne; protected $propertyTwo; /** * @var string */ private $propertyThree = 'defaultValue'; public function methodOne() { } protected function methodTwo() { } /** * @var mixed arg1 * @var array arg2 * @return string */ private function methodThree($arg1, array $arg2) { return 'result'; } }
Contributing
Please see CONTRIBUTING for details.
Testing
composer test
Changelog
Please see CHANGELOG for more information what has changed recently.
Credits
This package is heavily based on Cws Code Generator that is a fork of the krlove/code-generator package
License
The MIT License (MIT). Please see License File for more information.