X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/899389d1e4043331309c0433543419258b230b60..38ac4bc40322ecdc4052db4263466573e01fa51f:/wp-includes/shortcodes.php diff --git a/wp-includes/shortcodes.php b/wp-includes/shortcodes.php index e3c267a4..2661201b 100644 --- a/wp-includes/shortcodes.php +++ b/wp-includes/shortcodes.php @@ -184,9 +184,10 @@ function has_shortcode( $content, $tag ) { * @global array $shortcode_tags List of shortcode tags and their callback hooks. * * @param string $content Content to search for shortcodes. + * @param bool $ignore_html When true, shortcodes inside HTML elements will be skipped. * @return string Content with shortcodes filtered out. */ -function do_shortcode($content) { +function do_shortcode( $content, $ignore_html = false ) { global $shortcode_tags; if ( false === strpos( $content, '[' ) ) { @@ -196,8 +197,24 @@ function do_shortcode($content) { if (empty($shortcode_tags) || !is_array($shortcode_tags)) return $content; + $tagnames = array_keys($shortcode_tags); + $tagregexp = join( '|', array_map('preg_quote', $tagnames) ); + $pattern = "/\\[($tagregexp)/s"; + + if ( 1 !== preg_match( $pattern, $content ) ) { + // Avoids parsing HTML when there are no shortcodes or embeds anyway. + return $content; + } + + $content = do_shortcodes_in_html_tags( $content, $ignore_html ); + $pattern = get_shortcode_regex(); - return preg_replace_callback( "/$pattern/s", 'do_shortcode_tag', $content ); + $content = preg_replace_callback( "/$pattern/s", 'do_shortcode_tag', $content ); + + // Always restore square braces so we don't break things like is found. + . '-(?!->)' // Dash not followed by end of comment. + . '[^\-]*+' // Consume non-dashes. + . ')*+' // Loop possessively. + . '(?:-->)?'; // End of comment. If not found, match all input. + + $regex = + '/(' // Capture the entire match. + . '<' // Find start of element. + . '(?(?=!--)' // Is this a comment? + . $comment_regex // Find end of comment. + . '|' + . '[^>]*>?' // Find end of element. If not found, match all input. + . ')' + . ')/s'; + + $textarr = preg_split( $regex, $content, -1, PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY ); + + foreach ( $textarr as &$element ) { + if ( '<' !== $element[0] ) { + continue; + } + + $noopen = false === strpos( $element, '[' ); + $noclose = false === strpos( $element, ']' ); + if ( $noopen || $noclose ) { + // This element does not contain shortcodes. + if ( $noopen xor $noclose ) { + // Need to encode stray [ or ] chars. + $element = strtr( $element, $trans ); + } + continue; + } + + if ( $ignore_html || '