version 1.10, 2016/11/10 19:48:22
|
version 1.11, 2016/11/10 21:53:56
|
Line 1858 sub fix_paragraphs_inside {
|
Line 1858 sub fix_paragraphs_inside {
|
push(@new_children, $doc->createElement('p')); |
push(@new_children, $doc->createElement('p')); |
} |
} |
$p = undef; |
$p = undef; |
|
# ignore the next node if it is a br (the paragraph default margin will take as much space) |
|
# (ignoring whitespace) |
|
while (defined $next && $next->nodeType == XML_TEXT_NODE && $next->nodeValue =~ /^[ \t\f\n\r]*$/) { |
|
my $next2 = $next->nextSibling; |
|
$node->removeChild($next); |
|
$next = $next2; |
|
} |
|
if (defined $next && $next->nodeType == XML_ELEMENT_NODE && $next->nodeName eq 'br') { |
|
my $next2 = $next->nextSibling; |
|
$node->removeChild($next); |
|
$next = $next2; |
|
} |
} elsif ($child->nodeType == XML_ELEMENT_NODE && string_in_array(\@inline_like_block, $child->nodeName)) { |
} elsif ($child->nodeType == XML_ELEMENT_NODE && string_in_array(\@inline_like_block, $child->nodeName)) { |
# inline_like_block: use the paragraph if there is one, otherwise do not create one |
# inline_like_block: use the paragraph if there is one, otherwise do not create one |
if (defined $p) { |
if (defined $p) { |
Line 2034 sub fix_paragraph {
|
Line 2046 sub fix_paragraph {
|
if (!defined $left || !$left_needs_p) { |
if (!defined $left || !$left_needs_p) { |
$replacement->appendChild($middle); |
$replacement->appendChild($middle); |
} |
} |
|
# ignore the next node if it is a br (the paragraph default margin will take as much space) |
|
my $first_right; |
|
if (defined $right) { |
|
$first_right = $right->firstChild; |
|
# ignore non-nbsp whitespace |
|
while (defined $first_right && $first_right->nodeType == XML_TEXT_NODE && |
|
$first_right->nodeValue =~ /^[ \t\f\n\r]*$/) { |
|
$first_right = $first_right->nextSibling; |
|
} |
|
} |
|
if (defined $first_right && $first_right->nodeType == XML_ELEMENT_NODE && |
|
$first_right->nodeName eq 'br') { |
|
$right->removeChild($first_right); |
|
} |
} else { |
} else { |
fix_paragraphs_inside($n, $all_block); |
fix_paragraphs_inside($n, $all_block); |
$replacement->appendChild($n); |
$replacement->appendChild($n); |