mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-08 15:11:51 +00:00
[3.1.1] Land vs's HTMLPurifier_Generator patch, and a number of other bugfixes for that change
- Convert a number of calls to use new constructor signature for Generator - Make generator require configuration; this exposes a number of latent bugs - Removed generator hack - Convert Printers to use new optimized ConfigSchema format - Hack with Printer configuration; pass an array(generator config, render config) to distinguish between output and target. - HTML/CSS Printers need to be primed, otherwise fatal errors - Convert a few test-cases to use member properties git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1770 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
bb16d8eae5
commit
14d934c7ca
10
NEWS
10
NEWS
@ -23,6 +23,8 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
|
|||||||
- Account for browser confusion between Yen character and backslash in
|
- Account for browser confusion between Yen character and backslash in
|
||||||
Shift_JIS encoding. This fix generalizes to any other encoding which is not
|
Shift_JIS encoding. This fix generalizes to any other encoding which is not
|
||||||
a strict superset of printable ASCII.
|
a strict superset of printable ASCII.
|
||||||
|
- Fix missing configuration parameter in Generator calls. Thanks vs for the
|
||||||
|
partial patch.
|
||||||
. Added HTMLPurifier_UnitConverter and HTMLPurifier_Length for convenient
|
. Added HTMLPurifier_UnitConverter and HTMLPurifier_Length for convenient
|
||||||
handling of CSS-style lengths. HTMLPurifier_AttrDef_CSS_Length now uses
|
handling of CSS-style lengths. HTMLPurifier_AttrDef_CSS_Length now uses
|
||||||
this class.
|
this class.
|
||||||
@ -42,6 +44,14 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
|
|||||||
consult changes to HTMLPurifier_Config for details.
|
consult changes to HTMLPurifier_Config for details.
|
||||||
. Variable parsing types now are magic integers instead of strings
|
. Variable parsing types now are magic integers instead of strings
|
||||||
. Added benchmark for ConfigSchema
|
. Added benchmark for ConfigSchema
|
||||||
|
. HTMLPurifier_Generator requires $config and $context parameters. If you
|
||||||
|
don't know what they should be, use HTMLPurifier_Config::createDefault()
|
||||||
|
and new HTMLPurifier_Context().
|
||||||
|
. Printers now properly distinguish between output configuration, and
|
||||||
|
target configuration. This is not applicable to scripts using
|
||||||
|
the Printers for HTML Purifier related tasks.
|
||||||
|
. HTML/CSS Printers must be primed with prepareGenerator($gen_config), otherwise
|
||||||
|
fatal errors will ensue.
|
||||||
|
|
||||||
3.1.0, released 2008-05-18
|
3.1.0, released 2008-05-18
|
||||||
# Unnecessary references to objects (vestiges of PHP4) removed from method
|
# Unnecessary references to objects (vestiges of PHP4) removed from method
|
||||||
|
@ -68,19 +68,19 @@
|
|||||||
</directive>
|
</directive>
|
||||||
<directive id="Core.Encoding">
|
<directive id="Core.Encoding">
|
||||||
<file name="HTMLPurifier/Encoder.php">
|
<file name="HTMLPurifier/Encoder.php">
|
||||||
<line>281</line>
|
<line>288</line>
|
||||||
<line>305</line>
|
<line>315</line>
|
||||||
</file>
|
</file>
|
||||||
</directive>
|
</directive>
|
||||||
<directive id="Test.ForceNoIconv">
|
<directive id="Test.ForceNoIconv">
|
||||||
<file name="HTMLPurifier/Encoder.php">
|
<file name="HTMLPurifier/Encoder.php">
|
||||||
<line>283</line>
|
<line>293</line>
|
||||||
<line>310</line>
|
<line>323</line>
|
||||||
</file>
|
</file>
|
||||||
</directive>
|
</directive>
|
||||||
<directive id="Core.EscapeNonASCIICharacters">
|
<directive id="Core.EscapeNonASCIICharacters">
|
||||||
<file name="HTMLPurifier/Encoder.php">
|
<file name="HTMLPurifier/Encoder.php">
|
||||||
<line>307</line>
|
<line>319</line>
|
||||||
</file>
|
</file>
|
||||||
</directive>
|
</directive>
|
||||||
<directive id="Core.MaintainLineNumbers">
|
<directive id="Core.MaintainLineNumbers">
|
||||||
@ -96,17 +96,17 @@
|
|||||||
</directive>
|
</directive>
|
||||||
<directive id="Output.CommentScriptContents">
|
<directive id="Output.CommentScriptContents">
|
||||||
<file name="HTMLPurifier/Generator.php">
|
<file name="HTMLPurifier/Generator.php">
|
||||||
<line>41</line>
|
<line>40</line>
|
||||||
</file>
|
</file>
|
||||||
</directive>
|
</directive>
|
||||||
<directive id="Output.TidyFormat">
|
<directive id="Output.TidyFormat">
|
||||||
<file name="HTMLPurifier/Generator.php">
|
<file name="HTMLPurifier/Generator.php">
|
||||||
<line>70</line>
|
<line>69</line>
|
||||||
</file>
|
</file>
|
||||||
</directive>
|
</directive>
|
||||||
<directive id="Output.Newline">
|
<directive id="Output.Newline">
|
||||||
<file name="HTMLPurifier/Generator.php">
|
<file name="HTMLPurifier/Generator.php">
|
||||||
<line>84</line>
|
<line>83</line>
|
||||||
</file>
|
</file>
|
||||||
</directive>
|
</directive>
|
||||||
<directive id="HTML.BlockWrapper">
|
<directive id="HTML.BlockWrapper">
|
||||||
|
@ -55,10 +55,7 @@ class HTMLPurifier_ChildDef_Required extends HTMLPurifier_ChildDef
|
|||||||
$escape_invalid_children = $config->get('Core', 'EscapeInvalidChildren');
|
$escape_invalid_children = $config->get('Core', 'EscapeInvalidChildren');
|
||||||
|
|
||||||
// generator
|
// generator
|
||||||
static $gen = null;
|
$gen = new HTMLPurifier_Generator($config, $context);
|
||||||
if ($gen === null) {
|
|
||||||
$gen = new HTMLPurifier_Generator();
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($tokens_of_children as $token) {
|
foreach ($tokens_of_children as $token) {
|
||||||
if (!empty($token->is_whitespace)) {
|
if (!empty($token->is_whitespace)) {
|
||||||
@ -83,7 +80,7 @@ class HTMLPurifier_ChildDef_Required extends HTMLPurifier_ChildDef
|
|||||||
$result[] = $token;
|
$result[] = $token;
|
||||||
} elseif ($pcdata_allowed && $escape_invalid_children) {
|
} elseif ($pcdata_allowed && $escape_invalid_children) {
|
||||||
$result[] = new HTMLPurifier_Token_Text(
|
$result[] = new HTMLPurifier_Token_Text(
|
||||||
$gen->generateFromToken($token, $config)
|
$gen->generateFromToken($token)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
@ -94,7 +91,7 @@ class HTMLPurifier_ChildDef_Required extends HTMLPurifier_ChildDef
|
|||||||
} elseif ($pcdata_allowed && $escape_invalid_children) {
|
} elseif ($pcdata_allowed && $escape_invalid_children) {
|
||||||
$result[] =
|
$result[] =
|
||||||
new HTMLPurifier_Token_Text(
|
new HTMLPurifier_Token_Text(
|
||||||
$gen->generateFromToken( $token, $config )
|
$gen->generateFromToken($token)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
// drop silently
|
// drop silently
|
||||||
|
@ -35,8 +35,7 @@ class HTMLPurifier_Generator
|
|||||||
* @param $config Instance of HTMLPurifier_Config
|
* @param $config Instance of HTMLPurifier_Config
|
||||||
* @param $context Instance of HTMLPurifier_Context
|
* @param $context Instance of HTMLPurifier_Context
|
||||||
*/
|
*/
|
||||||
public function __construct($config = null, $context = null) {
|
public function __construct($config, $context) {
|
||||||
if (!$config) $config = HTMLPurifier_Config::createDefault();
|
|
||||||
$this->config = $config;
|
$this->config = $config;
|
||||||
$this->_scriptFix = $config->get('Output', 'CommentScriptContents');
|
$this->_scriptFix = $config->get('Output', 'CommentScriptContents');
|
||||||
$this->_def = $config->getHTMLDefinition();
|
$this->_def = $config->getHTMLDefinition();
|
||||||
|
@ -20,18 +20,15 @@ class HTMLPurifier_Printer
|
|||||||
* Initialize $generator.
|
* Initialize $generator.
|
||||||
*/
|
*/
|
||||||
public function __construct() {
|
public function __construct() {
|
||||||
$this->generator = new HTMLPurifier_Generator();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Give generator necessary configuration if possible
|
* Give generator necessary configuration if possible
|
||||||
*/
|
*/
|
||||||
public function prepareGenerator($config) {
|
public function prepareGenerator($config) {
|
||||||
// hack for smoketests/configForm.php
|
|
||||||
$all = $config->getAll();
|
$all = $config->getAll();
|
||||||
if (empty($all['HTML'])) return;
|
|
||||||
$context = new HTMLPurifier_Context();
|
$context = new HTMLPurifier_Context();
|
||||||
$this->generator->generateFromTokens(array(), $config, $context);
|
$this->generator = new HTMLPurifier_Generator($config, $context);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @todo Rewrite to use Interchange objects
|
||||||
|
*/
|
||||||
class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
|
class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -38,8 +41,8 @@ class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
|
|||||||
$this->name = $name;
|
$this->name = $name;
|
||||||
$this->compress = $compress;
|
$this->compress = $compress;
|
||||||
// initialize sub-printers
|
// initialize sub-printers
|
||||||
$this->fields['default'] = new HTMLPurifier_Printer_ConfigForm_default();
|
$this->fields[0] = new HTMLPurifier_Printer_ConfigForm_default();
|
||||||
$this->fields['bool'] = new HTMLPurifier_Printer_ConfigForm_bool();
|
$this->fields[HTMLPurifier_VarParser::BOOL] = new HTMLPurifier_Printer_ConfigForm_bool();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -68,14 +71,23 @@ class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns HTML output for a configuration form
|
* Returns HTML output for a configuration form
|
||||||
* @param $config Configuration object of current form state
|
* @param $config Configuration object of current form state, or an array
|
||||||
|
* where [0] has an HTML namespace and [1] is being rendered.
|
||||||
* @param $allowed Optional namespace(s) and directives to restrict form to.
|
* @param $allowed Optional namespace(s) and directives to restrict form to.
|
||||||
*/
|
*/
|
||||||
public function render($config, $allowed = true, $render_controls = true) {
|
public function render($config, $allowed = true, $render_controls = true) {
|
||||||
$this->config = $config;
|
if (is_array($config) && isset($config[0])) {
|
||||||
$this->prepareGenerator($config);
|
$gen_config = $config[0];
|
||||||
|
$config = $config[1];
|
||||||
|
} else {
|
||||||
|
$gen_config = $config;
|
||||||
|
}
|
||||||
|
|
||||||
$allowed = HTMLPurifier_Config::getAllowedDirectivesForForm($allowed);
|
$this->config = $config;
|
||||||
|
$this->genConfig = $gen_config;
|
||||||
|
$this->prepareGenerator($gen_config);
|
||||||
|
|
||||||
|
$allowed = HTMLPurifier_Config::getAllowedDirectivesForForm($allowed, $config->def);
|
||||||
$all = array();
|
$all = array();
|
||||||
foreach ($allowed as $key) {
|
foreach ($allowed as $key) {
|
||||||
list($ns, $directive) = $key;
|
list($ns, $directive) = $key;
|
||||||
@ -148,13 +160,19 @@ class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
|
|||||||
|
|
||||||
$ret .= $this->start('td');
|
$ret .= $this->start('td');
|
||||||
$def = $this->config->def->info[$ns][$directive];
|
$def = $this->config->def->info[$ns][$directive];
|
||||||
$type = $def->type;
|
if (is_int($def)) {
|
||||||
if (!isset($this->fields[$type])) $type = 'default';
|
$allow_null = $def < 0;
|
||||||
|
$type = abs($def);
|
||||||
|
} else {
|
||||||
|
$type = $def->type;
|
||||||
|
$allow_null = isset($def->allow_null);
|
||||||
|
}
|
||||||
|
if (!isset($this->fields[$type])) $type = 0; // default
|
||||||
$type_obj = $this->fields[$type];
|
$type_obj = $this->fields[$type];
|
||||||
if ($def->allow_null) {
|
if ($allow_null) {
|
||||||
$type_obj = new HTMLPurifier_Printer_ConfigForm_NullDecorator($type_obj);
|
$type_obj = new HTMLPurifier_Printer_ConfigForm_NullDecorator($type_obj);
|
||||||
}
|
}
|
||||||
$ret .= $type_obj->render($ns, $directive, $value, $this->name, $this->config);
|
$ret .= $type_obj->render($ns, $directive, $value, $this->name, array($this->genConfig, $this->config));
|
||||||
$ret .= $this->end('td');
|
$ret .= $this->end('td');
|
||||||
$ret .= $this->end('tr');
|
$ret .= $this->end('tr');
|
||||||
}
|
}
|
||||||
@ -180,7 +198,14 @@ class HTMLPurifier_Printer_ConfigForm_NullDecorator extends HTMLPurifier_Printer
|
|||||||
$this->obj = $obj;
|
$this->obj = $obj;
|
||||||
}
|
}
|
||||||
public function render($ns, $directive, $value, $name, $config) {
|
public function render($ns, $directive, $value, $name, $config) {
|
||||||
$this->prepareGenerator($config);
|
if (is_array($config) && isset($config[0])) {
|
||||||
|
$gen_config = $config[0];
|
||||||
|
$config = $config[1];
|
||||||
|
} else {
|
||||||
|
$gen_config = $config;
|
||||||
|
}
|
||||||
|
$this->prepareGenerator($gen_config);
|
||||||
|
|
||||||
$ret = '';
|
$ret = '';
|
||||||
$ret .= $this->start('label', array('for' => "$name:Null_$ns.$directive"));
|
$ret .= $this->start('label', array('for' => "$name:Null_$ns.$directive"));
|
||||||
$ret .= $this->element('span', "$ns.$directive:", array('class' => 'verbose'));
|
$ret .= $this->element('span', "$ns.$directive:", array('class' => 'verbose'));
|
||||||
@ -202,7 +227,7 @@ class HTMLPurifier_Printer_ConfigForm_NullDecorator extends HTMLPurifier_Printer
|
|||||||
$ret .= $this->elementEmpty('input', $attr);
|
$ret .= $this->elementEmpty('input', $attr);
|
||||||
$ret .= $this->text(' or ');
|
$ret .= $this->text(' or ');
|
||||||
$ret .= $this->elementEmpty('br');
|
$ret .= $this->elementEmpty('br');
|
||||||
$ret .= $this->obj->render($ns, $directive, $value, $name, $config);
|
$ret .= $this->obj->render($ns, $directive, $value, $name, array($gen_config, $config));
|
||||||
return $ret;
|
return $ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -214,22 +239,33 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
|
|||||||
public $cols = 18;
|
public $cols = 18;
|
||||||
public $rows = 5;
|
public $rows = 5;
|
||||||
public function render($ns, $directive, $value, $name, $config) {
|
public function render($ns, $directive, $value, $name, $config) {
|
||||||
$this->prepareGenerator($config);
|
if (is_array($config) && isset($config[0])) {
|
||||||
|
$gen_config = $config[0];
|
||||||
|
$config = $config[1];
|
||||||
|
} else {
|
||||||
|
$gen_config = $config;
|
||||||
|
}
|
||||||
|
$this->prepareGenerator($gen_config);
|
||||||
// this should probably be split up a little
|
// this should probably be split up a little
|
||||||
$ret = '';
|
$ret = '';
|
||||||
$def = $config->def->info[$ns][$directive];
|
$def = $config->def->info[$ns][$directive];
|
||||||
|
if (is_int($def)) {
|
||||||
|
$type = abs($def);
|
||||||
|
} else {
|
||||||
|
$type = $def->type;
|
||||||
|
}
|
||||||
if (is_array($value)) {
|
if (is_array($value)) {
|
||||||
switch ($def->type) {
|
switch ($type) {
|
||||||
case 'lookup':
|
case HTMLPurifier_VarParser::LOOKUP:
|
||||||
$array = $value;
|
$array = $value;
|
||||||
$value = array();
|
$value = array();
|
||||||
foreach ($array as $val => $b) {
|
foreach ($array as $val => $b) {
|
||||||
$value[] = $val;
|
$value[] = $val;
|
||||||
}
|
}
|
||||||
case 'list':
|
case HTMLPurifier_VarParser::ALIST:
|
||||||
$value = implode(PHP_EOL, $value);
|
$value = implode(PHP_EOL, $value);
|
||||||
break;
|
break;
|
||||||
case 'hash':
|
case HTMLPurifier_VarParser::HASH:
|
||||||
$nvalue = '';
|
$nvalue = '';
|
||||||
foreach ($value as $i => $v) {
|
foreach ($value as $i => $v) {
|
||||||
$nvalue .= "$i:$v" . PHP_EOL;
|
$nvalue .= "$i:$v" . PHP_EOL;
|
||||||
@ -240,7 +276,7 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
|
|||||||
$value = '';
|
$value = '';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($def->type === 'mixed') {
|
if ($type === HTMLPurifier_VarParser::MIXED) {
|
||||||
return 'Not supported';
|
return 'Not supported';
|
||||||
$value = serialize($value);
|
$value = serialize($value);
|
||||||
}
|
}
|
||||||
@ -249,7 +285,7 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
|
|||||||
'id' => "$name:$ns.$directive"
|
'id' => "$name:$ns.$directive"
|
||||||
);
|
);
|
||||||
if ($value === null) $attr['disabled'] = 'disabled';
|
if ($value === null) $attr['disabled'] = 'disabled';
|
||||||
if (is_array($def->allowed)) {
|
if (isset($def->allowed)) {
|
||||||
$ret .= $this->start('select', $attr);
|
$ret .= $this->start('select', $attr);
|
||||||
foreach ($def->allowed as $val => $b) {
|
foreach ($def->allowed as $val => $b) {
|
||||||
$attr = array();
|
$attr = array();
|
||||||
@ -258,8 +294,11 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
|
|||||||
}
|
}
|
||||||
$ret .= $this->end('select');
|
$ret .= $this->end('select');
|
||||||
} elseif (
|
} elseif (
|
||||||
$def->type == 'text' || $def->type == 'itext' ||
|
$type === HTMLPurifier_VarParser::TEXT ||
|
||||||
$def->type == 'list' || $def->type == 'hash' || $def->type == 'lookup'
|
$type === HTMLPurifier_VarParser::ITEXT ||
|
||||||
|
$type === HTMLPurifier_VarParser::ALIST ||
|
||||||
|
$type === HTMLPurifier_VarParser::HASH ||
|
||||||
|
$type === HTMLPurifier_VarParser::LOOKUP
|
||||||
) {
|
) {
|
||||||
$attr['cols'] = $this->cols;
|
$attr['cols'] = $this->cols;
|
||||||
$attr['rows'] = $this->rows;
|
$attr['rows'] = $this->rows;
|
||||||
@ -280,7 +319,13 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
|
|||||||
*/
|
*/
|
||||||
class HTMLPurifier_Printer_ConfigForm_bool extends HTMLPurifier_Printer {
|
class HTMLPurifier_Printer_ConfigForm_bool extends HTMLPurifier_Printer {
|
||||||
public function render($ns, $directive, $value, $name, $config) {
|
public function render($ns, $directive, $value, $name, $config) {
|
||||||
$this->prepareGenerator($config);
|
if (is_array($config) && isset($config[0])) {
|
||||||
|
$gen_config = $config[0];
|
||||||
|
$config = $config[1];
|
||||||
|
} else {
|
||||||
|
$gen_config = $config;
|
||||||
|
}
|
||||||
|
$this->prepareGenerator($gen_config);
|
||||||
$ret = '';
|
$ret = '';
|
||||||
$ret .= $this->start('div', array('id' => "$name:$ns.$directive"));
|
$ret .= $this->start('div', array('id' => "$name:$ns.$directive"));
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
|
|||||||
|
|
||||||
// local variables
|
// local variables
|
||||||
$result = array();
|
$result = array();
|
||||||
$generator = new HTMLPurifier_Generator();
|
$generator = new HTMLPurifier_Generator($config, $context);
|
||||||
$escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags');
|
$escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags');
|
||||||
$e = $context->get('ErrorCollector', true);
|
$e = $context->get('ErrorCollector', true);
|
||||||
|
|
||||||
@ -169,7 +169,7 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
|
|||||||
if ($escape_invalid_tags) {
|
if ($escape_invalid_tags) {
|
||||||
if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag to text');
|
if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag to text');
|
||||||
$result[] = new HTMLPurifier_Token_Text(
|
$result[] = new HTMLPurifier_Token_Text(
|
||||||
$generator->generateFromToken($token, $config, $context)
|
$generator->generateFromToken($token)
|
||||||
);
|
);
|
||||||
} elseif ($e) {
|
} elseif ($e) {
|
||||||
$e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag removed');
|
$e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag removed');
|
||||||
@ -209,7 +209,7 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
|
|||||||
if ($skipped_tags === false) {
|
if ($skipped_tags === false) {
|
||||||
if ($escape_invalid_tags) {
|
if ($escape_invalid_tags) {
|
||||||
$result[] = new HTMLPurifier_Token_Text(
|
$result[] = new HTMLPurifier_Token_Text(
|
||||||
$generator->generateFromToken($token, $config, $context)
|
$generator->generateFromToken($token)
|
||||||
);
|
);
|
||||||
if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Stray end tag to text');
|
if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Stray end tag to text');
|
||||||
} elseif ($e) {
|
} elseif ($e) {
|
||||||
|
@ -13,7 +13,7 @@ class HTMLPurifier_Strategy_RemoveForeignElements extends HTMLPurifier_Strategy
|
|||||||
|
|
||||||
public function execute($tokens, $config, $context) {
|
public function execute($tokens, $config, $context) {
|
||||||
$definition = $config->getHTMLDefinition();
|
$definition = $config->getHTMLDefinition();
|
||||||
$generator = new HTMLPurifier_Generator();
|
$generator = new HTMLPurifier_Generator($config, $context);
|
||||||
$result = array();
|
$result = array();
|
||||||
|
|
||||||
$escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags');
|
$escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags');
|
||||||
@ -101,7 +101,7 @@ class HTMLPurifier_Strategy_RemoveForeignElements extends HTMLPurifier_Strategy
|
|||||||
// invalid tag, generate HTML representation and insert in
|
// invalid tag, generate HTML representation and insert in
|
||||||
if ($e) $e->send(E_WARNING, 'Strategy_RemoveForeignElements: Foreign element to text');
|
if ($e) $e->send(E_WARNING, 'Strategy_RemoveForeignElements: Foreign element to text');
|
||||||
$token = new HTMLPurifier_Token_Text(
|
$token = new HTMLPurifier_Token_Text(
|
||||||
$generator->generateFromToken($token, $config, $context)
|
$generator->generateFromToken($token)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
// check if we need to destroy all of the tag's children
|
// check if we need to destroy all of the tag's children
|
||||||
|
@ -58,11 +58,10 @@ style="float:right;">
|
|||||||
|
|
||||||
$schema_builder = new HTMLPurifier_ConfigSchema_Builder_ConfigSchema();
|
$schema_builder = new HTMLPurifier_ConfigSchema_Builder_ConfigSchema();
|
||||||
$schema = $schema_builder->build($interchange);
|
$schema = $schema_builder->build($interchange);
|
||||||
HTMLPurifier_ConfigSchema::instance($schema);
|
|
||||||
|
|
||||||
$config = HTMLPurifier_Config::loadArrayFromForm($_GET, 'config');
|
$config = HTMLPurifier_Config::loadArrayFromForm($_GET, 'config', true, true, $schema);
|
||||||
$printer = new HTMLPurifier_Printer_ConfigForm('config', '?doc#%s');
|
$printer = new HTMLPurifier_Printer_ConfigForm('config', '?doc#%s');
|
||||||
echo $printer->render($config);
|
echo $printer->render(array(HTMLPurifier_Config::createDefault(), $config));
|
||||||
|
|
||||||
?>
|
?>
|
||||||
</form>
|
</form>
|
||||||
|
@ -13,8 +13,11 @@ if (file_exists('printDefinition.settings.php')) {
|
|||||||
include 'printDefinition.settings.php';
|
include 'printDefinition.settings.php';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$gen_config = HTMLPurifier_Config::createDefault();
|
||||||
$printer_html_definition = new HTMLPurifier_Printer_HTMLDefinition();
|
$printer_html_definition = new HTMLPurifier_Printer_HTMLDefinition();
|
||||||
|
$printer_html_definition->prepareGenerator($gen_config);
|
||||||
$printer_css_definition = new HTMLPurifier_Printer_CSSDefinition();
|
$printer_css_definition = new HTMLPurifier_Printer_CSSDefinition();
|
||||||
|
$printer_css_definition->prepareGenerator($gen_config);
|
||||||
|
|
||||||
$printer_config_form = new HTMLPurifier_Printer_ConfigForm(
|
$printer_config_form = new HTMLPurifier_Printer_ConfigForm(
|
||||||
'config',
|
'config',
|
||||||
|
@ -6,6 +6,7 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
|
|||||||
public function setup() {
|
public function setup() {
|
||||||
generate_mock_once('HTMLPurifier_Language');
|
generate_mock_once('HTMLPurifier_Language');
|
||||||
generate_mock_once('HTMLPurifier_Generator');
|
generate_mock_once('HTMLPurifier_Generator');
|
||||||
|
parent::setup();
|
||||||
}
|
}
|
||||||
|
|
||||||
function test() {
|
function test() {
|
||||||
@ -20,14 +21,13 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
|
|||||||
|
|
||||||
$line = false;
|
$line = false;
|
||||||
|
|
||||||
$context = new HTMLPurifier_Context();
|
$this->context->register('Locale', $language);
|
||||||
$context->register('Locale', $language);
|
$this->context->register('CurrentLine', $line);
|
||||||
$context->register('CurrentLine', $line);
|
|
||||||
|
|
||||||
$generator = new HTMLPurifier_Generator();
|
$generator = new HTMLPurifier_Generator($this->config, $this->context);
|
||||||
$context->register('Generator', $generator);
|
$this->context->register('Generator', $generator);
|
||||||
|
|
||||||
$collector = new HTMLPurifier_ErrorCollector($context);
|
$collector = new HTMLPurifier_ErrorCollector($this->context);
|
||||||
|
|
||||||
$line = 23;
|
$line = 23;
|
||||||
$collector->send(E_ERROR, 'message-1');
|
$collector->send(E_ERROR, 'message-1');
|
||||||
@ -48,23 +48,21 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
|
|||||||
|
|
||||||
$config = HTMLPurifier_Config::create(array('Core.MaintainLineNumbers' => true));
|
$config = HTMLPurifier_Config::create(array('Core.MaintainLineNumbers' => true));
|
||||||
|
|
||||||
$this->assertIdentical($collector->getHTMLFormatted($config), $formatted_result);
|
$this->assertIdentical($collector->getHTMLFormatted($this->config), $formatted_result);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function testNoErrors() {
|
function testNoErrors() {
|
||||||
$language = new HTMLPurifier_LanguageMock();
|
$language = new HTMLPurifier_LanguageMock();
|
||||||
$language->setReturnValue('getMessage', 'No errors', array('ErrorCollector: No errors'));
|
$language->setReturnValue('getMessage', 'No errors', array('ErrorCollector: No errors'));
|
||||||
$context = new HTMLPurifier_Context();
|
$this->context->register('Locale', $language);
|
||||||
$context->register('Locale', $language);
|
|
||||||
|
|
||||||
$generator = new HTMLPurifier_Generator();
|
$generator = new HTMLPurifier_Generator($this->config, $this->context);
|
||||||
$context->register('Generator', $generator);
|
$this->context->register('Generator', $generator);
|
||||||
|
|
||||||
$collector = new HTMLPurifier_ErrorCollector($context);
|
$collector = new HTMLPurifier_ErrorCollector($this->context);
|
||||||
$formatted_result = '<p>No errors</p>';
|
$formatted_result = '<p>No errors</p>';
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
$this->assertIdentical($collector->getHTMLFormatted($this->config), $formatted_result);
|
||||||
$this->assertIdentical($collector->getHTMLFormatted($config), $formatted_result);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function testNoLineNumbers() {
|
function testNoLineNumbers() {
|
||||||
@ -72,13 +70,12 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
|
|||||||
$language->setReturnValue('getMessage', 'Message 1', array('message-1'));
|
$language->setReturnValue('getMessage', 'Message 1', array('message-1'));
|
||||||
$language->setReturnValue('getMessage', 'Message 2', array('message-2'));
|
$language->setReturnValue('getMessage', 'Message 2', array('message-2'));
|
||||||
$language->setReturnValue('getErrorName', 'Error', array(E_ERROR));
|
$language->setReturnValue('getErrorName', 'Error', array(E_ERROR));
|
||||||
$context = new HTMLPurifier_Context();
|
$this->context->register('Locale', $language);
|
||||||
$context->register('Locale', $language);
|
|
||||||
|
|
||||||
$generator = new HTMLPurifier_Generator();
|
$generator = new HTMLPurifier_Generator($this->config, $this->context);
|
||||||
$context->register('Generator', $generator);
|
$this->context->register('Generator', $generator);
|
||||||
|
|
||||||
$collector = new HTMLPurifier_ErrorCollector($context);
|
$collector = new HTMLPurifier_ErrorCollector($this->context);
|
||||||
$collector->send(E_ERROR, 'message-1');
|
$collector->send(E_ERROR, 'message-1');
|
||||||
$collector->send(E_ERROR, 'message-2');
|
$collector->send(E_ERROR, 'message-2');
|
||||||
|
|
||||||
@ -91,23 +88,21 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
|
|||||||
$formatted_result =
|
$formatted_result =
|
||||||
'<ul><li><strong>Error</strong>: Message 1</li>'.
|
'<ul><li><strong>Error</strong>: Message 1</li>'.
|
||||||
'<li><strong>Error</strong>: Message 2</li></ul>';
|
'<li><strong>Error</strong>: Message 2</li></ul>';
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
$this->assertIdentical($collector->getHTMLFormatted($this->config), $formatted_result);
|
||||||
$this->assertIdentical($collector->getHTMLFormatted($config), $formatted_result);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function testContextSubstitutions() {
|
function testContextSubstitutions() {
|
||||||
|
|
||||||
$language = new HTMLPurifier_LanguageMock();
|
$language = new HTMLPurifier_LanguageMock();
|
||||||
$context = new HTMLPurifier_Context();
|
$this->context->register('Locale', $language);
|
||||||
$context->register('Locale', $language);
|
|
||||||
|
|
||||||
$generator = new HTMLPurifier_Generator();
|
$generator = new HTMLPurifier_Generator($this->config, $this->context);
|
||||||
$context->register('Generator', $generator);
|
$this->context->register('Generator', $generator);
|
||||||
|
|
||||||
$current_token = false;
|
$current_token = false;
|
||||||
$context->register('CurrentToken', $current_token);
|
$this->context->register('CurrentToken', $current_token);
|
||||||
|
|
||||||
$collector = new HTMLPurifier_ErrorCollector($context);
|
$collector = new HTMLPurifier_ErrorCollector($this->context);
|
||||||
|
|
||||||
// 0
|
// 0
|
||||||
$current_token = new HTMLPurifier_Token_Start('a', array('href' => 'http://example.com'), 32);
|
$current_token = new HTMLPurifier_Token_Start('a', array('href' => 'http://example.com'), 32);
|
||||||
@ -123,7 +118,7 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
|
|||||||
$collector->send(E_NOTICE, 'message-attr'); // test when context isn't available
|
$collector->send(E_NOTICE, 'message-attr'); // test when context isn't available
|
||||||
|
|
||||||
// 2
|
// 2
|
||||||
$context->register('CurrentAttr', $current_attr);
|
$this->context->register('CurrentAttr', $current_attr);
|
||||||
$collector->send(E_NOTICE, 'message-attr');
|
$collector->send(E_NOTICE, 'message-attr');
|
||||||
|
|
||||||
$result = array(
|
$result = array(
|
||||||
|
@ -37,7 +37,7 @@ class HTMLPurifier_LanguageTest extends HTMLPurifier_Harness
|
|||||||
function test_formatMessage_tokenParameter() {
|
function test_formatMessage_tokenParameter() {
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
$config = HTMLPurifier_Config::createDefault();
|
||||||
$context = new HTMLPurifier_Context();
|
$context = new HTMLPurifier_Context();
|
||||||
$generator = new HTMLPurifier_Generator(); // replace with mock if this gets icky
|
$generator = new HTMLPurifier_Generator($config, $context); // replace with mock if this gets icky
|
||||||
$context->register('Generator', $generator);
|
$context->register('Generator', $generator);
|
||||||
$lang = new HTMLPurifier_Language($config, $context);
|
$lang = new HTMLPurifier_Language($config, $context);
|
||||||
$lang->_loaded = true;
|
$lang->_loaded = true;
|
||||||
|
Loading…
Reference in New Issue
Block a user