Work around fatal error caused by mbstring.func_overload = 2. Props codestyling . fixes #5599 for trunk
git-svn-id: https://develop.svn.wordpress.org/trunk@8420 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
3f555491f3
commit
ee18970580
@ -58,21 +58,39 @@ class StringReader {
|
|||||||
function StringReader($str='') {
|
function StringReader($str='') {
|
||||||
$this->_str = $str;
|
$this->_str = $str;
|
||||||
$this->_pos = 0;
|
$this->_pos = 0;
|
||||||
|
// If string functions are overloaded, we need to use the mb versions
|
||||||
|
$this->is_overloaded = ((ini_get("mbstring.func_overload") & 2) != 0) && function_exists('mb_substr');
|
||||||
|
}
|
||||||
|
|
||||||
|
function _substr($string, $start, $length) {
|
||||||
|
if ($this->is_overloaded) {
|
||||||
|
return mb_substr($string,$start,$length,'ascii');
|
||||||
|
} else {
|
||||||
|
return substr($string,$start,$length);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function _strlen($string) {
|
||||||
|
if ($this->is_overloaded) {
|
||||||
|
return mb_strlen($string,'ascii');
|
||||||
|
} else {
|
||||||
|
return strlen($string);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function read($bytes) {
|
function read($bytes) {
|
||||||
$data = substr($this->_str, $this->_pos, $bytes);
|
$data = $this->_substr($this->_str, $this->_pos, $bytes);
|
||||||
$this->_pos += $bytes;
|
$this->_pos += $bytes;
|
||||||
if (strlen($this->_str)<$this->_pos)
|
if ($this->_strlen($this->_str)<$this->_pos)
|
||||||
$this->_pos = strlen($this->_str);
|
$this->_pos = $this->_strlen($this->_str);
|
||||||
|
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
function seekto($pos) {
|
function seekto($pos) {
|
||||||
$this->_pos = $pos;
|
$this->_pos = $pos;
|
||||||
if (strlen($this->_str)<$this->_pos)
|
if ($this->_strlen($this->_str)<$this->_pos)
|
||||||
$this->_pos = strlen($this->_str);
|
$this->_pos = $this->_strlen($this->_str);
|
||||||
return $this->_pos;
|
return $this->_pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,9 +99,8 @@ class StringReader {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function length() {
|
function length() {
|
||||||
return strlen($this->_str);
|
return $this->_strlen($this->_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -149,6 +166,8 @@ class FileReader {
|
|||||||
// over it (it assumes knowledge of StringReader internals)
|
// over it (it assumes knowledge of StringReader internals)
|
||||||
class CachedFileReader extends StringReader {
|
class CachedFileReader extends StringReader {
|
||||||
function CachedFileReader($filename) {
|
function CachedFileReader($filename) {
|
||||||
|
parent::StringReader();
|
||||||
|
|
||||||
if (file_exists($filename)) {
|
if (file_exists($filename)) {
|
||||||
|
|
||||||
$length=filesize($filename);
|
$length=filesize($filename);
|
||||||
@ -159,7 +178,6 @@ class CachedFileReader extends StringReader {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$this->_str = fread($fd, $length);
|
$this->_str = fread($fd, $length);
|
||||||
$this->_pos = 0;
|
|
||||||
fclose($fd);
|
fclose($fd);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user