mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-02 12:49:27 +00:00
175 lines
5.2 KiB
PHP
175 lines
5.2 KiB
PHP
<?php
|
|
/**
|
|
* File containing the ezcBaseOptions class.
|
|
*
|
|
* @package Base
|
|
* @version 1.5
|
|
* @copyright Copyright (C) 2005-2008 eZ systems as. All rights reserved.
|
|
* @license http://ez.no/licenses/new_bsd New BSD License
|
|
*/
|
|
|
|
/**
|
|
* Base options class for all eZ components.
|
|
*
|
|
* @package Base
|
|
* @version 1.5
|
|
*/
|
|
abstract class ezcBaseOptions implements ArrayAccess
|
|
{
|
|
/**
|
|
* Container to hold the properties
|
|
*
|
|
* @var array(string=>mixed)
|
|
*/
|
|
protected $properties;
|
|
|
|
/**
|
|
* Construct a new options object.
|
|
* Options are constructed from an option array by default. The constructor
|
|
* automatically passes the given options to the __set() method to set them
|
|
* in the class.
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* If trying to access a non existent property.
|
|
* @throws ezcBaseValueException
|
|
* If the value for a property is out of range.
|
|
* @param array(string=>mixed) $options The initial options to set.
|
|
*/
|
|
public function __construct( array $options = array() )
|
|
{
|
|
foreach ( $options as $option => $value )
|
|
{
|
|
$this->__set( $option, $value );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Merge an array into the actual options object.
|
|
* This method merges an array of new options into the actual options object.
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* If trying to access a non existent property.
|
|
* @throws ezcBaseValueException
|
|
* If the value for a property is out of range.
|
|
* @param array(string=>mixed) $newOptions The new options.
|
|
*/
|
|
public function merge( array $newOptions )
|
|
{
|
|
foreach ( $newOptions as $key => $value )
|
|
{
|
|
$this->__set( $key, $value );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Property get access.
|
|
* Simply returns a given option.
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* If a the value for the property options is not an instance of
|
|
* @param string $propertyName The name of the option to get.
|
|
* @return mixed The option value.
|
|
* @ignore
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* if the given property does not exist.
|
|
* @throws ezcBasePropertyPermissionException
|
|
* if the property to be set is a write-only property.
|
|
*/
|
|
public function __get( $propertyName )
|
|
{
|
|
if ( $this->__isset( $propertyName ) === true )
|
|
{
|
|
return $this->properties[$propertyName];
|
|
}
|
|
throw new ezcBasePropertyNotFoundException( $propertyName );
|
|
}
|
|
|
|
/**
|
|
* Sets an option.
|
|
* This method is called when an option is set.
|
|
*
|
|
* @param string $propertyName The name of the option to set.
|
|
* @param mixed $propertyValue The option value.
|
|
* @ignore
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* if the given property does not exist.
|
|
* @throws ezcBaseValueException
|
|
* if the value to be assigned to a property is invalid.
|
|
* @throws ezcBasePropertyPermissionException
|
|
* if the property to be set is a read-only property.
|
|
*/
|
|
abstract public function __set( $propertyName, $propertyValue );
|
|
|
|
/**
|
|
* Returns if a option exists.
|
|
*
|
|
* @param string $propertyName Option name to check for.
|
|
* @return bool Whether the option exists.
|
|
* @ignore
|
|
*/
|
|
public function __isset( $propertyName )
|
|
{
|
|
return array_key_exists( $propertyName, $this->properties );
|
|
}
|
|
|
|
/**
|
|
* Returns if an option exists.
|
|
* Allows isset() using ArrayAccess.
|
|
*
|
|
* @param string $propertyName The name of the option to get.
|
|
* @return bool Whether the option exists.
|
|
*/
|
|
public function offsetExists( $propertyName )
|
|
{
|
|
return $this->__isset( $propertyName );
|
|
}
|
|
|
|
/**
|
|
* Returns an option value.
|
|
* Get an option value by ArrayAccess.
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* If $propertyName is not a key in the $properties array.
|
|
* @param string $propertyName The name of the option to get.
|
|
* @return mixed The option value.
|
|
*/
|
|
public function offsetGet( $propertyName )
|
|
{
|
|
return $this->__get( $propertyName );
|
|
}
|
|
|
|
/**
|
|
* Set an option.
|
|
* Sets an option using ArrayAccess.
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* If $propertyName is not a key in the $properties array.
|
|
* @throws ezcBaseValueException
|
|
* If the value for a property is out of range.
|
|
* @param string $propertyName The name of the option to set.
|
|
* @param mixed $propertyValue The value for the option.
|
|
*/
|
|
public function offsetSet( $propertyName, $propertyValue )
|
|
{
|
|
$this->__set( $propertyName, $propertyValue );
|
|
}
|
|
|
|
/**
|
|
* Unset an option.
|
|
* Unsets an option using ArrayAccess.
|
|
*
|
|
* @throws ezcBasePropertyNotFoundException
|
|
* If $propertyName is not a key in the $properties array.
|
|
* @throws ezcBaseValueException
|
|
* If a the value for a property is out of range.
|
|
* @param string $propertyName The name of the option to unset.
|
|
*/
|
|
public function offsetUnset( $propertyName )
|
|
{
|
|
$this->__set( $propertyName, null );
|
|
}
|
|
}
|
|
?>
|