diff -r 000000000000 -r 4eba9c11703f web/Zend/Validate/Float.php --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/web/Zend/Validate/Float.php Mon Dec 13 18:29:26 2010 +0100 @@ -0,0 +1,134 @@ + "Invalid type given. String, integer or float expected", + self::NOT_FLOAT => "'%value%' does not appear to be a float", + ); + + protected $_locale; + + /** + * Constructor for the float validator + * + * @param string|Zend_Config|Zend_Locale $locale + */ + public function __construct($locale = null) + { + if ($locale instanceof Zend_Config) { + $locale = $locale->toArray(); + } + + if (is_array($locale)) { + if (array_key_exists('locale', $locale)) { + $locale = $locale['locale']; + } else { + $locale = null; + } + } + + if (empty($locale)) { + require_once 'Zend/Registry.php'; + if (Zend_Registry::isRegistered('Zend_Locale')) { + $locale = Zend_Registry::get('Zend_Locale'); + } + } + + $this->setLocale($locale); + } + + /** + * Returns the set locale + */ + public function getLocale() + { + return $this->_locale; + } + + /** + * Sets the locale to use + * + * @param string|Zend_Locale $locale + */ + public function setLocale($locale = null) + { + require_once 'Zend/Locale.php'; + $this->_locale = Zend_Locale::findLocale($locale); + return $this; + } + + /** + * Defined by Zend_Validate_Interface + * + * Returns true if and only if $value is a floating-point value + * + * @param string $value + * @return boolean + */ + public function isValid($value) + { + if (!is_string($value) && !is_int($value) && !is_float($value)) { + $this->_error(self::INVALID); + return false; + } + + if (is_float($value)) { + return true; + } + + $this->_setValue($value); + try { + if (!Zend_Locale_Format::isFloat($value, array('locale' => $this->_locale))) { + $this->_error(self::NOT_FLOAT); + return false; + } + } catch (Zend_Locale_Exception $e) { + $this->_error(self::NOT_FLOAT); + return false; + } + + return true; + } +}