/ConsoleTools/src/dialog/validators/question_dialog_type.php
https://github.com/F5/zetacomponents · PHP · 243 lines · 113 code · 10 blank · 120 comment · 15 complexity · 3b890cc452629f64150034e0c6eb7665 MD5 · raw file
- <?php
- /**
- * File containing the ezcConsoleQuestionDialogTypeValidator class.
- *
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- *
- * @package ConsoleTools
- * @version //autogentag//
- * @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
- * @filesource
- */
- /**
- * Validator class to validate a certain data type.
- * Validator class for ezcConsoleQuestionDialog objects that validates a
- * certain datatype.
- *
- * @package ConsoleTools
- * @version //autogen//
- *
- * @property int $type
- * One of ezcConsoleQuestionDialogTypeValidator::TYPE_*. The type to
- * check against and convert results to.
- * @property mixed $default
- * A default value if no result given.
- */
- class ezcConsoleQuestionDialogTypeValidator implements ezcConsoleQuestionDialogValidator
- {
- /**
- * Data type string.
- */
- const TYPE_STRING = 0;
- /**
- * Data type int.
- */
- const TYPE_INT = 1;
- /**
- * Data type float.
- */
- const TYPE_FLOAT = 2;
- /**
- * Data type bool.
- * The results 1 and "true" will be cased to true, 0 and "false" to false.
- */
- const TYPE_BOOL = 3;
- /**
- * Properties.
- *
- * @var array
- */
- protected $properties = array(
- "type" => self::TYPE_STRING,
- "default" => null,
- );
- /**
- * Creates a new question dialog type validator.
- * Creates a new question dialog type validator, which validates the result
- * specified to be of a certaon type. The $type must be one of the TYPE_*
- * constants in this class. If no value is provided by the user a possibly
- * set $default value is used instead.
- *
- * @param int $type One of ezcConsoleQuestionDialogTypeValidator::TYPE_*.
- * @param mixed $default Default value according to $type.
- * @return void
- */
- public function __construct( $type = self::TYPE_STRING, $default = null )
- {
- $this->type = $type;
- $this->default = $default;
- }
- /**
- * Returns if the given result is valid.
- * Returns if the result is of the given type.
- *
- * @param mixed $result The result to check.
- * @return bool True if the result is valid. Otherwise false.
- */
- public function validate( $result )
- {
- if ( $result === "" )
- {
- return $this->default !== null;
- }
- switch ( $this->type )
- {
- case self::TYPE_INT:
- return is_int( $result );
- case self::TYPE_FLOAT:
- return is_float( $result );
- case self::TYPE_BOOL:
- return is_bool( $result );
- case self::TYPE_STRING:
- default:
- return is_string( $result );
- }
- }
- /**
- * Returns a fixed version of the result, if possible.
- * Returns the value casted into the correct type or the default value, if
- * it exists and the result is empty.
- *
- * @param mixed $result The result received.
- * @return mixed The manipulated result.
- */
- public function fixup( $result )
- {
- if ( $result === "" && $this->default !== null )
- {
- return $this->default;
- }
- switch ( $this->type )
- {
- case self::TYPE_INT:
- return ( preg_match( "/^[0-9\-]+$/", $result ) !== 0 ) ? (int) $result : $result;
- case self::TYPE_FLOAT:
- return ( preg_match( "/^[0-9.E\-]+$/i", $result ) !== 0 ) ? (float) $result : $result;
- case self::TYPE_BOOL:
- switch ( $result )
- {
- case "1":
- case "true":
- return true;
- case "0":
- case "false":
- return false;
- }
- case self::TYPE_STRING:
- default:
- return $result;
- }
- }
- /**
- * Returns a string representing valid results.
- * Returns the string that can will be displayed with the question to
- * indicate valid results to the user and a possibly set default, if
- * available.
- *
- * @return string
- */
- public function getResultString()
- {
- $res = "(<%s>)" . ( $this->default !== null ? " [{$this->default}]" : "" );
- switch ( $this->type )
- {
- case self::TYPE_INT:
- return sprintf( $res, "int" );
- case self::TYPE_FLOAT:
- return sprintf( $res, "float" );
- case self::TYPE_BOOL:
- return sprintf( $res, "bool" );
- case self::TYPE_STRING:
- default:
- return sprintf( $res, "string" );
- }
- }
-
- /**
- * Property read access.
- *
- * @param string $propertyName Name of the property.
- * @return mixed Value of the property or null.
- *
- * @throws ezcBasePropertyNotFoundException
- * If the the desired property is not found.
- * @ignore
- */
- public function __get( $propertyName )
- {
- if ( isset( $this->$propertyName ) )
- {
- return $this->properties[$propertyName];
- }
- throw new ezcBasePropertyNotFoundException( $propertyName );
- }
- /**
- * Property write access.
- *
- * @param string $propertyName Name of the property.
- * @param mixed $propertyValue The value for the property.
- *
- * @throws ezcBasePropertyNotFoundException
- * If a the value for the property options is not an instance of
- * @throws ezcBaseValueException
- * If a the value for a property is out of range.
- * @ignore
- */
- public function __set( $propertyName, $propertyValue )
- {
- switch ( $propertyName )
- {
- case "type":
- if ( $propertyValue !== self::TYPE_STRING && $propertyValue !== self::TYPE_INT && $propertyValue !== self::TYPE_FLOAT && $propertyValue !== self::TYPE_BOOL )
- {
- throw new ezcBaseValueException( $propertyName, $propertyValue, "ezcConsoleQuestionDialogTypeValidator::TYPE_*" );
- }
- break;
- case "default":
- if ( is_scalar( $propertyValue ) === false && $propertyValue !== null )
- {
- throw new ezcBaseValueException( $propertyName, $propertyValue, "scalar" );
- }
- break;
- default:
- throw new ezcBasePropertyNotFoundException( $propertyName );
- }
- $this->properties[$propertyName] = $propertyValue;
- }
- /**
- * Property isset access.
- *
- * @param string $propertyName Name of the property.
- * @return bool True is the property is set, otherwise false.
- * @ignore
- */
- public function __isset( $propertyName )
- {
- return array_key_exists( $propertyName, $this->properties );
- }
- }
- ?>