Вход Регистрация
Файл: system/vendor/laminas/laminas-stdlib/src/AbstractOptions.php
Строк: 153
<?php

/**
 * @see       https://github.com/laminas/laminas-stdlib for the canonical source repository
 * @copyright https://github.com/laminas/laminas-stdlib/blob/master/COPYRIGHT.md
 * @license   https://github.com/laminas/laminas-stdlib/blob/master/LICENSE.md New BSD License
 */

namespace LaminasStdlib;

use 
Traversable;

abstract class 
AbstractOptions implements ParameterObjectInterface
{
    
// @codingStandardsIgnoreStart
    /**
     * We use the __ prefix to avoid collisions with properties in
     * user-implementations.
     *
     * @var bool
     */
    
protected $__strictMode__ true;
    
// @codingStandardsIgnoreEnd

    /**
     * Constructor
     *
     * @param  array|Traversable|null $options
     */
    
public function __construct($options null)
    {
        if (
null !== $options) {
            
$this->setFromArray($options);
        }
    }

    
/**
     * Set one or more configuration properties
     *
     * @param  array|Traversable|AbstractOptions $options
     * @throws ExceptionInvalidArgumentException
     * @return AbstractOptions Provides fluent interface
     */
    
public function setFromArray($options)
    {
        if (
$options instanceof self) {
            
$options $options->toArray();
        }

        if (! 
is_array($options) && ! $options instanceof Traversable) {
            throw new 
ExceptionInvalidArgumentException(
                
sprintf(
                    
'Parameter provided to %s must be an %s, %s or %s',
                    
__METHOD__,
                    
'array',
                    
'Traversable',
                    
'LaminasStdlibAbstractOptions'
                
)
            );
        }

        foreach (
$options as $key => $value) {
            
$this->__set($key$value);
        }

        return 
$this;
    }

    
/**
     * Cast to array
     *
     * @return array
     */
    
public function toArray()
    {
        
$array = [];
        
$transform = function ($letters) {
            
$letter array_shift($letters);
            return 
'_' strtolower($letter);
        };
        foreach (
$this as $key => $value) {
            if (
$key === '__strictMode__') {
                continue;
            }
            
$normalizedKey preg_replace_callback('/([A-Z])/'$transform$key);
            
$array[$normalizedKey] = $value;
        }
        return 
$array;
    }

    
/**
     * Set a configuration property
     *
     * @see ParameterObject::__set()
     * @param string $key
     * @param mixed $value
     * @throws ExceptionBadMethodCallException
     * @return void
     */
    
public function __set($key$value)
    {
        
$setter 'set' str_replace('_'''$key);

        if (
is_callable([$this$setter])) {
            
$this->{$setter}($value);

            return;
        }

        if (
$this->__strictMode__) {
            throw new 
ExceptionBadMethodCallException(sprintf(
                
'The option "%s" does not have a callable "%s" ("%s") setter method which must be defined',
                
$key,
                
'set' str_replace(' '''ucwords(str_replace('_'' '$key))),
                
$setter
            
));
        }
    }

    
/**
     * Get a configuration property
     *
     * @see ParameterObject::__get()
     * @param string $key
     * @throws ExceptionBadMethodCallException
     * @return mixed
     */
    
public function __get($key)
    {
        
$getter 'get' str_replace('_'''$key);

        if (
is_callable([$this$getter])) {
            return 
$this->{$getter}();
        }

        throw new 
ExceptionBadMethodCallException(sprintf(
            
'The option "%s" does not have a callable "%s" getter method which must be defined',
            
$key,
            
'get' str_replace(' '''ucwords(str_replace('_'' '$key)))
        ));
    }

    
/**
     * Test if a configuration property is null
     * @see ParameterObject::__isset()
     * @param string $key
     * @return bool
     */
    
public function __isset($key)
    {
        
$getter 'get' str_replace('_'''$key);

        return 
method_exists($this$getter) && null !== $this->__get($key);
    }

    
/**
     * Set a configuration property to NULL
     *
     * @see ParameterObject::__unset()
     * @param string $key
     * @throws ExceptionInvalidArgumentException
     * @return void
     */
    
public function __unset($key)
    {
        try {
            
$this->__set($keynull);
        } catch (
ExceptionBadMethodCallException $e) {
            throw new 
ExceptionInvalidArgumentException(
                
'The class property $' $key ' cannot be unset as'
                
' NULL is an invalid value for it',
                
0,
                
$e
            
);
        }
    }
}
Онлайн: 0
Реклама