diff options
-rw-r--r-- | feed.php | 2 | ||||
-rw-r--r-- | inc/utf8.php | 27 |
2 files changed, 12 insertions, 17 deletions
@@ -157,7 +157,7 @@ function cleanDesc($desc){ $desc = strip_tags($desc); $desc = preg_replace('/[\n\r\t]/',' ',$desc); $desc = preg_replace('/ /',' ',$desc); - $desc = substr($desc,0,250); + $desc = utf8_substr($desc,0,250); $desc = $desc.'...'; return $desc; } diff --git a/inc/utf8.php b/inc/utf8.php index 3e3edd67f..0b90c8586 100644 --- a/inc/utf8.php +++ b/inc/utf8.php @@ -111,24 +111,19 @@ function utf8_strlen($string){ /** * Unicode aware replacement for substr() * - * @todo Handle negative positions etc. - * @author Harry Fuecks <hfuecks@gmail.com> + * @author lmak at NOSPAM dot iti dot gr + * @link http://www.php.net/manual/en/function.substr.php * @see substr() */ -function utf8_substr($str, $start, $length=null){ - if ( is_null($length) ) { - $length = '*'; - } else { - $length = '{0,'.$length.'}'; - } - $pattern = '/^.{'.$start.'}(.'.$length.')/us'; - preg_match($pattern, $str, $matches); - - if ( isset($matches[1]) ) { - return $matches[1]; - } - return false; -} +function utf8_substr($str,$start,$length=null){ + preg_match_all("/./u", $str, $ar); + + if($length != null) { + return join("",array_slice($ar[0],$start,$length)); + } else { + return join("",array_slice($ar[0],$start)); + } +} /** * Unicode aware replacement for explode |