grottopress/getter

Get private object attributes directly, without calling getter methods.

v1.0.0 2023-05-31 15:18 UTC

This package is auto-updated.

Last update: 2024-04-23 13:58:22 UTC


README

Description

Getter allows you to get private object attributes directly, without calling getter methods.

For example, instead of calling $myObject->getMyAttr(), you can just do $myObject->myAttr. Under the hood, Getter gets your attribute by calling a private getMyAttr() 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/getter

Usage

Import trait into your class, and use thus:

<?php
declare (strict_types = 1);

namespace Vendor;

use GrottoPress\Getter\GetterTrait;

class MyClass
{
    /**
     * Import trait
     */
    use GetterTrait;

    private $haveMe;
    private $leaveMeAlone;

    public function __construct()
    {
        $this->haveMe = 'Hello :-)';
        $this->leaveMeAlone = 'Go away!';
    }

    /**
     * Define your private getter method
     * Method name should be of the format "get{$attrName}"
     */
    private function getHaveMe(): string
    {
        return $this->haveMe;
    }

    // ...
}

// Instantiate
$object = new Vendor\MyClass();

// Try to get attributes
echo $object->haveMe; // => Hello :-)
echo $object->leaveMeAlone; // => Error: 'getLeaveMeAlone()' not defined
echo $object->nonExistent; // => Exception: 'nonExistent' does not exist

Development

Run tests with composer run test.

Contributing

  1. Fork it
  2. Switch to the master branch: git checkout master
  3. Create your feature branch: git checkout -b my-new-feature
  4. Make your changes, updating changelog and documentation as appropriate.
  5. Commit your changes: git commit
  6. Push to the branch: git push origin my-new-feature
  7. Submit a new Pull Request against the GrottoPress:master branch.