mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2024-11-30 01:36:21 +00:00
74 lines
2.2 KiB
PHP
74 lines
2.2 KiB
PHP
|
<?php
|
||
|
|
||
|
// Enum = Enumerated
|
||
|
/**
|
||
|
* Validates a keyword against a list of valid values.
|
||
|
* @warning The case-insensitive compare of this function uses PHP's
|
||
|
* built-in strtolower and ctype_lower functions, which may
|
||
|
* cause problems with international comparisons
|
||
|
*/
|
||
|
class HTMLPurifier_AttrDef_Enum extends HTMLPurifier_AttrDef
|
||
|
{
|
||
|
|
||
|
/**
|
||
|
* Lookup table of valid values.
|
||
|
* @type array
|
||
|
* @todo Make protected
|
||
|
*/
|
||
|
public $valid_values = array();
|
||
|
|
||
|
/**
|
||
|
* Bool indicating whether or not enumeration is case sensitive.
|
||
|
* @note In general this is always case insensitive.
|
||
|
*/
|
||
|
protected $case_sensitive = false; // values according to W3C spec
|
||
|
|
||
|
/**
|
||
|
* @param array $valid_values List of valid values
|
||
|
* @param bool $case_sensitive Whether or not case sensitive
|
||
|
*/
|
||
|
public function __construct($valid_values = array(), $case_sensitive = false)
|
||
|
{
|
||
|
$this->valid_values = array_flip($valid_values);
|
||
|
$this->case_sensitive = $case_sensitive;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $string
|
||
|
* @param HTMLPurifier_Config $config
|
||
|
* @param HTMLPurifier_Context $context
|
||
|
* @return bool|string
|
||
|
*/
|
||
|
public function validate($string, $config, $context)
|
||
|
{
|
||
|
$string = trim($string);
|
||
|
if (!$this->case_sensitive) {
|
||
|
// we may want to do full case-insensitive libraries
|
||
|
$string = ctype_lower($string) ? $string : strtolower($string);
|
||
|
}
|
||
|
$result = isset($this->valid_values[$string]);
|
||
|
|
||
|
return $result ? $string : false;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $string In form of comma-delimited list of case-insensitive
|
||
|
* valid values. Example: "foo,bar,baz". Prepend "s:" to make
|
||
|
* case sensitive
|
||
|
* @return HTMLPurifier_AttrDef_Enum
|
||
|
*/
|
||
|
public function make($string)
|
||
|
{
|
||
|
if (strlen($string) > 2 && $string[0] == 's' && $string[1] == ':') {
|
||
|
$string = substr($string, 2);
|
||
|
$sensitive = true;
|
||
|
} else {
|
||
|
$sensitive = false;
|
||
|
}
|
||
|
$values = explode(',', $string);
|
||
|
return new HTMLPurifier_AttrDef_Enum($values, $sensitive);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// vim: et sw=4 sts=4
|