You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
90 lines
2.2 KiB
90 lines
2.2 KiB
<?php |
|
|
|
/** |
|
* Validates a number as defined by the CSS spec. |
|
*/ |
|
class HTMLPurifier_AttrDef_CSS_Number extends HTMLPurifier_AttrDef |
|
{ |
|
|
|
/** |
|
* Indicates whether or not only positive values are allowed. |
|
* @type bool |
|
*/ |
|
protected $non_negative = false; |
|
|
|
/** |
|
* @param bool $non_negative indicates whether negatives are forbidden |
|
*/ |
|
public function __construct($non_negative = false) |
|
{ |
|
$this->non_negative = $non_negative; |
|
} |
|
|
|
/** |
|
* @param string $number |
|
* @param HTMLPurifier_Config $config |
|
* @param HTMLPurifier_Context $context |
|
* @return string|bool |
|
* @warning Some contexts do not pass $config, $context. These |
|
* variables should not be used without checking HTMLPurifier_Length |
|
*/ |
|
public function validate($number, $config, $context) |
|
{ |
|
$number = $this->parseCDATA($number); |
|
|
|
if ($number === '') { |
|
return false; |
|
} |
|
if ($number === '0') { |
|
return '0'; |
|
} |
|
|
|
$sign = ''; |
|
switch ($number[0]) { |
|
case '-': |
|
if ($this->non_negative) { |
|
return false; |
|
} |
|
$sign = '-'; |
|
case '+': |
|
$number = substr($number, 1); |
|
} |
|
|
|
if (ctype_digit($number)) { |
|
$number = ltrim($number, '0'); |
|
return $number ? $sign . $number : '0'; |
|
} |
|
|
|
// Period is the only non-numeric character allowed |
|
if (strpos($number, '.') === false) { |
|
return false; |
|
} |
|
|
|
list($left, $right) = explode('.', $number, 2); |
|
|
|
if ($left === '' && $right === '') { |
|
return false; |
|
} |
|
if ($left !== '' && !ctype_digit($left)) { |
|
return false; |
|
} |
|
|
|
// Remove leading zeros until positive number or a zero stays left |
|
if (ltrim($left, '0') != '') { |
|
$left = ltrim($left, '0'); |
|
} else { |
|
$left = '0'; |
|
} |
|
|
|
$right = rtrim($right, '0'); |
|
|
|
if ($right === '') { |
|
return $left ? $sign . $left : '0'; |
|
} elseif (!ctype_digit($right)) { |
|
return false; |
|
} |
|
return $sign . $left . '.' . $right; |
|
} |
|
} |
|
|
|
// vim: et sw=4 sts=4
|
|
|