$value) { $this->{'_' . $key} = $value; } } else { $this->_name = $name; $this->_help = $help; $this->_required = $required; $this->_choices = $choices; } } /** * Get the name of the argument * * @return string */ public function name() { return $this->_name; } /** * Generate the help for this this argument. * * @param int $width The width to make the name of the option. * @return string */ public function help($width = 0) { $name = $this->_name; if (strlen($name) < $width) { $name = str_pad($name, $width, ' '); } $optional = ''; if (!$this->isRequired()) { $optional = ' (optional)'; } if (!empty($this->_choices)) { $optional .= sprintf(' (choices: %s)', implode('|', $this->_choices)); } return sprintf('%s%s%s', $name, $this->_help, $optional); } /** * Get the usage value for this argument * * @return string */ public function usage() { $name = $this->_name; if (!empty($this->_choices)) { $name = implode('|', $this->_choices); } if (!$this->isRequired()) { $name = '[' . $name . ']'; } return $name; } /** * Check if this argument is a required argument * * @return boolean */ public function isRequired() { return (bool) $this->_required; } /** * Check that $value is a valid choice for this argument. * * @return boolean */ public function validChoice($value) { if (empty($this->_choices)) { return true; } if (!in_array($value, $this->_choices)) { throw new InvalidArgumentException( sprintf(__('"%s" is not a valid value for %s'), $value, $this->_name) ); } return true; } }