Overview

Namespaces

  • Cz
    • Cli
      • Inputs
      • Outputs
      • Parameters

Classes

  • Cz\Cli\Console
  • Cz\Cli\ConsoleFactory
  • Cz\Cli\Inputs\DefaultInputProvider
  • Cz\Cli\Inputs\ReadlineInputProvider
  • Cz\Cli\Outputs\BaseOutput
  • Cz\Cli\Outputs\ColoredOutput
  • Cz\Cli\Outputs\TextOutput
  • Cz\Cli\Parameters\BaseParser
  • Cz\Cli\Parameters\DefaultParametersParser

Interfaces

  • Cz\Cli\IInputProvider
  • Cz\Cli\IOutputFormatter
  • Cz\Cli\IParametersParser

Exceptions

  • Cz\Cli\ConsoleException
  • Cz\Cli\InputException
  • Cz\Cli\OutputException
  • Cz\Cli\ParametersException
  • Cz\Cli\ParametersParseException
  • Overview
  • Namespace
  • Class
  1:   2:   3:   4:   5:   6:   7:   8:   9:  10:  11:  12:  13:  14:  15:  16:  17:  18:  19:  20:  21:  22:  23:  24:  25:  26:  27:  28:  29:  30:  31:  32:  33:  34:  35:  36:  37:  38:  39:  40:  41:  42:  43:  44:  45:  46:  47:  48:  49:  50:  51:  52:  53:  54:  55:  56:  57:  58:  59:  60:  61:  62:  63:  64:  65:  66:  67:  68:  69:  70:  71:  72:  73:  74:  75:  76:  77:  78:  79:  80:  81:  82:  83:  84:  85:  86:  87:  88:  89:  90:  91:  92:  93:  94:  95:  96:  97:  98:  99: 100: 101: 102: 103: 104: 105: 106: 107: 108: 109: 110: 111: 112: 113: 114: 115: 116: 117: 118: 119: 120: 121: 122: 123: 124: 125: 126: 127: 128: 129: 130: 131: 
<?php
    /** Cz CLI Console
     * 
     * @author      Jan Pecha, <janpecha@email.cz>
     */
    
    namespace Cz\Cli\Parameters;
    use Cz\Cli\IParametersParser,
        Cz\Cli\ParametersException;
    
    abstract class BaseParser implements IParametersParser
    {
        /** @var  array|NULL */
        protected $defaultParameters;
        
        /** @var  array|NULL */
        protected $parameters;
        
        /** @var  bool */
        protected $parsed = FALSE;
        
        /** @var  array|NULL */
        protected $rawParameters;
        
        
        
        public function setRawParameters(array $parameters = NULL)
        {
            $this->rawParameters = $parameters;
            return $this;
        }
        
        
        
        public function setDefaultParameters(array $defaultParameters = NULL)
        {
            $this->defaultParameters = $defaultParameters;
            return $this;
        }
        
        
        
        public function getParameters()
        {
            if(!$this->parsed)
            {
                $this->parameters = $this->parse($this->rawParameters);
            }
            
            return $this->parameters;
        }
        
        
        
        public function getParameter($name, $defaultValue = NULL, $required = FALSE)
        {
            if(!$this->parsed)
            {
                $this->parameters = $this->parse($this->rawParameters);
            }
            
            if(!isset($this->parameters[$name]))
            {
                if($required)
                {
                    throw new ParametersException('Required parameters not found.');
                }
                
                return $defaultValue;
            }
            
            return $this->parameters[$name];
        }
        
        
        
        /**
         * @param   array|NULL
         * @return  self
         */
        protected function setParameters(array $parameters = NULL)
        {
            $this->parameters = self::merge($parameters, $this->defaultParameters);
            return $this;
        }
        
        
        
        protected abstract function parse(array $rawParameters = NULL);
        
        
        
        /**
         * Left side has pririoty. Helper method.
         * @param   array
         * @param   array
         * @return  array|NULL
         */
        protected static function merge($left, $right)
        {
            if(is_array($left) && is_array($right))
            {
                foreach($left as $key => $val)
                {
                    if(is_int($key))
                    {
                        $right[] = $val;
                    }
                    else
                    {
                        if(isset($right[$key]))
                        {
                            $val = self::merge($val, $right[$key]);
                        }
                        
                        $right[$key] = $val;
                    }
                }
                
                return $right;
            }
            elseif($left === NULL && is_array($right))
            {
                return $right;
            }
            
            return $left;
        }
    }

czproject/phpcli v2.0.0-beta API documentation API documentation generated by ApiGen