mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-03 05:11:52 +00:00
Rename xhtml-1.1 to html-modularization and remove outdated segments.
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1124 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
2e089477a5
commit
9c60eeed04
@ -1,11 +1,8 @@
|
|||||||
|
|
||||||
XHTML 1.1 and HTML Purifier
|
The Modularizatino of HTMLDefinition in HTML Purifier
|
||||||
[needs updating, most of this is implemented]
|
|
||||||
|
|
||||||
Todo for XHTML 1.1 support <http://www.w3.org/TR/xhtml11/changes.html>
|
Todo for XHTML 1.1 support <http://www.w3.org/TR/xhtml11/changes.html>
|
||||||
1. Scratch lang entirely in favor of xml:lang
|
1. Support Ruby <http://www.w3.org/TR/2001/REC-ruby-20010531/>
|
||||||
2. Scratch name entirely in favor of id (partially-done)
|
|
||||||
3. Support Ruby <http://www.w3.org/TR/2001/REC-ruby-20010531/>
|
|
||||||
|
|
||||||
HTML Purifier uses the modularization of XHTML
|
HTML Purifier uses the modularization of XHTML
|
||||||
<http://www.w3.org/TR/xhtml-modularization/> to organize the internals
|
<http://www.w3.org/TR/xhtml-modularization/> to organize the internals
|
||||||
@ -13,25 +10,10 @@ of HTMLDefinition into a more manageable and extensible fashion. Rather
|
|||||||
than have one super-object, HTMLDefinition is split into HTMLModules,
|
than have one super-object, HTMLDefinition is split into HTMLModules,
|
||||||
each of which are responsible for defining elements, their attributes,
|
each of which are responsible for defining elements, their attributes,
|
||||||
and other properties (for a more indepth coverage, see
|
and other properties (for a more indepth coverage, see
|
||||||
/library/HTMLPurifier/HTMLModule.php's docblock comments).
|
/library/HTMLPurifier/HTMLModule.php's docblock comments). These modules
|
||||||
|
are managed by HTMLModuleManager.
|
||||||
|
|
||||||
The modules that W3C defines and we support are:
|
Modules that we don't support but could support are:
|
||||||
|
|
||||||
* 5.1. Attribute Collections (technically not a module
|
|
||||||
* 5.2. Core Modules
|
|
||||||
o 5.2.2. Text Module
|
|
||||||
o 5.2.3. Hypertext Module
|
|
||||||
o 5.2.4. List Module
|
|
||||||
* 5.4. Text Extension Modules
|
|
||||||
o 5.4.1. Presentation Module
|
|
||||||
o 5.4.2. Edit Module
|
|
||||||
o 5.4.3. Bi-directional Text Module
|
|
||||||
* 5.6. Table Modules
|
|
||||||
o 5.6.2. Tables Module
|
|
||||||
* 5.7. Image Module
|
|
||||||
* 5.18. Style Attribute Module
|
|
||||||
|
|
||||||
Modules that we don't support but coul support are:
|
|
||||||
|
|
||||||
* 5.6. Table Modules
|
* 5.6. Table Modules
|
||||||
o 5.6.1. Basic Tables Module [?]
|
o 5.6.1. Basic Tables Module [?]
|
||||||
@ -39,10 +21,8 @@ Modules that we don't support but coul support are:
|
|||||||
* 5.9. Server-side Image Map Module [?]
|
* 5.9. Server-side Image Map Module [?]
|
||||||
* 5.12. Target Module [?]
|
* 5.12. Target Module [?]
|
||||||
* 5.21. Name Identification Module [deprecated]
|
* 5.21. Name Identification Module [deprecated]
|
||||||
* 5.22. Legacy Module [deprecated]
|
|
||||||
|
|
||||||
These modules will not be implemented due to their dangerousness or
|
These modules would be implemented as "unsafe":
|
||||||
inapplicability as an XHTML fragment:
|
|
||||||
|
|
||||||
* 5.2. Core Modules
|
* 5.2. Core Modules
|
||||||
o 5.2.1. Structure Module
|
o 5.2.1. Structure Module
|
||||||
@ -65,11 +45,7 @@ of robust tools for handling them (the main problem is that all the
|
|||||||
current parsers are usually PHP 5 only and solely-validating, not
|
current parsers are usually PHP 5 only and solely-validating, not
|
||||||
correcting).
|
correcting).
|
||||||
|
|
||||||
The abstraction of the HTMLDefinition creation process will also
|
This system may be generalized and ported over for CSS.
|
||||||
contribute to a need for a caching system. Cache invalidation would be
|
|
||||||
difficult, but could be done by comparing the HTML and Attr config
|
|
||||||
namespaces with a copy that was packaged along with the serialized
|
|
||||||
HTMLDefinition object.
|
|
||||||
|
|
||||||
== General Use-Case ==
|
== General Use-Case ==
|
||||||
|
|
||||||
@ -92,7 +68,7 @@ like this:
|
|||||||
<?php
|
<?php
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
$config = HTMLPurifier_Config::createDefault();
|
||||||
$def =& $config->getHTMLDefinition(true); // reference to raw
|
$def =& $config->getHTMLDefinition(true); // reference to raw
|
||||||
unset($def->modules['Hypertext']); // rm ''a'' link
|
$def->addElement('marquee', 'Block', 'Flow', 'Common');
|
||||||
$purifier = new HTMLPurifier($config);
|
$purifier = new HTMLPurifier($config);
|
||||||
$purifier->purify($html); // now the definition is finalized
|
$purifier->purify($html); // now the definition is finalized
|
||||||
?>
|
?>
|
||||||
@ -185,4 +161,4 @@ Content sets can be altered using HTMLModule->content_sets, an associative
|
|||||||
array of content set names to content set contents. If the content set
|
array of content set names to content set contents. If the content set
|
||||||
already exists, your values are appended on to it (great for, say,
|
already exists, your values are appended on to it (great for, say,
|
||||||
registering the font tag as an inline element), otherwise it is
|
registering the font tag as an inline element), otherwise it is
|
||||||
created. They are substituted into content_model.
|
created. They are substituted into content_model.
|
Loading…
Reference in New Issue
Block a user