ILIAS
release_5-3 Revision v5.3.23-19-g915713cf615
|
Forgivingly lexes HTML (SGML-style) markup into tokens. More...
Public Member Functions | |
__construct () | |
parseText ($string, $config) | |
parseAttr ($string, $config) | |
parseData ($string, $is_attr, $config) | |
Parses special entities into the proper characters. More... | |
tokenizeHTML ($string, $config, $context) | |
Lexes an HTML string into tokens. More... | |
normalize ($html, $config, $context) | |
Takes a piece of HTML and normalizes it by converting entities, fixing encoding, extracting bits, and other good stuff. More... | |
extractBody ($html) | |
Takes a string of HTML (fragment or document) and returns the content. More... | |
Static Public Member Functions | |
static | create ($config) |
Retrieves or sets the default Lexer as a Prototype Factory. More... | |
Data Fields | |
$tracksLineNumbers = false | |
Whether or not this lexer implements line-number/column-number tracking. More... | |
Static Protected Member Functions | |
static | escapeCDATA ($string) |
Translates CDATA sections into regular sections (through escaping). More... | |
static | escapeCommentedCDATA ($string) |
Special CDATA case that is especially convoluted for <script> More... | |
static | removeIEConditional ($string) |
Special Internet Explorer conditional comments should be removed. More... | |
static | CDATACallback ($matches) |
Callback function for escapeCDATA() that does the work. More... | |
Protected Attributes | |
$_special_entity2str | |
Most common entity to raw value conversion table for special entities. More... | |
Forgivingly lexes HTML (SGML-style) markup into tokens.
A lexer parses a string of SGML-style markup and converts them into corresponding tokens. It doesn't check for well-formedness, although its internal mechanism may make this automatic (such as the case of HTMLPurifier_Lexer_DOMLex). There are several implementations to choose from.
A lexer is HTML-oriented: it might work with XML, but it's not recommended, as we adhere to a subset of the specification for optimization reasons. This might change in the future. Also, most tokenizers are not expected to handle DTDs or PIs.
This class should not be directly instantiated, but you may use create() to retrieve a default copy of the lexer. Being a supertype, this class does not actually define any implementation, but offers commonly used convenience functions for subclasses.
HTMLPurifier_Lexer::__construct | ( | ) |
Definition at line 152 of file Lexer.php.
|
staticprotected |
Callback function for escapeCDATA() that does the work.
array | $matches | PCRE matches array, with index 0 the entire match and 1 the inside of the CDATA section. |
|
static |
Retrieves or sets the default Lexer as a Prototype Factory.
By default HTMLPurifier_Lexer_DOMLex will be returned. There are a few exceptions involving special features that only DirectLex implements.
HTMLPurifier_Config | $config |
HTMLPurifier_Exception |
Definition at line 69 of file Lexer.php.
References $config.
Referenced by HTMLPurifier\purify().
|
staticprotected |
Translates CDATA sections into regular sections (through escaping).
string | $string | HTML string to process. |
Definition at line 244 of file Lexer.php.
References array.
Referenced by normalize().
|
staticprotected |
Special CDATA case that is especially convoluted for <script>
string | $string | HTML string to process. |
Definition at line 258 of file Lexer.php.
References array.
Referenced by normalize().
HTMLPurifier_Lexer::extractBody | ( | $html | ) |
HTMLPurifier_Lexer::normalize | ( | $html, | |
$config, | |||
$context | |||
) |
Takes a piece of HTML and normalizes it by converting entities, fixing encoding, extracting bits, and other good stuff.
string | $html | HTML. |
HTMLPurifier_Config | $config | |
HTMLPurifier_Context | $context |
Definition at line 305 of file Lexer.php.
References $config, $html, HTMLPurifier_Encoder\cleanUTF8(), escapeCDATA(), escapeCommentedCDATA(), extractBody(), and removeIEConditional().
Referenced by HTMLPurifier_Lexer_PH5P\tokenizeHTML(), HTMLPurifier_Lexer_DirectLex\tokenizeHTML(), and HTMLPurifier_Lexer_DOMLex\tokenizeHTML().
HTMLPurifier_Lexer::parseAttr | ( | $string, | |
$config | |||
) |
Definition at line 176 of file Lexer.php.
References $config, and parseData().
Referenced by HTMLPurifier_Lexer_DirectLex\parseAttributeString().
HTMLPurifier_Lexer::parseData | ( | $string, | |
$is_attr, | |||
$config | |||
) |
Parses special entities into the proper characters.
This string will translate escaped versions of the special characters into the correct ones.
string | $string | String character data to be parsed. |
Definition at line 189 of file Lexer.php.
References $config.
Referenced by parseAttr(), and parseText().
HTMLPurifier_Lexer::parseText | ( | $string, | |
$config | |||
) |
Definition at line 172 of file Lexer.php.
References $config, and parseData().
Referenced by HTMLPurifier_Lexer_DOMLex\createStartNode(), and HTMLPurifier_Lexer_DirectLex\tokenizeHTML().
|
staticprotected |
Special Internet Explorer conditional comments should be removed.
string | $string | HTML string to process. |
Definition at line 272 of file Lexer.php.
Referenced by normalize().
HTMLPurifier_Lexer::tokenizeHTML | ( | $string, | |
$config, | |||
$context | |||
) |
Lexes an HTML string into tokens.
$string | String HTML. | |
HTMLPurifier_Config | $config | |
HTMLPurifier_Context | $context |
|
protected |
HTMLPurifier_Lexer::$tracksLineNumbers = false |