Make WordPress Core

Ticket #15006: 15006.diff

File 15006.diff, 1.2 KB (added by codeclarified, 11 years ago)

Updates to wpautop() regex

  • wp-includes/formatting.php

    diff --git wp-includes/formatting.php wp-includes/formatting.php
    index 3828c6a..284c9df 100644
    function wpautop($pee, $br = true) { 
    421421                $pee .= '<p>' . trim($tinkle, "\n") . "</p>\n";
    422422        }
    423423
    424         $pee = preg_replace('|<p>\s*</p>|', '', $pee); // under certain strange conditions it could create a P of entirely whitespace
     424        $pee = preg_replace('|<p[^>]*>\s*</p>|', '', $pee); // under certain strange conditions it could create a P of entirely whitespace
    425425        $pee = preg_replace('!<p>([^<]+)</(div|address|form)>!', "<p>$1</p></$2>", $pee);
    426426        $pee = preg_replace('!<p>\s*(</?' . $allblocks . '[^>]*>)\s*</p>!', "$1", $pee); // don't pee all over a tag
    427427        $pee = preg_replace("|<p>(<li.+?)</p>|", "$1", $pee); // problem with nested lists
    function wpautop($pee, $br = true) { 
    429429        $pee = str_replace('</blockquote></p>', '</p></blockquote>', $pee);
    430430        $pee = preg_replace('!<p>\s*(</?' . $allblocks . '[^>]*>)!', "$1", $pee);
    431431        $pee = preg_replace('!(</?' . $allblocks . '[^>]*>)\s*</p>!', "$1", $pee);
     432        $pee = balanceTags($pee, true);
    432433
    433434        if ( $br ) {
    434435                $pee = preg_replace_callback('/<(script|style).*?<\/\\1>/s', '_autop_newline_preservation_helper', $pee);