forked from extern/egroupware
Fix newline issue
This commit is contained in:
parent
ea5535284f
commit
9d39f2ec98
@ -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;
|
||||||
|
@ -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'];
|
||||||
|
Loading…
Reference in New Issue
Block a user