diff options
author | Urban Müller | 2011-11-15 14:41:34 +0000 |
---|---|---|
committer | Urban Müller | 2011-11-15 14:41:34 +0000 |
commit | 62a80d4a07941b1783dcbd3151f33f8f2c3b9cfa (patch) | |
tree | 2ff2c8228e9b37624d84f5e15ded53662ecd47eb /it.class | |
parent | 88321feeb17e271cbaa582dd2507f3591f65f5f7 (diff) | |
download | itools-62a80d4a07941b1783dcbd3151f33f8f2c3b9cfa.tar.gz itools-62a80d4a07941b1783dcbd3151f33f8f2c3b9cfa.tar.bz2 itools-62a80d4a07941b1783dcbd3151f33f8f2c3b9cfa.zip |
faster it::replace
Diffstat (limited to 'it.class')
-rw-r--r-- | it.class | 8 |
1 files changed, 3 insertions, 5 deletions
@@ -394,18 +394,16 @@ static function match($pattern, $string, $p = null) */ static function replace($replacements, $string, $p = array()) { - $patterns = array(); - - foreach (array_keys($replacements) as $pattern) + foreach ($replacements as $pattern => $dummy) $patterns[] = !preg_match('/\\\\[wb]|[!\x80-\xff]|\[\[:/i', $pattern) && !$p ? "!$pattern!i" : it::convertregex($complex = $pattern, $p); if (!$complex) - $result = preg_replace($patterns, array_values($replacements), $string); + $result = preg_replace($patterns, $replacements, $string); else { $oldlocale = setlocale(LC_CTYPE, 0); setlocale(LC_CTYPE, 'de_CH'); - $result = preg_replace($patterns, array_values($replacements), $string, isset($p['limit']) ? $p['limit'] : -1); + $result = preg_replace($patterns, $replacements, $string, isset($p['limit']) ? $p['limit'] : -1); setlocale(LC_CTYPE, $oldlocale); } |