aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/includes/cache.php
diff options
context:
space:
mode:
authorAndreas Fischer <bantu@phpbb.com>2011-01-07 15:41:12 +0100
committerAndreas Fischer <bantu@phpbb.com>2011-01-07 15:41:12 +0100
commita469e804930e66c244da27deb4dc94b5e280659f (patch)
tree3bab2abf053b81af81aab73d97c39d7f622f5130 /phpBB/includes/cache.php
parent7a2348bf7f0ee67856cc5ae15591b7d1b7c48763 (diff)
parent95cf47c4ef41b1ad7c5dc27eb9a078769851acf8 (diff)
downloadforums-a469e804930e66c244da27deb4dc94b5e280659f.tar
forums-a469e804930e66c244da27deb4dc94b5e280659f.tar.gz
forums-a469e804930e66c244da27deb4dc94b5e280659f.tar.bz2
forums-a469e804930e66c244da27deb4dc94b5e280659f.tar.xz
forums-a469e804930e66c244da27deb4dc94b5e280659f.zip
Merge branch 'ticket/rxu/9933' into develop-olympus
* ticket/rxu/9933: [ticket/9933] Create unit test for word censor regular expression. [ticket/9933] Move word censor regex into separate function in functions.php [ticket/9933] Wrong handling consecutive multiple asterisks in word censor
Diffstat (limited to 'phpBB/includes/cache.php')
-rw-r--r--phpBB/includes/cache.php19
1 files changed, 1 insertions, 18 deletions
diff --git a/phpBB/includes/cache.php b/phpBB/includes/cache.php
index b50fab4ca2..612adcca4f 100644
--- a/phpBB/includes/cache.php
+++ b/phpBB/includes/cache.php
@@ -82,26 +82,9 @@ class cache extends acm
$result = $db->sql_query($sql);
$censors = array();
- $unicode = ((version_compare(PHP_VERSION, '5.1.0', '>=') || (version_compare(PHP_VERSION, '5.0.0-dev', '<=') && version_compare(PHP_VERSION, '4.4.0', '>='))) && @preg_match('/\p{L}/u', 'a') !== false) ? true : false;
-
while ($row = $db->sql_fetchrow($result))
{
- if ($unicode)
- {
- // Unescape the asterisk to simplify further conversions
- $row['word'] = str_replace('\*', '*', preg_quote($row['word'], '#'));
-
- // Replace the asterisk inside the pattern, at the start and at the end of it with regexes
- $row['word'] = preg_replace(array('#(?<=[\p{Nd}\p{L}_])\*(?=[\p{Nd}\p{L}_])#iu', '#^\*#', '#\*$#'), array('([\x20]*?|[\p{Nd}\p{L}_-]*?)', '[\p{Nd}\p{L}_-]*?', '[\p{Nd}\p{L}_-]*?'), $row['word']);
-
- // Generate the final substitution
- $censors['match'][] = '#(?<![\p{Nd}\p{L}_-])(' . $row['word'] . ')(?![\p{Nd}\p{L}_-])#iu';
- }
- else
- {
- $censors['match'][] = '#(?<!\S)(' . str_replace('\*', '\S*?', preg_quote($row['word'], '#')) . ')(?!\S)#iu';
- }
-
+ $censors['match'][] = get_censor_preg_expression($row['word']);
$censors['replace'][] = $row['replacement'];
}
$db->sql_freeresult($result);