1
0
mirror of https://github.com/danielstjules/Stringy.git synced 2025-08-10 15:23:59 +02:00

Fix #129: Always use root namespace for mbstring functions

This commit is contained in:
Daniel St. Jules
2016-03-21 13:22:27 -07:00
parent b953a85d2c
commit a2d1ec535a

View File

@@ -52,7 +52,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
} }
$this->str = (string) $str; $this->str = (string) $str;
$this->encoding = $encoding ?: mb_internal_encoding(); $this->encoding = $encoding ?: \mb_internal_encoding();
} }
/** /**
@@ -122,7 +122,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
return static::create('', $this->encoding); return static::create('', $this->encoding);
} }
$substrIndex = $startIndex + mb_strlen($start, $this->encoding); $substrIndex = $startIndex + \mb_strlen($start, $this->encoding);
$endIndex = $this->indexOf($end, $substrIndex); $endIndex = $this->indexOf($end, $substrIndex);
if ($endIndex === false) { if ($endIndex === false) {
return static::create('', $this->encoding); return static::create('', $this->encoding);
@@ -148,7 +148,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
'/[-_\s]+(.)?/u', '/[-_\s]+(.)?/u',
function ($match) use ($encoding) { function ($match) use ($encoding) {
if (isset($match[1])) { if (isset($match[1])) {
return mb_strtoupper($match[1], $encoding); return \mb_strtoupper($match[1], $encoding);
} }
return ''; return '';
@@ -159,7 +159,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$stringy->str = preg_replace_callback( $stringy->str = preg_replace_callback(
'/[\d]+(.)?/u', '/[\d]+(.)?/u',
function ($match) use ($encoding) { function ($match) use ($encoding) {
return mb_strtoupper($match[0], $encoding); return \mb_strtoupper($match[0], $encoding);
}, },
$stringy->str $stringy->str
); );
@@ -208,10 +208,10 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$encoding = $this->encoding; $encoding = $this->encoding;
if ($caseSensitive) { if ($caseSensitive) {
return (mb_strpos($this->str, $needle, 0, $encoding) !== false); return (\mb_strpos($this->str, $needle, 0, $encoding) !== false);
} }
return (mb_stripos($this->str, $needle, 0, $encoding) !== false); return (\mb_stripos($this->str, $needle, 0, $encoding) !== false);
} }
/** /**
@@ -284,13 +284,13 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
public function countSubstr($substring, $caseSensitive = true) public function countSubstr($substring, $caseSensitive = true)
{ {
if ($caseSensitive) { if ($caseSensitive) {
return mb_substr_count($this->str, $substring, $this->encoding); return \mb_substr_count($this->str, $substring, $this->encoding);
} }
$str = mb_strtoupper($this->str, $this->encoding); $str = \mb_strtoupper($this->str, $this->encoding);
$substring = mb_strtoupper($substring, $this->encoding); $substring = \mb_strtoupper($substring, $this->encoding);
return mb_substr_count($str, $substring, $this->encoding); return \mb_substr_count($str, $substring, $this->encoding);
} }
/** /**
@@ -317,14 +317,14 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
public function delimit($delimiter) public function delimit($delimiter)
{ {
// Save current regex encoding so we can reset it after // Save current regex encoding so we can reset it after
$regexEncoding = mb_regex_encoding(); $regexEncoding = \mb_regex_encoding();
mb_regex_encoding($this->encoding); \mb_regex_encoding($this->encoding);
$str = mb_ereg_replace('\B([A-Z])', '-\1', $this->trim()); $str = \mb_ereg_replace('\B([A-Z])', '-\1', $this->trim());
$str = mb_strtolower($str, $this->encoding); $str = \mb_strtolower($str, $this->encoding);
$str = mb_ereg_replace('[-_\s]+', $delimiter, $str); $str = \mb_ereg_replace('[-_\s]+', $delimiter, $str);
mb_regex_encoding($regexEncoding); \mb_regex_encoding($regexEncoding);
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -340,15 +340,15 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function endsWith($substring, $caseSensitive = true) public function endsWith($substring, $caseSensitive = true)
{ {
$substringLength = mb_strlen($substring, $this->encoding); $substringLength = \mb_strlen($substring, $this->encoding);
$strLength = $this->length(); $strLength = $this->length();
$endOfStr = mb_substr($this->str, $strLength - $substringLength, $endOfStr = \mb_substr($this->str, $strLength - $substringLength,
$substringLength, $this->encoding); $substringLength, $this->encoding);
if (!$caseSensitive) { if (!$caseSensitive) {
$substring = mb_strtolower($substring, $this->encoding); $substring = \mb_strtolower($substring, $this->encoding);
$endOfStr = mb_strtolower($endOfStr, $this->encoding); $endOfStr = \mb_strtolower($endOfStr, $this->encoding);
} }
return (string) $substring === $endOfStr; return (string) $substring === $endOfStr;
@@ -508,7 +508,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function indexOf($needle, $offset = 0) public function indexOf($needle, $offset = 0)
{ {
return mb_strpos($this->str, (string) $needle, return \mb_strpos($this->str, (string) $needle,
(int) $offset, $this->encoding); (int) $offset, $this->encoding);
} }
@@ -524,7 +524,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function indexOfLast($needle, $offset = 0) public function indexOfLast($needle, $offset = 0)
{ {
return mb_strrpos($this->str, (string) $needle, return \mb_strrpos($this->str, (string) $needle,
(int) $offset, $this->encoding); (int) $offset, $this->encoding);
} }
@@ -542,8 +542,8 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
return $stringy; return $stringy;
} }
$start = mb_substr($stringy->str, 0, $index, $stringy->encoding); $start = \mb_substr($stringy->str, 0, $index, $stringy->encoding);
$end = mb_substr($stringy->str, $index, $stringy->length(), $end = \mb_substr($stringy->str, $index, $stringy->length(),
$stringy->encoding); $stringy->encoding);
$stringy->str = $start . $substring . $end; $stringy->str = $start . $substring . $end;
@@ -681,7 +681,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function length() public function length()
{ {
return mb_strlen($this->str, $this->encoding); return \mb_strlen($this->str, $this->encoding);
} }
/** /**
@@ -692,7 +692,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function lines() public function lines()
{ {
$array = mb_split('[\r\n]{1,2}', $this->str); $array = \mb_split('[\r\n]{1,2}', $this->str);
for ($i = 0; $i < count($array); $i++) { for ($i = 0; $i < count($array); $i++) {
$array[$i] = static::create($array[$i], $this->encoding); $array[$i] = static::create($array[$i], $this->encoding);
} }
@@ -709,13 +709,13 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
public function longestCommonPrefix($otherStr) public function longestCommonPrefix($otherStr)
{ {
$encoding = $this->encoding; $encoding = $this->encoding;
$maxLength = min($this->length(), mb_strlen($otherStr, $encoding)); $maxLength = min($this->length(), \mb_strlen($otherStr, $encoding));
$longestCommonPrefix = ''; $longestCommonPrefix = '';
for ($i = 0; $i < $maxLength; $i++) { for ($i = 0; $i < $maxLength; $i++) {
$char = mb_substr($this->str, $i, 1, $encoding); $char = \mb_substr($this->str, $i, 1, $encoding);
if ($char == mb_substr($otherStr, $i, 1, $encoding)) { if ($char == \mb_substr($otherStr, $i, 1, $encoding)) {
$longestCommonPrefix .= $char; $longestCommonPrefix .= $char;
} else { } else {
break; break;
@@ -734,13 +734,13 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
public function longestCommonSuffix($otherStr) public function longestCommonSuffix($otherStr)
{ {
$encoding = $this->encoding; $encoding = $this->encoding;
$maxLength = min($this->length(), mb_strlen($otherStr, $encoding)); $maxLength = min($this->length(), \mb_strlen($otherStr, $encoding));
$longestCommonSuffix = ''; $longestCommonSuffix = '';
for ($i = 1; $i <= $maxLength; $i++) { for ($i = 1; $i <= $maxLength; $i++) {
$char = mb_substr($this->str, -$i, 1, $encoding); $char = \mb_substr($this->str, -$i, 1, $encoding);
if ($char == mb_substr($otherStr, -$i, 1, $encoding)) { if ($char == \mb_substr($otherStr, -$i, 1, $encoding)) {
$longestCommonSuffix = $char . $longestCommonSuffix; $longestCommonSuffix = $char . $longestCommonSuffix;
} else { } else {
break; break;
@@ -764,7 +764,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$encoding = $this->encoding; $encoding = $this->encoding;
$stringy = static::create($this->str, $encoding); $stringy = static::create($this->str, $encoding);
$strLength = $stringy->length(); $strLength = $stringy->length();
$otherLength = mb_strlen($otherStr, $encoding); $otherLength = \mb_strlen($otherStr, $encoding);
// Return if either string is empty // Return if either string is empty
if ($strLength == 0 || $otherLength == 0) { if ($strLength == 0 || $otherLength == 0) {
@@ -779,8 +779,8 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
for ($i = 1; $i <= $strLength; $i++) { for ($i = 1; $i <= $strLength; $i++) {
for ($j = 1; $j <= $otherLength; $j++) { for ($j = 1; $j <= $otherLength; $j++) {
$strChar = mb_substr($stringy->str, $i - 1, 1, $encoding); $strChar = \mb_substr($stringy->str, $i - 1, 1, $encoding);
$otherChar = mb_substr($otherStr, $j - 1, 1, $encoding); $otherChar = \mb_substr($otherStr, $j - 1, 1, $encoding);
if ($strChar == $otherChar) { if ($strChar == $otherChar) {
$table[$i][$j] = $table[$i - 1][$j - 1] + 1; $table[$i][$j] = $table[$i - 1][$j - 1] + 1;
@@ -794,7 +794,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
} }
} }
$stringy->str = mb_substr($stringy->str, $end - $len, $len, $encoding); $stringy->str = \mb_substr($stringy->str, $end - $len, $len, $encoding);
return $stringy; return $stringy;
} }
@@ -806,11 +806,11 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function lowerCaseFirst() public function lowerCaseFirst()
{ {
$first = mb_substr($this->str, 0, 1, $this->encoding); $first = \mb_substr($this->str, 0, 1, $this->encoding);
$rest = mb_substr($this->str, 1, $this->length() - 1, $rest = \mb_substr($this->str, 1, $this->length() - 1,
$this->encoding); $this->encoding);
$str = mb_strtolower($first, $this->encoding) . $rest; $str = \mb_strtolower($first, $this->encoding) . $rest;
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -855,7 +855,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
throw new OutOfBoundsException('No character exists at the index'); throw new OutOfBoundsException('No character exists at the index');
} }
return mb_substr($this->str, $offset, 1, $this->encoding); return \mb_substr($this->str, $offset, 1, $this->encoding);
} }
/** /**
@@ -983,11 +983,11 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function regexReplace($pattern, $replacement, $options = 'msr') public function regexReplace($pattern, $replacement, $options = 'msr')
{ {
$regexEncoding = mb_regex_encoding(); $regexEncoding = \mb_regex_encoding();
mb_regex_encoding($this->encoding); \mb_regex_encoding($this->encoding);
$str = mb_ereg_replace($pattern, $replacement, $this->str, $options); $str = \mb_ereg_replace($pattern, $replacement, $this->str, $options);
mb_regex_encoding($regexEncoding); \mb_regex_encoding($regexEncoding);
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -1003,7 +1003,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$stringy = static::create($this->str, $this->encoding); $stringy = static::create($this->str, $this->encoding);
if ($stringy->startsWith($substring)) { if ($stringy->startsWith($substring)) {
$substringLength = mb_strlen($substring, $stringy->encoding); $substringLength = \mb_strlen($substring, $stringy->encoding);
return $stringy->substr($substringLength); return $stringy->substr($substringLength);
} }
@@ -1021,7 +1021,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$stringy = static::create($this->str, $this->encoding); $stringy = static::create($this->str, $this->encoding);
if ($stringy->endsWith($substring)) { if ($stringy->endsWith($substring)) {
$substringLength = mb_strlen($substring, $stringy->encoding); $substringLength = \mb_strlen($substring, $stringy->encoding);
return $stringy->substr(0, $stringy->length() - $substringLength); return $stringy->substr(0, $stringy->length() - $substringLength);
} }
@@ -1065,7 +1065,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
// Loop from last index of string to first // Loop from last index of string to first
for ($i = $strLength - 1; $i >= 0; $i--) { for ($i = $strLength - 1; $i >= 0; $i--) {
$reversed .= mb_substr($this->str, $i, 1, $this->encoding); $reversed .= \mb_substr($this->str, $i, 1, $this->encoding);
} }
return static::create($reversed, $this->encoding); return static::create($reversed, $this->encoding);
@@ -1090,16 +1090,16 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
// Need to further trim the string so we can append the substring // Need to further trim the string so we can append the substring
$encoding = $stringy->encoding; $encoding = $stringy->encoding;
$substringLength = mb_strlen($substring, $encoding); $substringLength = \mb_strlen($substring, $encoding);
$length = $length - $substringLength; $length = $length - $substringLength;
$truncated = mb_substr($stringy->str, 0, $length, $encoding); $truncated = \mb_substr($stringy->str, 0, $length, $encoding);
// If the last word was truncated // If the last word was truncated
if (mb_strpos($stringy->str, ' ', $length - 1, $encoding) != $length) { if (mb_strpos($stringy->str, ' ', $length - 1, $encoding) != $length) {
// Find pos of the last occurrence of a space, get up to that // Find pos of the last occurrence of a space, get up to that
$lastPos = mb_strrpos($truncated, ' ', 0, $encoding); $lastPos = \mb_strrpos($truncated, ' ', 0, $encoding);
$truncated = mb_substr($truncated, 0, $lastPos, $encoding); $truncated = \mb_substr($truncated, 0, $lastPos, $encoding);
} }
$stringy->str = $truncated . $substring; $stringy->str = $truncated . $substring;
@@ -1120,7 +1120,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$shuffledStr = ''; $shuffledStr = '';
foreach ($indexes as $i) { foreach ($indexes as $i) {
$shuffledStr .= mb_substr($this->str, $i, 1, $this->encoding); $shuffledStr .= \mb_substr($this->str, $i, 1, $this->encoding);
} }
return static::create($shuffledStr, $this->encoding); return static::create($shuffledStr, $this->encoding);
@@ -1159,13 +1159,13 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function startsWith($substring, $caseSensitive = true) public function startsWith($substring, $caseSensitive = true)
{ {
$substringLength = mb_strlen($substring, $this->encoding); $substringLength = \mb_strlen($substring, $this->encoding);
$startOfStr = mb_substr($this->str, 0, $substringLength, $startOfStr = \mb_substr($this->str, 0, $substringLength,
$this->encoding); $this->encoding);
if (!$caseSensitive) { if (!$caseSensitive) {
$substring = mb_strtolower($substring, $this->encoding); $substring = \mb_strtolower($substring, $this->encoding);
$startOfStr = mb_strtolower($startOfStr, $this->encoding); $startOfStr = \mb_strtolower($startOfStr, $this->encoding);
} }
return (string) $substring === $startOfStr; return (string) $substring === $startOfStr;
@@ -1193,7 +1193,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$length = $end - $start; $length = $end - $start;
} }
$str = mb_substr($this->str, $start, $length, $this->encoding); $str = \mb_substr($this->str, $start, $length, $this->encoding);
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -1219,14 +1219,14 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
return array(static::create($this->str, $this->encoding)); return array(static::create($this->str, $this->encoding));
} }
$regexEncoding = mb_regex_encoding(); $regexEncoding = \mb_regex_encoding();
mb_regex_encoding($this->encoding); \mb_regex_encoding($this->encoding);
// mb_split returns the remaining unsplit string in the last index when // mb_split returns the remaining unsplit string in the last index when
// supplying a limit // supplying a limit
$limit = ($limit > 0) ? $limit += 1 : -1; $limit = ($limit > 0) ? $limit += 1 : -1;
$array = mb_split($pattern, $this->str, $limit); $array = \mb_split($pattern, $this->str, $limit);
mb_regex_encoding($regexEncoding); \mb_regex_encoding($regexEncoding);
if ($limit > 0 && count($array) === $limit) { if ($limit > 0 && count($array) === $limit) {
array_pop($array); array_pop($array);
@@ -1251,7 +1251,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
public function substr($start, $length = null) public function substr($start, $length = null)
{ {
$length = $length === null ? $this->length() : $length; $length = $length === null ? $this->length() : $length;
$str = mb_substr($this->str, $start, $length, $this->encoding); $str = \mb_substr($this->str, $start, $length, $this->encoding);
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -1283,11 +1283,11 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
$stringy->str = preg_replace_callback( $stringy->str = preg_replace_callback(
'/[\S]/u', '/[\S]/u',
function ($match) use ($encoding) { function ($match) use ($encoding) {
if ($match[0] == mb_strtoupper($match[0], $encoding)) { if ($match[0] == \mb_strtoupper($match[0], $encoding)) {
return mb_strtolower($match[0], $encoding); return \mb_strtolower($match[0], $encoding);
} }
return mb_strtoupper($match[0], $encoding); return \mb_strtoupper($match[0], $encoding);
}, },
$stringy->str $stringy->str
); );
@@ -1415,7 +1415,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function toLowerCase() public function toLowerCase()
{ {
$str = mb_strtolower($this->str, $this->encoding); $str = \mb_strtolower($this->str, $this->encoding);
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -1458,7 +1458,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function toTitleCase() public function toTitleCase()
{ {
$str = mb_convert_case($this->str, MB_CASE_TITLE, $this->encoding); $str = \mb_convert_case($this->str, \MB_CASE_TITLE, $this->encoding);
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -1471,7 +1471,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function toUpperCase() public function toUpperCase()
{ {
$str = mb_strtoupper($this->str, $this->encoding); $str = \mb_strtoupper($this->str, $this->encoding);
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -1538,10 +1538,10 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
} }
// Need to further trim the string so we can append the substring // Need to further trim the string so we can append the substring
$substringLength = mb_strlen($substring, $stringy->encoding); $substringLength = \mb_strlen($substring, $stringy->encoding);
$length = $length - $substringLength; $length = $length - $substringLength;
$truncated = mb_substr($stringy->str, 0, $length, $stringy->encoding); $truncated = \mb_substr($stringy->str, 0, $length, $stringy->encoding);
$stringy->str = $truncated . $substring; $stringy->str = $truncated . $substring;
return $stringy; return $stringy;
@@ -1579,11 +1579,11 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
public function upperCaseFirst() public function upperCaseFirst()
{ {
$first = mb_substr($this->str, 0, 1, $this->encoding); $first = \mb_substr($this->str, 0, 1, $this->encoding);
$rest = mb_substr($this->str, 1, $this->length() - 1, $rest = \mb_substr($this->str, 1, $this->length() - 1,
$this->encoding); $this->encoding);
$str = mb_strtoupper($first, $this->encoding) . $rest; $str = \mb_strtoupper($first, $this->encoding) . $rest;
return static::create($str, $this->encoding); return static::create($str, $this->encoding);
} }
@@ -1768,7 +1768,7 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
private function applyPadding($left = 0, $right = 0, $padStr = ' ') private function applyPadding($left = 0, $right = 0, $padStr = ' ')
{ {
$stringy = static::create($this->str, $this->encoding); $stringy = static::create($this->str, $this->encoding);
$length = mb_strlen($padStr, $stringy->encoding); $length = \mb_strlen($padStr, $stringy->encoding);
$strLength = $stringy->length(); $strLength = $stringy->length();
$paddedLength = $strLength + $left + $right; $paddedLength = $strLength + $left + $right;
@@ -1777,9 +1777,9 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
return $stringy; return $stringy;
} }
$leftPadding = mb_substr(str_repeat($padStr, ceil($left / $length)), 0, $leftPadding = \mb_substr(str_repeat($padStr, ceil($left / $length)), 0,
$left, $stringy->encoding); $left, $stringy->encoding);
$rightPadding = mb_substr(str_repeat($padStr, ceil($right / $length)), $rightPadding = \mb_substr(str_repeat($padStr, ceil($right / $length)),
0, $right, $stringy->encoding); 0, $right, $stringy->encoding);
$stringy->str = $leftPadding . $stringy->str . $rightPadding; $stringy->str = $leftPadding . $stringy->str . $rightPadding;
@@ -1795,11 +1795,11 @@ class Stringy implements Countable, IteratorAggregate, ArrayAccess
*/ */
private function matchesPattern($pattern) private function matchesPattern($pattern)
{ {
$regexEncoding = mb_regex_encoding(); $regexEncoding = \mb_regex_encoding();
mb_regex_encoding($this->encoding); \mb_regex_encoding($this->encoding);
$match = mb_ereg_match($pattern, $this->str); $match = \mb_ereg_match($pattern, $this->str);
mb_regex_encoding($regexEncoding); \mb_regex_encoding($regexEncoding);
return $match; return $match;
} }