jonathanguo / code-generator
Code Generator
Installs: 27 449
Dependents: 2
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
This package is auto-updated.
Last update: 2025-01-08 04:37:07 UTC
README
This package is a shameless copy of krlove/code-generator. It does the job but looks like the author is not actively maintaining the package any longer. When I cloned the repo on 20th December 2018, there is an issue and two PRs are not responded since 2017.
Also another reason is I need the code generator to generate some code with custom styles. The requirements might not be general cares. So I decided to duplicate the repo rather than fork it.
Code generator
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 jonathanguo/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 JonathanGuo\CodeGenerator\Model\ArgumentModel; use JonathanGuo\CodeGenerator\Model\ClassModel; use JonathanGuo\CodeGenerator\Model\ConstantModel; use JonathanGuo\CodeGenerator\Model\ClassNameModel; use JonathanGuo\CodeGenerator\Model\DocBlockModel; use JonathanGuo\CodeGenerator\Model\MethodModel; use JonathanGuo\CodeGenerator\Model\NamespaceModel; use JonathanGuo\CodeGenerator\Model\PropertyModel; use JonathanGuo\CodeGenerator\Model\UseTraitModel; use JonathanGuo\CodeGenerator\Model\UseClassModel; use JonathanGuo\CodeGenerator\Model\VirtualMethodModel; use JonathanGuo\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 = ; 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'; } }
If you don't want to generate class/properties DocBlock, you can turn it off by
$phpClass->setGenerateClassDocBlock(false);