115 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			115 lines
		
	
	
		
			4.5 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;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Writes and reads values to/from an object/array graph.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @author Bernhard Schussek <bschussek@gmail.com>
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								interface PropertyAccessorInterface
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Sets the value at the end of the property path of the object graph.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * Example:
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     *     use Symfony\Component\PropertyAccess\PropertyAccess;
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     *     $propertyAccessor = PropertyAccess::createPropertyAccessor();
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     *     echo $propertyAccessor->setValue($object, 'child.name', 'Fabien');
							 | 
						||
| 
								 | 
							
								     *     // equals echo $object->getChild()->setName('Fabien');
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * This method first tries to find a public setter for each property in the
							 | 
						||
| 
								 | 
							
								     * path. The name of the setter must be the camel-cased property name
							 | 
						||
| 
								 | 
							
								     * prefixed with "set".
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * If the setter does not exist, this method tries to find a public
							 | 
						||
| 
								 | 
							
								     * property. The value of the property is then changed.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * If neither is found, an exception is thrown.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param object|array                 $objectOrArray The object or array to modify
							 | 
						||
| 
								 | 
							
								     * @param string|PropertyPathInterface $propertyPath  The property path to modify
							 | 
						||
| 
								 | 
							
								     * @param mixed                        $value         The value to set at the end of the property path
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @throws Exception\InvalidArgumentException If the property path is invalid
							 | 
						||
| 
								 | 
							
								     * @throws Exception\AccessException          If a property/index does not exist or is not public
							 | 
						||
| 
								 | 
							
								     * @throws Exception\UnexpectedTypeException  If a value within the path is neither object nor array
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function setValue(&$objectOrArray, $propertyPath, $value);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Returns the value at the end of the property path of the object graph.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * Example:
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     *     use Symfony\Component\PropertyAccess\PropertyAccess;
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     *     $propertyAccessor = PropertyAccess::createPropertyAccessor();
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     *     echo $propertyAccessor->getValue($object, 'child.name');
							 | 
						||
| 
								 | 
							
								     *     // equals echo $object->getChild()->getName();
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * This method first tries to find a public getter for each property in the
							 | 
						||
| 
								 | 
							
								     * path. The name of the getter must be the camel-cased property name
							 | 
						||
| 
								 | 
							
								     * prefixed with "get", "is", or "has".
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * If the getter does not exist, this method tries to find a public
							 | 
						||
| 
								 | 
							
								     * property. The value of the property is then returned.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * If none of them are found, an exception is thrown.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param object|array                 $objectOrArray The object or array to traverse
							 | 
						||
| 
								 | 
							
								     * @param string|PropertyPathInterface $propertyPath  The property path to read
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return mixed The value at the end of the property path
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @throws Exception\InvalidArgumentException If the property path is invalid
							 | 
						||
| 
								 | 
							
								     * @throws Exception\AccessException          If a property/index does not exist or is not public
							 | 
						||
| 
								 | 
							
								     * @throws Exception\UnexpectedTypeException  If a value within the path is neither object
							 | 
						||
| 
								 | 
							
								     *                                            nor array
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function getValue($objectOrArray, $propertyPath);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Returns whether a value can be written at a given property path.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * Whenever this method returns true, {@link setValue()} is guaranteed not
							 | 
						||
| 
								 | 
							
								     * to throw an exception when called with the same arguments.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param object|array                 $objectOrArray The object or array to check
							 | 
						||
| 
								 | 
							
								     * @param string|PropertyPathInterface $propertyPath  The property path to check
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return bool Whether the value can be set
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @throws Exception\InvalidArgumentException If the property path is invalid
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function isWritable($objectOrArray, $propertyPath);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Returns whether a property path can be read from an object graph.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * Whenever this method returns true, {@link getValue()} is guaranteed not
							 | 
						||
| 
								 | 
							
								     * to throw an exception when called with the same arguments.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param object|array                 $objectOrArray The object or array to check
							 | 
						||
| 
								 | 
							
								     * @param string|PropertyPathInterface $propertyPath  The property path to check
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return bool Whether the property path can be read
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @throws Exception\InvalidArgumentException If the property path is invalid
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function isReadable($objectOrArray, $propertyPath);
							 | 
						||
| 
								 | 
							
								}
							 |