mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2024-11-25 15:38:40 +00:00
96d4a3ecf7
Due to historical reasons, the code is in subfolder "1". With SVN removal, we place the code back and remove the annoying "1" folder.
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
|