Don't place smilies inside of pre or code tags. Don't skip smilie after a smilie with an 8 in it. Fix regular expression used for smiley translations to work when there is only one registered emoticon.
Props solarissmoke, soulseekah, mdbitz, yonasy. ht to mdbitz for the Unit Tests and a comprehensive patch. Fixes #16448, #20124, #25303. Built from https://develop.svn.wordpress.org/trunk@26191 git-svn-id: http://core.svn.wordpress.org/trunk@26099 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
630619cf6c
commit
c2bc0e6836
|
@ -1793,18 +1793,36 @@ function translate_smiley( $matches ) {
|
|||
* @param string $text Content to convert smilies from text.
|
||||
* @return string Converted content with text smilies replaced with images.
|
||||
*/
|
||||
function convert_smilies($text) {
|
||||
function convert_smilies( $text ) {
|
||||
global $wp_smiliessearch;
|
||||
$output = '';
|
||||
if ( get_option('use_smilies') && !empty($wp_smiliessearch) ) {
|
||||
if ( get_option( 'use_smilies' ) && ! empty( $wp_smiliessearch ) ) {
|
||||
// HTML loop taken from texturize function, could possible be consolidated
|
||||
$textarr = preg_split("/(<.*>)/U", $text, -1, PREG_SPLIT_DELIM_CAPTURE); // capture the tags as well as in between
|
||||
$stop = count($textarr);// loop stuff
|
||||
for ($i = 0; $i < $stop; $i++) {
|
||||
$textarr = preg_split( '/(<.*>)/U', $text, -1, PREG_SPLIT_DELIM_CAPTURE ); // capture the tags as well as in between
|
||||
$stop = count( $textarr );// loop stuff
|
||||
|
||||
// Ignore proessing of specific tags
|
||||
$tags_to_ignore = 'code|pre|style|script|textarea';
|
||||
$ignore_block_element = '';
|
||||
|
||||
for ( $i = 0; $i < $stop; $i++ ) {
|
||||
$content = $textarr[$i];
|
||||
if ((strlen($content) > 0) && ('<' != $content[0])) { // If it's not a tag
|
||||
$content = preg_replace_callback($wp_smiliessearch, 'translate_smiley', $content);
|
||||
|
||||
// If we're in an ignore block, wait until we find its closing tag
|
||||
if ( '' == $ignore_block_element && preg_match( '/^<(' . $tags_to_ignore . ')>/', $content, $matches ) ) {
|
||||
$ignore_block_element = $matches[1];
|
||||
}
|
||||
|
||||
// If it's not a tag and not in ignore block
|
||||
if ( '' == $ignore_block_element && strlen( $content ) > 0 && '<' != $content[0] ) {
|
||||
$content = preg_replace_callback( $wp_smiliessearch, 'translate_smiley', $content );
|
||||
}
|
||||
|
||||
// did we exit ignore block
|
||||
if ( '' != $ignore_block_element && '</' . $ignore_block_element . '>' == $content ) {
|
||||
$ignore_block_element = '';
|
||||
}
|
||||
|
||||
$output .= $content;
|
||||
}
|
||||
} else {
|
||||
|
|
|
@ -2477,6 +2477,7 @@ function _mce_set_direction( $input ) {
|
|||
return $input;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Convert smiley code to the icon graphic file equivalent.
|
||||
*
|
||||
|
@ -2566,7 +2567,7 @@ function smilies_init() {
|
|||
*/
|
||||
krsort($wpsmiliestrans);
|
||||
|
||||
$wp_smiliessearch = '/(?:\s|^)';
|
||||
$wp_smiliessearch = '/((?:\s|^)';
|
||||
|
||||
$subchar = '';
|
||||
foreach ( (array) $wpsmiliestrans as $smiley => $img ) {
|
||||
|
@ -2576,7 +2577,7 @@ function smilies_init() {
|
|||
// new subpattern?
|
||||
if ($firstchar != $subchar) {
|
||||
if ($subchar != '') {
|
||||
$wp_smiliessearch .= ')|(?:\s|^)';
|
||||
$wp_smiliessearch .= ')(?=\s|$))|((?:\s|^)'; ;
|
||||
}
|
||||
$subchar = $firstchar;
|
||||
$wp_smiliessearch .= preg_quote($firstchar, '/') . '(?:';
|
||||
|
@ -2586,7 +2587,8 @@ function smilies_init() {
|
|||
$wp_smiliessearch .= preg_quote($rest, '/');
|
||||
}
|
||||
|
||||
$wp_smiliessearch .= ')(?:\s|$)/m';
|
||||
$wp_smiliessearch .= ')(?=\s|$))/m';
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue