grottopress / setter
Set private object attributes directly, without calling setter methods.
Installs: 16
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/grottopress/setter
Requires
- php: >=7.0
Requires (Dev)
README
Description
Setter allows you to set private object attributes directly, without calling setter methods.
For example, instead of calling $myObject->setMyAttr($newValue), you can just do $myObject->myAttr = $newValue. Under the hood, Setter sets your attribute by calling a private setMyAttr() method that you define in your class.
This way, you get the benefit of syntactic sugar, while maintaining encapsulation.
Installation
Install via composer:
composer require grottopress/setter
Usage
Import trait into your class, and use thus:
<?php declare (strict_types = 1); namespace Vendor; use GrottoPress\Setter\SetterTrait; class MyClass { /** * Import trait */ use SetterTrait; private $changeMe; private $leaveMeAlone; /** * Define your private setter method * Method name should be of the format "set{$attrName}" */ private function setChangeMe($newValue) { $this->changeMe = $newValue; } // ... } // Instantiate $object = new Vendor\MyClass(); // Try to set attributes $object->changeMe = 'New Me!'; // => Works! $object->leaveMeAlone = 'xyz'; // => Error: 'setLeaveMeAlone()' not defined
Development
Run tests with composer run test.
Contributing
- Fork it
- Switch to the
masterbranch:git checkout master - Create your feature branch:
git checkout -b my-new-feature - Make your changes, updating changelog and documentation as appropriate.
- Commit your changes:
git commit - Push to the branch:
git push origin my-new-feature - Submit a new Pull Request against the
GrottoPress:masterbranch.