105 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
 | 
						|
namespace Zxing\Common;
 | 
						|
 | 
						|
use \Zxing\NotFoundException;
 | 
						|
use ReflectionClass;
 | 
						|
 | 
						|
/**
 | 
						|
 * A general enum implementation until we got SplEnum.
 | 
						|
 */
 | 
						|
final class AbstractEnum
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Default value.
 | 
						|
     */
 | 
						|
    const __default = null;
 | 
						|
    /**
 | 
						|
     * Current value.
 | 
						|
     *
 | 
						|
     * @var mixed
 | 
						|
     */
 | 
						|
    protected $value;
 | 
						|
    /**
 | 
						|
     * Cache of constants.
 | 
						|
     *
 | 
						|
     * @var array
 | 
						|
     */
 | 
						|
    protected $constants;
 | 
						|
    /**
 | 
						|
     * Whether to handle values strict or not.
 | 
						|
     *
 | 
						|
     * @var boolean
 | 
						|
     */
 | 
						|
    protected $strict;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Creates a new enum.
 | 
						|
     *
 | 
						|
     * @param mixed   $initialValue
 | 
						|
     * @param boolean $strict
 | 
						|
     */
 | 
						|
    public function __construct($initialValue = null, $strict = false)
 | 
						|
    {
 | 
						|
        $this->strict = $strict;
 | 
						|
        $this->change($initialValue);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Changes the value of the enum.
 | 
						|
     *
 | 
						|
     * @param  mixed $value
 | 
						|
     *
 | 
						|
     * @return void
 | 
						|
     */
 | 
						|
    public function change($value)
 | 
						|
    {
 | 
						|
        if (!in_array($value, $this->getConstList(), $this->strict)) {
 | 
						|
            throw new \UnexpectedValueException('Value not a const in enum ' . get_class($this));
 | 
						|
        }
 | 
						|
        $this->value = $value;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets all constants (possible values) as an array.
 | 
						|
     *
 | 
						|
     * @param  boolean $includeDefault
 | 
						|
     *
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    public function getConstList($includeDefault = true)
 | 
						|
    {
 | 
						|
        if ($this->constants === null) {
 | 
						|
            $reflection      = new ReflectionClass($this);
 | 
						|
            $this->constants = $reflection->getConstants();
 | 
						|
        }
 | 
						|
        if ($includeDefault) {
 | 
						|
            return $this->constants;
 | 
						|
        }
 | 
						|
        $constants = $this->constants;
 | 
						|
        unset($constants['__default']);
 | 
						|
 | 
						|
        return $constants;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets current value.
 | 
						|
     *
 | 
						|
     * @return mixed
 | 
						|
     */
 | 
						|
    public function get()
 | 
						|
    {
 | 
						|
        return $this->value;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the name of the enum.
 | 
						|
     *
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    public function __toString()
 | 
						|
    {
 | 
						|
        return (string)array_search($this->value, $this->getConstList());
 | 
						|
    }
 | 
						|
}
 |