170 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			170 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
 | 
						|
/*
 | 
						|
 * This file is part of the Symfony package.
 | 
						|
 *
 | 
						|
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
						|
 *
 | 
						|
 * For the full copyright and license information, please view the LICENSE
 | 
						|
 * file that was distributed with this source code.
 | 
						|
 */
 | 
						|
 | 
						|
namespace Symfony\Component\PropertyAccess;
 | 
						|
 | 
						|
use Psr\Cache\CacheItemPoolInterface;
 | 
						|
 | 
						|
/**
 | 
						|
 * A configurable builder to create a PropertyAccessor.
 | 
						|
 *
 | 
						|
 * @author Jérémie Augustin <jeremie.augustin@pixel-cookers.com>
 | 
						|
 */
 | 
						|
class PropertyAccessorBuilder
 | 
						|
{
 | 
						|
    private $magicCall = false;
 | 
						|
    private $throwExceptionOnInvalidIndex = false;
 | 
						|
    private $throwExceptionOnInvalidPropertyPath = true;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var CacheItemPoolInterface|null
 | 
						|
     */
 | 
						|
    private $cacheItemPool;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enables the use of "__call" by the PropertyAccessor.
 | 
						|
     *
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function enableMagicCall()
 | 
						|
    {
 | 
						|
        $this->magicCall = true;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disables the use of "__call" by the PropertyAccessor.
 | 
						|
     *
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function disableMagicCall()
 | 
						|
    {
 | 
						|
        $this->magicCall = false;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @return bool whether the use of "__call" by the PropertyAccessor is enabled
 | 
						|
     */
 | 
						|
    public function isMagicCallEnabled()
 | 
						|
    {
 | 
						|
        return $this->magicCall;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enables exceptions when reading a non-existing index.
 | 
						|
     *
 | 
						|
     * This has no influence on writing non-existing indices with PropertyAccessorInterface::setValue()
 | 
						|
     * which are always created on-the-fly.
 | 
						|
     *
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function enableExceptionOnInvalidIndex()
 | 
						|
    {
 | 
						|
        $this->throwExceptionOnInvalidIndex = true;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disables exceptions when reading a non-existing index.
 | 
						|
     *
 | 
						|
     * Instead, null is returned when calling PropertyAccessorInterface::getValue() on a non-existing index.
 | 
						|
     *
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function disableExceptionOnInvalidIndex()
 | 
						|
    {
 | 
						|
        $this->throwExceptionOnInvalidIndex = false;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @return bool whether an exception is thrown or null is returned when reading a non-existing index
 | 
						|
     */
 | 
						|
    public function isExceptionOnInvalidIndexEnabled()
 | 
						|
    {
 | 
						|
        return $this->throwExceptionOnInvalidIndex;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enables exceptions when reading a non-existing property.
 | 
						|
     *
 | 
						|
     * This has no influence on writing non-existing indices with PropertyAccessorInterface::setValue()
 | 
						|
     * which are always created on-the-fly.
 | 
						|
     *
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function enableExceptionOnInvalidPropertyPath()
 | 
						|
    {
 | 
						|
        $this->throwExceptionOnInvalidPropertyPath = true;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disables exceptions when reading a non-existing index.
 | 
						|
     *
 | 
						|
     * Instead, null is returned when calling PropertyAccessorInterface::getValue() on a non-existing index.
 | 
						|
     *
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function disableExceptionOnInvalidPropertyPath()
 | 
						|
    {
 | 
						|
        $this->throwExceptionOnInvalidPropertyPath = false;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @return bool whether an exception is thrown or null is returned when reading a non-existing property
 | 
						|
     */
 | 
						|
    public function isExceptionOnInvalidPropertyPath()
 | 
						|
    {
 | 
						|
        return $this->throwExceptionOnInvalidPropertyPath;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets a cache system.
 | 
						|
     *
 | 
						|
     * @return PropertyAccessorBuilder The builder object
 | 
						|
     */
 | 
						|
    public function setCacheItemPool(CacheItemPoolInterface $cacheItemPool = null)
 | 
						|
    {
 | 
						|
        $this->cacheItemPool = $cacheItemPool;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the used cache system.
 | 
						|
     *
 | 
						|
     * @return CacheItemPoolInterface|null
 | 
						|
     */
 | 
						|
    public function getCacheItemPool()
 | 
						|
    {
 | 
						|
        return $this->cacheItemPool;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Builds and returns a new PropertyAccessor object.
 | 
						|
     *
 | 
						|
     * @return PropertyAccessorInterface The built PropertyAccessor
 | 
						|
     */
 | 
						|
    public function getPropertyAccessor()
 | 
						|
    {
 | 
						|
        return new PropertyAccessor($this->magicCall, $this->throwExceptionOnInvalidIndex, $this->cacheItemPool, $this->throwExceptionOnInvalidPropertyPath);
 | 
						|
    }
 | 
						|
}
 |