drupol / anonymize
Converts an object/class into an anonymous class.
Fund package maintenance!
drupol
Requires
- php: >= 7.1.3
- drupol/dynamicobjects: ^1
Requires (Dev)
README
Anonymize
Description
Convert a regular class into an anonymous class.
Features
- Converts public properties and methods into dynamic classes and properties.
Requirements
- PHP >= 7.1.3
Installation
composer require drupol/anonymize
Usage
Using the object:
<?php include 'vendor/autoload.php'; class Hello { public $property = 'YES!'; public function say() { echo 'Hello ' . $this->world(); } private function world() { return 'world!'; } } $class = new Hello(); $class->say(); // Hello world! $anonymizedClass = \drupol\Anonymize\Anonymize::convertToAnonymous($class); $anonymizedClass::addDynamicMethod('say', function () use ($anonymizedClass) { echo 'Goodbye ' . $anonymizedClass->world(); }); $anonymizedClass::addDynamicMethod('world', function () { return 'universe!'; }); $anonymizedClass->say(); // Goodbye universe!
API
<?php /** * Convert an object into an anonymous object. * * @param \stdClass $object * The object to convert. * * @return Anonymize */ AnonymizeTrait::convertToAnonymous($object);
The rest of the library API relies and inherit from DynamicObjects.
Code quality, tests and benchmarks
Every time changes are introduced into the library, Travis CI run the tests and the benchmarks.
The library has tests written with PHPSpec.
Feel free to check them out in the spec
directory. Run composer phpspec
to trigger the tests.
Before each commit some inspections are executed with GrumPHP, run ./vendor/bin/grumphp run
to check manually.
PHPInfection is used to ensure that your code is properly tested, run composer infection
to test your code.
Contributing
Feel free to contribute to this library by sending Github pull requests. I'm quite reactive :-)