Merge pull request #5216 from abanink/2337

solves 2337 Smiley Pack 1.04: some smiley keywords aren't replaced correctly
This commit is contained in:
Hypolite Petovan 2018-06-14 15:36:21 -04:00 committed by GitHub
commit 6191fab4d7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -145,6 +145,27 @@ class Smilies
return $params; return $params;
} }
/**
* Copied from http://php.net/manual/en/function.str-replace.php#88569
* Modified for camel caps: renamed stro_replace -> strOrigReplace
*
* When using str_replace(...), values that did not exist in the original string (but were put there by previous
* replacements) will be replaced continuously. This string replacement function is designed to replace the values
* in $search with those in $replace while not factoring in prior replacements. Note that this function will
* always look for the longest possible match first and then work its way down to individual characters.
*
* @param array $search list of strings or characters that need to be replaced
* @param array $replace list of strings or characters that will replace the corresponding values in $search
* @param string $subject the string on which this operation is being performed
*
* @return string $subject with all substrings in the $search array replaced by the values in the $replace array
*/
private static function strOrigReplace($search, $replace, $subject)
{
return strtr($subject, array_combine($search, $replace));
}
/** /**
* @brief Replaces text emoticons with graphical images * @brief Replaces text emoticons with graphical images
* *
@ -196,7 +217,7 @@ class Smilies
} }
} else { } else {
$params['string'] = preg_replace_callback('/<(3+)/', 'self::pregHeart', $params['string']); $params['string'] = preg_replace_callback('/<(3+)/', 'self::pregHeart', $params['string']);
$s = str_replace($params['texts'], $params['icons'], $params['string']); $s = self::strOrigReplace($params['texts'], $params['icons'], $params['string']);
} }
$s = preg_replace_callback('/<pre>(.*?)<\/pre>/ism', 'self::decode', $s); $s = preg_replace_callback('/<pre>(.*?)<\/pre>/ism', 'self::decode', $s);