function htmltidy_node_validate in HTML Tidy 7
Implementation of hook_node_validate().
File
- ./
htmltidy.node.inc, line 83 - The HTML Tidy hook implementations for Drupal's Node system.
Code
function htmltidy_node_validate($node) {
// Get a list of all formats that have this filter enabled.
$formats = htmltidy_get_formats();
// Iterate through each field.
$field_list = field_info_instances('node', $node->type);
foreach ($field_list as $field_name => $field_data) {
// Ignore empty fields.
if (isset($node->{$field_name})) {
// Iterate through the language of each field.
foreach ($node->{$field_name} as $language => $instances) {
// Iterate through each language's instance.
foreach ($instances as $instance_id => $instance) {
// Skip through non-numerically keyed values to avoid items like
// "[add_more] => Add another item".
if (!is_numeric($instance_id)) {
continue;
}
// Get a reference to the contents of this instance.
$contents =& $node->{$field_name}[$language][$instance_id]['value'];
// Act only on instances that are set to something.
if (isset($contents)) {
// Determine the text format of the instance.
$format =& $node->{$field_name}[$language][$instance_id]['format'];
// It's possible that the format may not be set because some field
// types (like plain text) don't specify text formats. As such,
// they won't want any filters run on them. We can simply ignore
// these instances.
// Check if this format has our filter enabled.
if (isset($format) && array_key_exists($format, $formats)) {
// Call all of the filters. If they're using this one, it'll fall
// into the proper order when they all run. When we get to ours,
// it'll set any warnings or errors for us.
global $_htmltidy_filter;
check_markup($contents, $format);
// Collect the errors and warnings if our filter was run.
$filtered =& $_htmltidy_filter['filtered'];
if (isset($filtered) && $filtered) {
$errors = $_htmltidy_filter['errors'];
$warnings = $_htmltidy_filter['warnings'];
}
else {
// Our filter isn't being run, so we have to run it through
// ourselves.
// If there are any settings, format them properly and remove
// any extraneous data elements.
if (isset($formats[$format])) {
$settings = unserialize($formats[$format]);
$settings = $settings['htmltidy_filter_' . $format];
}
// If not, create an empty container.
$settings = isset($settings) ? $settings : array();
// Get the tidied text and set the field value to it.
$clean = htmltidy_fragment($contents, TRUE, $settings, $errors, $warnings);
form_set_value(array(
'#parents' => array(
$field_name,
),
), $clean, $form_state);
}
// If there were any errors or warnings, act on them.
if ($errors || $warnings) {
// As a courtesy, display the original text to the editor.
$message = '<p>Original body:</p><pre>' . htmlentities($contents) . '</pre>';
// Report any errors.
if ($errors) {
$message .= theme('item_list', array_map('htmlentities', $errors));
form_set_error($field_name, $message);
}
// Report any warnings.
if ($warnings) {
drupal_set_message("The following HTML errors have been cleaned up automatically for you: " . theme('item_list', array(
'items' => array_map('htmlentities', $warnings),
)));
}
}
}
}
}
}
}
}
}