mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-07 06:51:51 +00:00
[1.7.0] Modify addElement to return a reference to the created definition, shorten other HTMLModules accordingly.
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1046 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
ed73fdd5b8
commit
e0cf214c44
@ -137,9 +137,11 @@ class HTMLPurifier_HTMLModule
|
|||||||
* element?
|
* element?
|
||||||
* @param $attr What unique attributes does the element define?
|
* @param $attr What unique attributes does the element define?
|
||||||
* @note See ElementDef for in-depth descriptions of these parameters.
|
* @note See ElementDef for in-depth descriptions of these parameters.
|
||||||
|
* @return Reference to created element definition object, so you
|
||||||
|
* can set advanced parameters
|
||||||
* @protected
|
* @protected
|
||||||
*/
|
*/
|
||||||
function addElement($element, $safe, $type, $contents, $attr_includes, $attr = array()) {
|
function &addElement($element, $safe, $type, $contents, $attr_includes, $attr = array()) {
|
||||||
$this->elements[] = $element;
|
$this->elements[] = $element;
|
||||||
// parse content_model
|
// parse content_model
|
||||||
list($content_model_type, $content_model) = $this->parseContents($contents);
|
list($content_model_type, $content_model) = $this->parseContents($contents);
|
||||||
@ -153,6 +155,7 @@ class HTMLPurifier_HTMLModule
|
|||||||
);
|
);
|
||||||
// literal object $contents means direct child manipulation
|
// literal object $contents means direct child manipulation
|
||||||
if (!is_string($contents)) $this->info[$element]->child = $contents;
|
if (!is_string($contents)) $this->info[$element]->child = $contents;
|
||||||
|
return $this->info[$element];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -17,7 +17,7 @@ class HTMLPurifier_HTMLModule_Bdo extends HTMLPurifier_HTMLModule
|
|||||||
|
|
||||||
function HTMLPurifier_HTMLModule_Bdo() {
|
function HTMLPurifier_HTMLModule_Bdo() {
|
||||||
$dir = new HTMLPurifier_AttrDef_Enum(array('ltr','rtl'), false);
|
$dir = new HTMLPurifier_AttrDef_Enum(array('ltr','rtl'), false);
|
||||||
$this->addElement(
|
$bdo =& $this->addElement(
|
||||||
'bdo', true, 'Inline', 'Inline', array('Core', 'Lang'),
|
'bdo', true, 'Inline', 'Inline', array('Core', 'Lang'),
|
||||||
array(
|
array(
|
||||||
'dir' => $dir, // required
|
'dir' => $dir, // required
|
||||||
@ -28,7 +28,8 @@ class HTMLPurifier_HTMLModule_Bdo extends HTMLPurifier_HTMLModule
|
|||||||
// be managed with a global attribute transform)
|
// be managed with a global attribute transform)
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
$this->info['bdo']->attr_transform_post['required-dir'] = new HTMLPurifier_AttrTransform_BdoDir();
|
$bdo->attr_transform_post['required-dir'] = new HTMLPurifier_AttrTransform_BdoDir();
|
||||||
|
|
||||||
$this->attr_collections['I18N']['dir'] = $dir;
|
$this->attr_collections['I18N']['dir'] = $dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ class HTMLPurifier_HTMLModule_Hypertext extends HTMLPurifier_HTMLModule
|
|||||||
var $name = 'Hypertext';
|
var $name = 'Hypertext';
|
||||||
|
|
||||||
function HTMLPurifier_HTMLModule_Hypertext() {
|
function HTMLPurifier_HTMLModule_Hypertext() {
|
||||||
$this->addElement(
|
$a =& $this->addElement(
|
||||||
'a', true, 'Inline', 'Inline', 'Common',
|
'a', true, 'Inline', 'Inline', 'Common',
|
||||||
array(
|
array(
|
||||||
// 'accesskey' => 'Character',
|
// 'accesskey' => 'Character',
|
||||||
@ -25,7 +25,7 @@ class HTMLPurifier_HTMLModule_Hypertext extends HTMLPurifier_HTMLModule
|
|||||||
// 'type' => 'ContentType',
|
// 'type' => 'ContentType',
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
$this->info['a']->excludes = array('a' => true);
|
$a->excludes = array('a' => true);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ class HTMLPurifier_HTMLModule_Image extends HTMLPurifier_HTMLModule
|
|||||||
var $content_sets = array('Inline' => 'img');
|
var $content_sets = array('Inline' => 'img');
|
||||||
|
|
||||||
function HTMLPurifier_HTMLModule_Image() {
|
function HTMLPurifier_HTMLModule_Image() {
|
||||||
$this->addElement(
|
$img =& $this->addElement(
|
||||||
'img', true, 'Inline', 'Empty', 'Common',
|
'img', true, 'Inline', 'Empty', 'Common',
|
||||||
array(
|
array(
|
||||||
'alt' => 'Text',
|
'alt' => 'Text',
|
||||||
@ -28,7 +28,7 @@ class HTMLPurifier_HTMLModule_Image extends HTMLPurifier_HTMLModule
|
|||||||
'width' => 'Length'
|
'width' => 'Length'
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
$this->info['img']->attr_transform_post[] =
|
$img->attr_transform_post[] =
|
||||||
new HTMLPurifier_AttrTransform_ImgRequired();
|
new HTMLPurifier_AttrTransform_ImgRequired();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,8 +26,8 @@ class HTMLPurifier_HTMLModule_List extends HTMLPurifier_HTMLModule
|
|||||||
$this->addElement('ul', true, 'List', 'Required: li', 'Common');
|
$this->addElement('ul', true, 'List', 'Required: li', 'Common');
|
||||||
$this->addElement('dl', true, 'List', 'Required: dt | dd', 'Common');
|
$this->addElement('dl', true, 'List', 'Required: dt | dd', 'Common');
|
||||||
|
|
||||||
$this->addElement('li', true, false, 'Flow', 'Common');
|
$li =& $this->addElement('li', true, false, 'Flow', 'Common');
|
||||||
$this->info['li']->auto_close = array('li' => true);
|
$li->auto_close = array('li' => true);
|
||||||
|
|
||||||
$this->addElement('dd', true, false, 'Flow', 'Common');
|
$this->addElement('dd', true, false, 'Flow', 'Common');
|
||||||
$this->addElement('dt', true, false, 'Inline', 'Common');
|
$this->addElement('dt', true, false, 'Inline', 'Common');
|
||||||
|
@ -21,7 +21,7 @@ class HTMLPurifier_HTMLModuleTest extends UnitTestCase
|
|||||||
function test_addElement() {
|
function test_addElement() {
|
||||||
|
|
||||||
$module = new HTMLPurifier_HTMLModule();
|
$module = new HTMLPurifier_HTMLModule();
|
||||||
$module->addElement(
|
$def =& $module->addElement(
|
||||||
'a', true, 'Inline', 'Optional: #PCDATA', array('Common'),
|
'a', true, 'Inline', 'Optional: #PCDATA', array('Common'),
|
||||||
array(
|
array(
|
||||||
'href' => 'URI'
|
'href' => 'URI'
|
||||||
@ -29,19 +29,21 @@ class HTMLPurifier_HTMLModuleTest extends UnitTestCase
|
|||||||
);
|
);
|
||||||
|
|
||||||
$module2 = new HTMLPurifier_HTMLModule();
|
$module2 = new HTMLPurifier_HTMLModule();
|
||||||
$def = new HTMLPurifier_ElementDef();
|
$def2 = new HTMLPurifier_ElementDef();
|
||||||
$def->safe = true;
|
$def2->safe = true;
|
||||||
$def->content_model = '#PCDATA';
|
$def2->content_model = '#PCDATA';
|
||||||
$def->content_model_type = 'optional';
|
$def2->content_model_type = 'optional';
|
||||||
$def->attr = array(
|
$def2->attr = array(
|
||||||
'href' => 'URI',
|
'href' => 'URI',
|
||||||
0 => array('Common')
|
0 => array('Common')
|
||||||
);
|
);
|
||||||
$module2->info['a'] = $def;
|
$module2->info['a'] = $def2;
|
||||||
$module2->elements = array('a');
|
$module2->elements = array('a');
|
||||||
$module2->content_sets['Inline'] = 'a';
|
$module2->content_sets['Inline'] = 'a';
|
||||||
|
|
||||||
$this->assertIdentical($module, $module2);
|
$this->assertIdentical($module, $module2);
|
||||||
|
$this->assertIdentical($def, $def2);
|
||||||
|
$this->assertReference($def, $module->info['a']);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user