Fix newline issue

This commit is contained in:
Jörg Lehrke 2010-02-16 15:09:52 +00:00
parent ea5535284f
commit 9d39f2ec98
2 changed files with 35 additions and 12 deletions

View File

@ -6,9 +6,9 @@ $GLOBALS['_HORDE_STRING_CHARSET'] = 'iso-8859-1';
* The String:: class provides static methods for charset and locale safe * The String:: class provides static methods for charset and locale safe
* string manipulation. * string manipulation.
* *
* $Horde: framework/Util/String.php,v 1.43.6.31 2008/10/23 21:28:38 jan Exp $ * $Horde: framework/Util/String.php,v 1.43.6.38 2009-09-15 16:36:14 jan Exp $
* *
* Copyright 2003-2008 The Horde Project (http://www.horde.org/) * Copyright 2003-2009 The Horde Project (http://www.horde.org/)
* *
* See the enclosed file COPYING for license information (LGPL). If you * See the enclosed file COPYING for license information (LGPL). If you
* did not receive this file, see http://www.fsf.org/copyleft/lgpl.html. * did not receive this file, see http://www.fsf.org/copyleft/lgpl.html.
@ -86,6 +86,9 @@ class String {
} }
/* If the from and to character sets are identical, return now. */ /* If the from and to character sets are identical, return now. */
if ($from == $to) {
return $input;
}
$from = String::lower($from); $from = String::lower($from);
$to = String::lower($to); $to = String::lower($to);
if ($from == $to) { if ($from == $to) {
@ -94,6 +97,7 @@ class String {
if (is_array($input)) { if (is_array($input)) {
$tmp = array(); $tmp = array();
reset($input);
while (list($key, $val) = each($input)) { while (list($key, $val) = each($input)) {
$tmp[String::_convertCharset($key, $from, $to)] = String::convertCharset($val, $from, $to); $tmp[String::_convertCharset($key, $from, $to)] = String::convertCharset($val, $from, $to);
} }
@ -317,9 +321,12 @@ class String {
if (is_null($length)) { if (is_null($length)) {
$length = String::length($string, $charset) - $start; $length = String::length($string, $charset) - $start;
} }
if ($length == 0) { if ($length == 0) {
return ''; return '';
} }
/* Try mbstring. */
if (String::extensionExists('mbstring')) { if (String::extensionExists('mbstring')) {
if (is_null($charset)) { if (is_null($charset)) {
$charset = $GLOBALS['_HORDE_STRING_CHARSET']; $charset = $GLOBALS['_HORDE_STRING_CHARSET'];
@ -327,10 +334,27 @@ class String {
$old_error = error_reporting(0); $old_error = error_reporting(0);
$ret = mb_substr($string, $start, $length, String::_mbstringCharset($charset)); $ret = mb_substr($string, $start, $length, String::_mbstringCharset($charset));
error_reporting($old_error); error_reporting($old_error);
if (!empty($ret)) { /* mb_substr() returns empty string on failure. */
if (strlen($ret)) {
return $ret; return $ret;
} }
} }
/* Try iconv. */
if (function_exists('iconv_substr')) {
if (is_null($charset)) {
$charset = $GLOBALS['_HORDE_STRING_CHARSET'];
}
$old_error = error_reporting(0);
$ret = iconv_substr($string, $start, $length, $charset);
error_reporting($old_error);
/* iconv_substr() returns false on failure. */
if ($ret !== false) {
return $ret;
}
}
return substr($string, $start, $length); return substr($string, $start, $length);
} }
@ -349,9 +373,6 @@ class String {
$charset = $GLOBALS['_HORDE_STRING_CHARSET']; $charset = $GLOBALS['_HORDE_STRING_CHARSET'];
} }
$charset = String::lower($charset); $charset = String::lower($charset);
if ($charset == 'utf-8' || $charset == 'utf8') {
return strlen(utf8_decode($string));
}
if (String::extensionExists('mbstring')) { if (String::extensionExists('mbstring')) {
$old_error = error_reporting(0); $old_error = error_reporting(0);
$ret = mb_strlen($string, String::_mbstringCharset($charset)); $ret = mb_strlen($string, String::_mbstringCharset($charset));
@ -360,6 +381,9 @@ class String {
return $ret; return $ret;
} }
} }
if ($charset == 'utf-8' || $charset == 'utf8') {
return strlen(utf8_decode($string));
}
return strlen($string); return strlen($string);
} }
@ -482,9 +506,9 @@ class String {
$line = String::substr($string, 0, $width, 'utf-8'); $line = String::substr($string, 0, $width, 'utf-8');
$string = String::substr($string, String::length($line, 'utf-8'), null, 'utf-8'); $string = String::substr($string, String::length($line, 'utf-8'), null, 'utf-8');
// Make sure didn't cut a word, unless we want hard breaks anyway. // Make sure didn't cut a word, unless we want hard breaks anyway.
if (!$cut && preg_match('/^(.+?)(\s|\r?\n)/u', $string, $match)) { if (!$cut && preg_match('/^(.+?)((\s|\r?\n).*)/us', $string, $match)) {
$line .= $match[1]; $line .= $match[1];
$string = String::substr($string, String::length($match[1], 'utf-8'), null, 'utf-8'); $string = $match[2];
} }
// Wrap at existing line breaks. // Wrap at existing line breaks.
if (preg_match('/^(.*?)(\r?\n)(.*)$/u', $line, $match)) { if (preg_match('/^(.*?)(\r?\n)(.*)$/u', $line, $match)) {
@ -513,8 +537,7 @@ class String {
} }
// Hard wrap if necessary. // Hard wrap if necessary.
if ($cut) { if ($cut) {
$wrapped .= String::substr($line, 0, $width, 'utf-8') . $break; $wrapped .= $line . $break;
$string = String::substr($line, $width, null, 'utf-8') . $string;
continue; continue;
} }
$wrapped .= $line; $wrapped .= $line;

View File

@ -1180,7 +1180,7 @@ class Horde_iCalendar {
case 'QUOTED-PRINTABLE': case 'QUOTED-PRINTABLE':
if (!$this->isOldFormat()) if (!$this->isOldFormat())
{ {
$enconding = false; $encoding = false;
break; break;
} }
$params_str .= ';ENCODING=' . $params['ENCODING']; $params_str .= ';ENCODING=' . $params['ENCODING'];