mirror of
https://github.com/moodle/moodle.git
synced 2025-07-26 08:50:30 +02:00
Prior to this change, all the line endings in the imported HTMLPurifier library were using CRLF (\r\n aka Windows style), but the HTMLPurifier source and also the downloadable artefacts use LF (\n aka Linux style) as line endings. This has been the case since510d190382
when with the commit "MDL-38672 import HTML Purifier 4.5.0" all line endings were changed from LF to CRLF. There was no comment in the commit on why this change was done. As the original source uses LF, this commit partly reverts510d190382
and goes back to LF as line endings. Signed-off-by: Daniel Ziegenberg <daniel@ziegenberg.at>
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
|