1
0
mirror of https://github.com/danielstjules/Stringy.git synced 2025-09-02 09:33:10 +02:00

27 Commits
1.8.1 ... 1.9.0

Author SHA1 Message Date
Daniel St. Jules
3cf18e9e42 1.9.0 2015-02-09 22:19:18 -08:00
Daniel St. Jules
04b12c9500 Document hasLowerCase and hasUpperCase 2015-02-09 22:10:46 -08:00
Daniel St. Jules
b2386b6c33 Sticking to the ruler where possible 2015-02-09 21:38:42 -08:00
Daniel St. Jules
1172a75d1e Improve coverage of charsArray() 2015-02-09 21:27:21 -08:00
Daniel St. Jules
4ebf9aee3d Merge pull request #79 from vlakoff/tweak
Just a little bit of tweaking
2015-02-03 02:21:24 -08:00
vlakoff
61b986a3e6 Code tweaking
Prettier, one less instanciation.
2015-02-03 11:13:58 +01:00
vlakoff
2bd4be60bb Uniformization in docblocks 2015-02-03 11:10:27 +01:00
Daniel St. Jules
0aa476d44c Merge pull request #68 from vlakoff/toAscii
[Proposal] Add $replaceUnsupported and $fallback parameters to toAscii()
2015-02-02 23:42:47 -08:00
Daniel St. Jules
f63646dcba Merge pull request #78 from vlakoff/readme
Clean up some commas in README
2015-02-02 23:41:43 -08:00
vlakoff
97e607dc5d Add $removeUnsupported parameter to toAscii() 2015-02-03 07:12:02 +01:00
vlakoff
a9a4ce461f Clean up some commas in README 2015-02-03 06:29:04 +01:00
Daniel St. Jules
9a0f0e16cb Merge pull request #77 from takobell/master
Add Stringy->hasUpperCase, Stringy->hasLowerCase along with StaticString counterparts & tests.
2015-02-01 22:09:48 -08:00
Brad Bell
e9cd229808 Add StaticStringy::hasUpperCase, StaticStringy::hasLowerCase, Stringy->hasUpperCase and Stringy->hasLowerCase along with tests. 2015-01-23 15:52:58 -08:00
Daniel St. Jules
4974407729 charsArray formatting 2015-01-18 20:14:57 -08:00
Daniel St. Jules
8a36b8d3f0 Merge pull request #74 from anhskohbo/master
Support Full Unicode For Vietnamese.
2015-01-18 20:11:40 -08:00
Daniel St. Jules
66c2a98e83 Merge pull request #75 from vlakoff/tweak
Minor improvements
2015-01-16 18:50:54 -08:00
vlakoff
36c3fd05d2 Use Stringy's trim() method in applyDelimiter()
This trim() method may be more powerful in the future.
2015-01-17 01:53:01 +01:00
vlakoff
f3bd5b6c62 Fix method name
applyDelimeter() --> applyDelimiter()

Thankfully, it is a protected method.
2015-01-17 01:52:55 +01:00
vlakoff
dd34bc6f85 Minor code adjustment 2015-01-17 01:52:46 +01:00
anhskohbo
f490aa2894 Support Full Unicode For Vietnamese.
Signed-off-by: anhskohbo <anhskohbo@gmail.com>
2015-01-14 03:43:59 +07:00
Daniel St. Jules
40974608d4 Merge pull request #70 from vlakoff/toAscii-2
Separate toAscii()'s charsArray to allow customization
2015-01-13 12:25:16 -08:00
vlakoff
8676bd9d9b Add cache in charsArray()
This is static but confined to this function block,
so this doesn't introduce any side effect.

The performance gain is really worth it.
2015-01-12 19:59:37 +01:00
Daniel St. Jules
f4327a2583 Merge pull request #73 from lucasmichot/missing-space
Style fix
2015-01-11 17:39:30 -08:00
Lucas Michot
571dc93d1e Add missing space 2015-01-12 02:38:52 +01:00
vlakoff
62f6fd7b3a Separate toAscii()'s charsArray to allow customization 2015-01-10 22:39:36 +01:00
Daniel St. Jules
8b834482df Merge pull request #72 from vlakoff/spaces
Add remaining Unicode spaces
2015-01-09 19:58:36 -08:00
vlakoff
08a72a72dd Add remaining Unicode spaces
* spaces U+2000 to U+200A (there already was thin space U+2009)
* medium mathematical space (U+205F)
2015-01-09 19:14:16 +01:00
7 changed files with 356 additions and 119 deletions

View File

@@ -1,3 +1,13 @@
### 1.9.0 (2015-02-09)
* Added hasUpperCase and hasLowerCase
* Added $removeUnsupported parameter to toAscii()
* Improved toAscii support with additional Unicode spaces, Vietnamese chars,
and numerous other characters
* Separated the charsArray from toAscii as a protected method that may be
extended by inheriting classes
* Chars array is cached for better performance
### 1.8.1 (2015-01-08) ### 1.8.1 (2015-01-08)
* Optimized chars() * Optimized chars()

View File

@@ -26,6 +26,8 @@ PHP 5.3+ and HHVM. Inspired by underscore.string.js.
* [ensureRight](#ensureright) * [ensureRight](#ensureright)
* [first](#first) * [first](#first)
* [getEncoding](#getencoding) * [getEncoding](#getencoding)
* [hasLowerCase](#haslowercase)
* [hasUpperCase](#hasuppercase)
* [humanize](#humanize) * [humanize](#humanize)
* [insert](#insert) * [insert](#insert)
* [isAlpha](#isalpha) * [isAlpha](#isalpha)
@@ -83,7 +85,7 @@ in your composer.json file:
```json ```json
{ {
"require": { "require": {
"danielstjules/stringy": "~1.8" "danielstjules/stringy": "~1.9"
} }
} }
``` ```
@@ -314,7 +316,7 @@ S::countSubstr('Ο συγγραφέας είπε', 'α', 'UTF-8'); // 2
#### create #### create
S::create(mixed $str, [, $encoding ]) S::create(mixed $str [, $encoding ])
Creates a Stringy object and assigns both str and encoding properties Creates a Stringy object and assigns both str and encoding properties
the supplied values. $str is cast to a string prior to assignment, and if the supplied values. $str is cast to a string prior to assignment, and if
@@ -405,6 +407,32 @@ Returns the encoding used by the Stringy object.
S::create('fòô bàř', 'UTF-8')->getEncoding(); // 'UTF-8' S::create('fòô bàř', 'UTF-8')->getEncoding(); // 'UTF-8'
``` ```
#### hasLowerCase
$stringy->hasLowerCase()
S::hasLowerCase(string $str [, string $encoding ])
Returns true if the string contains a lower case char, false otherwise.
```php
S::create('fòô bàř', 'UTF-8')->hasLowerCase();
S::hasLowerCase('fòô bàř', 'UTF-8'); // true
```
#### hasUpperCase
$stringy->hasUpperCase()
S::hasUpperCase(string $str [, string $encoding ])
Returns true if the string contains an upper case char, false otherwise.
```php
S::create('fòô bàř', 'UTF-8')->hasUpperCase();
S::hasUpperCase('fòô bàř', 'UTF-8'); // false
```
#### humanize #### humanize
$stringy->humanize() $stringy->humanize()
@@ -734,7 +762,7 @@ S::replace('fòô bàř fòô bàř', 'fòô ', '', 'UTF-8'); // 'bàř bàř'
$stringy->reverse() $stringy->reverse()
S::reverse(string $str, [, string $encoding ]) S::reverse(string $str [, string $encoding ])
Returns a reversed string. A multibyte version of strrev(). Returns a reversed string. A multibyte version of strrev().
@@ -745,9 +773,9 @@ S::reverse('fòô bàř', 'UTF-8'); // 'řàb ôòf'
#### safeTruncate #### safeTruncate
$stringy->safeTruncate(int $length, [, string $substring = '' ]) $stringy->safeTruncate(int $length [, string $substring = '' ])
S::safeTruncate(string $str, int $length, [, string $substring = '' [, string $encoding ]]) S::safeTruncate(string $str, int $length [, string $substring = '' [, string $encoding ]])
Truncates the string to a given length, while ensuring that it does not Truncates the string to a given length, while ensuring that it does not
split words. If $substring is provided, and truncating occurs, the split words. If $substring is provided, and truncating occurs, the
@@ -881,10 +909,11 @@ S::titleize('i like to watch DVDs at home', $ignore, 'UTF-8');
$stringy->toAscii() $stringy->toAscii()
S::toAscii(string $str) S::toAscii(string $str [, boolean $removeUnsupported = true])
Returns an ASCII version of the string. A set of non-ASCII characters are Returns an ASCII version of the string. A set of non-ASCII characters are
replaced with their closest ASCII counterparts, and the rest are removed. replaced with their closest ASCII counterparts, and the rest are removed
unless instructed otherwise.
```php ```php
S::create('fòô bàř')->toAscii(); S::create('fòô bàř')->toAscii();
@@ -909,7 +938,7 @@ S::toLowerCase('FÒÔ BÀŘ', 'UTF-8'); // 'fòô bàř'
$stringy->toSpaces([ tabLength = 4 ]) $stringy->toSpaces([ tabLength = 4 ])
S::toSpaces(string $str, [, int $tabLength = 4 ]) S::toSpaces(string $str [, int $tabLength = 4 ])
Converts each tab in the string to some number of spaces, as defined by Converts each tab in the string to some number of spaces, as defined by
$tabLength. By default, each tab is converted to 4 consecutive spaces. $tabLength. By default, each tab is converted to 4 consecutive spaces.
@@ -923,7 +952,7 @@ S::toSpaces(' String speech = "Hi"'); // ' String speech = "Hi"'
$stringy->toTabs([ tabLength = 4 ]) $stringy->toTabs([ tabLength = 4 ])
S::toTabs(string $str, [, int $tabLength = 4 ]) S::toTabs(string $str [, int $tabLength = 4 ])
Converts each occurrence of some consecutive number of spaces, as defined Converts each occurrence of some consecutive number of spaces, as defined
by $tabLength, to a tab. By default, each 4 consecutive spaces are by $tabLength, to a tab. By default, each 4 consecutive spaces are
@@ -976,9 +1005,9 @@ S::trim(' fòô bàř '); // 'fòô bàř'
#### truncate #### truncate
$stringy->truncate(int $length, [, string $substring = '' ]) $stringy->truncate(int $length [, string $substring = '' ])
S::truncate(string $str, int $length, [, string $substring = '' [, string $encoding ]]) S::truncate(string $str, int $length [, string $substring = '' [, string $encoding ]])
Truncates the string to a given length. If $substring is provided, and Truncates the string to a given length. If $substring is provided, and
truncating occurs, the string is further truncated so that the substring truncating occurs, the string is further truncated so that the substring

View File

@@ -166,14 +166,17 @@ class StaticStringy
/** /**
* Returns an ASCII version of the string. A set of non-ASCII characters are * Returns an ASCII version of the string. A set of non-ASCII characters are
* replaced with their closest ASCII counterparts, and the rest are removed. * replaced with their closest ASCII counterparts, and the rest are removed
* unless instructed otherwise.
* *
* @param string $str A string with non-ASCII characters * @param string $str A string with non-ASCII characters
* @param bool $removeUnsupported Whether or not to remove the
* unsupported characters
* @return string A string containing only ASCII characters * @return string A string containing only ASCII characters
*/ */
public static function toAscii($str) public static function toAscii($str, $removeUnsupported = true)
{ {
return (string) Stringy::create($str)->toAscii(); return (string) Stringy::create($str)->toAscii($removeUnsupported);
} }
/** /**
@@ -683,6 +686,32 @@ class StaticStringy
return (string) Stringy::create($str, $encoding)->removeRight($substring); return (string) Stringy::create($str, $encoding)->removeRight($substring);
} }
/**
* Returns true if the string contains a lower case char, false
* otherwise.
*
* @param string $str String to check
* @param string $encoding The character encoding
* @return bool Whether or not $str contains a lower case character.
*/
public static function hasLowerCase($str, $encoding = null)
{
return Stringy::create($str, $encoding)->hasLowerCase();
}
/**
* Returns true if the string contains an upper case char, false
* otherwise.
*
* @param string $str String to check
* @param string $encoding The character encoding
* @return bool Whether or not $str contains an upper case character.
*/
public static function hasUpperCase($str, $encoding = null)
{
return Stringy::create($str, $encoding)->hasUpperCase();
}
/** /**
* Returns true if the string contains only alphabetic chars, false * Returns true if the string contains only alphabetic chars, false
* otherwise. * otherwise.
@@ -815,7 +844,7 @@ class StaticStringy
public static function replace($str, $search, $replacement, $encoding = null) public static function replace($str, $search, $replacement, $encoding = null)
{ {
return (string) Stringy::create($str, $encoding) return (string) Stringy::create($str, $encoding)
->replace($search,$replacement); ->replace($search, $replacement);
} }
/** /**

View File

@@ -235,14 +235,14 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
public function camelize() public function camelize()
{ {
$encoding = $this->encoding; $encoding = $this->encoding;
$stringy = static::create($this->str, $this->encoding); $stringy = $this->trim()->lowerCaseFirst();
$camelCase = preg_replace_callback( $camelCase = preg_replace_callback(
'/[-_\s]+(.)?/u', '/[-_\s]+(.)?/u',
function ($match) use ($encoding) { function ($match) use ($encoding) {
return $match[1] ? mb_strtoupper($match[1], $encoding) : ''; return $match[1] ? mb_strtoupper($match[1], $encoding) : '';
}, },
$stringy->trim()->lowerCaseFirst()->str $stringy->str
); );
$stringy->str = preg_replace_callback( $stringy->str = preg_replace_callback(
@@ -277,7 +277,7 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
*/ */
public function dasherize() public function dasherize()
{ {
return $this->applyDelimeter('-'); return $this->applyDelimiter('-');
} }
/** /**
@@ -290,7 +290,7 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
*/ */
public function underscored() public function underscored()
{ {
return $this->applyDelimeter('_'); return $this->applyDelimiter('_');
} }
/** /**
@@ -299,13 +299,13 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
* @param string $delimiter Sequence used to separate parts of the string * @param string $delimiter Sequence used to separate parts of the string
* @return Stringy Object with a delimited $str * @return Stringy Object with a delimited $str
*/ */
protected function applyDelimeter($delimiter) protected function applyDelimiter($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])', $delimiter .'\1', trim($this->str)); $str = mb_ereg_replace('\B([A-Z])', $delimiter .'\1', $this->trim());
$str = mb_ereg_replace('[-_\s]+', $delimiter, $str); $str = mb_ereg_replace('[-_\s]+', $delimiter, $str);
$str = mb_strtolower($str, $this->encoding); $str = mb_strtolower($str, $this->encoding);
@@ -354,7 +354,7 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
$buffer = preg_replace_callback( $buffer = preg_replace_callback(
'/([\S]+)/u', '/([\S]+)/u',
function ($match) use (&$encoding, &$ignore) { function ($match) use ($encoding, $ignore) {
if ($ignore && in_array($match[0], $ignore)) { if ($ignore && in_array($match[0], $ignore)) {
return $match[0]; return $match[0];
} else { } else {
@@ -419,107 +419,161 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
/** /**
* Returns an ASCII version of the string. A set of non-ASCII characters are * Returns an ASCII version of the string. A set of non-ASCII characters are
* replaced with their closest ASCII counterparts, and the rest are removed. * replaced with their closest ASCII counterparts, and the rest are removed
* unless instructed otherwise.
* *
* @param bool $removeUnsupported Whether or not to remove the
* unsupported characters
* @return Stringy Object whose $str contains only ASCII characters * @return Stringy Object whose $str contains only ASCII characters
*/ */
public function toAscii() public function toAscii($removeUnsupported = true)
{ {
$str = $this->str; $str = $this->str;
$charsArray = array(
'a' => array('à', 'á', 'â', 'ä', 'ã', 'ā', 'ą', 'ă', 'å', 'α', foreach ($this->charsArray() as $key => $value) {
'ά', 'ἀ', 'ἁ', 'ἂ', 'ἃ', 'ἄ', 'ἅ', 'ἆ', 'ἇ', 'ᾀ', $str = str_replace($value, $key, $str);
'ᾁ', 'ᾂ', 'ᾃ', 'ᾄ', 'ᾅ', 'ᾆ', 'ᾇ', 'ὰ', 'ά', 'ᾰ', }
'ᾱ', 'ᾲ', 'ᾳ', 'ᾴ', 'ᾶ', 'ᾷ', 'а'),
'b' => array('б', 'β'), if ($removeUnsupported) {
$str = preg_replace('/[^\x20-\x7E]/u', '', $str);
}
return static::create($str, $this->encoding);
}
/**
* Returns the replacements for the toAscii() method.
*
* @return array An array of replacements.
*/
protected function charsArray()
{
static $charsArray;
if (isset($charsArray)) return $charsArray;
return $charsArray = array(
'a' => array(
'à', 'á', 'ả', 'ã', 'ạ', 'ă', 'ắ', 'ằ', 'ẳ', 'ẵ',
'ặ', 'â', 'ấ', 'ầ', 'ẩ', 'ẫ', 'ậ', 'ä', 'ā', 'ą',
'å', 'α', 'ά', 'ἀ', 'ἁ', 'ἂ', 'ἃ', 'ἄ', 'ἅ', 'ἆ',
'ἇ', 'ᾀ', 'ᾁ', 'ᾂ', 'ᾃ', 'ᾄ', 'ᾅ', 'ᾆ', 'ᾇ', 'ὰ',
'ά', 'ᾰ', 'ᾱ', 'ᾲ', 'ᾳ', 'ᾴ', 'ᾶ', 'ᾷ', 'а', 'أ'),
'b' => array('б', 'β', 'Ъ', 'Ь', 'ب'),
'c' => array('ç', 'ć', 'č', 'ĉ', 'ċ'), 'c' => array('ç', 'ć', 'č', 'ĉ', 'ċ'),
'd' => array('ď', 'ð', 'đ', 'ƌ', 'ȡ', 'ɖ', 'ɗ', 'ᵭ', 'ᶁ', 'ᶑ', 'd' => array('ď', 'ð', 'đ', 'ƌ', 'ȡ', 'ɖ', 'ɗ', 'ᵭ', 'ᶁ', 'ᶑ',
'д'), 'д', 'δ', 'د', 'ض'),
'e' => array('è', 'é', 'ê', 'ë', 'ē', 'ę', 'ě', 'ĕ', 'ė', 'ε', 'e' => array('é', 'è', '', '', '', 'ê', 'ế', '', '', '',
'έ', '', '', '', '', '', '', '', 'έ', 'е', '', 'ë', 'ē', 'ę', 'ě', 'ĕ', 'ė', 'ε', 'έ', '',
'ё', 'э', 'є'), 'ἑ', 'ἒ', 'ἓ', 'ἔ', '', '', 'έ', 'е', 'ё', 'э',
'f' => array('ф'), 'є', 'ə'),
'g' => array('ĝ', ', 'ġ', 'ģ', 'г', '), 'f' => array('ф', 'φ', 'ف'),
'h' => array('ĥ', '), 'g' => array('ĝ', 'ğ', 'ġ', 'ģ', 'г', 'ґ', 'γ', '),
'i' => array('ì', ', 'î', 'ï', 'ī', 'ĩ', 'ĭ', 'į', 'ı', 'ι', 'h' => array('ĥ', 'ħ', 'η', 'ή', 'ح', 'ه'),
'ί', 'ϊ', 'ΐ', '', '', '', '', '', '', '', 'i' => array('í', 'ì', '', 'ĩ', '', 'î', 'ï', 'ī', 'ĭ', 'į',
'', '', 'ί', '', '', '', 'ΐ', '', '', 'і', 'ı', 'ι', 'ί', 'ϊ', 'ΐ', '', '', '', '', '',
'ї', 'и'), 'ἵ', 'ἶ', 'ἷ', 'ὶ', 'ί', 'ῐ', '', 'ῒ', 'ΐ', 'ῖ',
'j' => array('ĵ'), '', 'і', 'ї', 'и'),
'k' => array('ķ', 'ĸ', 'к'), 'j' => array('ĵ', 'ј', 'Ј'),
'l' => array('ł', 'ľ', 'ĺ', 'ļ', 'ŀ', 'л'), 'k' => array('ķ', ', 'к', 'κ', 'Ķ', 'ق', 'ك'),
'm' => array('м'), 'l' => array('ł', 'ľ', 'ĺ', 'ļ', 'ŀ', 'л', 'λ', '),
'n' => array('ñ', 'ń', 'ň', 'ņ', 'ʼn', 'ŋ', 'ν', '), 'm' => array('м', 'μ', 'م'),
'o' => array('ò', 'ó', ', 'õ', 'ø', 'ō', 'ő', 'ŏ', 'ο', 'ό', 'n' => array('ñ', 'ń', 'ň', 'ņ', 'ʼn', 'ŋ', 'ν', 'н', 'ن'),
'', '', '', '', '', '', '', 'ό', 'ö', 'о'), 'o' => array('ó', 'ò', '', 'õ', '', 'ô', '', '', '', '',
'p' => array('п'), '', 'ơ', 'ớ', 'ờ', 'ở', 'ỡ', 'ợ', 'ø', 'ō', 'ő',
'r' => array('ŕ', 'ř', 'ŗ', 'р'), 'ŏ', 'ο', 'ὀ', 'ὁ', 'ὂ', 'ὃ', '', '', '', 'ό',
's' => array('ś', 'š', 'ş', 'с'), 'ö', 'о', 'و', 'θ'),
't' => array('ť', 'ţ', '), 'p' => array('п', 'π'),
'u' => array('ü', ', 'ú', 'û', 'ū', 'ů', 'ű', 'ŭ', 'ũ', 'ų', 'r' => array('ŕ', 'ř', 'ŗ', 'р', 'ρ', 'ر'),
'µ', 'у'), 's' => array('ś', 'š', 'ş', 'с', 'σ', 'ș', 'ς', 'س', 'ص'),
't' => array('ť', 'ţ', 'т', 'τ', 'ț', 'ت', 'ط'),
'u' => array('ú', 'ù', 'ủ', 'ũ', 'ụ', 'ư', 'ứ', 'ừ', 'ử', 'ữ',
'ự', 'ü', 'û', 'ū', 'ů', 'ű', 'ŭ', 'ų', 'µ', 'у'),
'v' => array('в'), 'v' => array('в'),
'w' => array('ŵ'), 'w' => array('ŵ', 'ω', 'ώ'),
'y' => array('ÿ', 'ý', 'ŷ', 'й', '), 'x' => array('χ'),
'z' => array('ź', 'ž', 'ż', 'з'), 'y' => array('ý', 'ỳ', 'ỷ', 'ỹ', 'ỵ', 'ÿ', 'ŷ', 'й', 'ы', 'υ',
'ϋ', 'ύ', 'ΰ', 'ي'),
'z' => array('ź', 'ž', 'ż', 'з', 'ζ', 'ز'),
'aa' => array('ع'),
'ae' => array('æ'),
'ch' => array('ч'), 'ch' => array('ч'),
'kh' => array('х'), 'dj' => array('ђ', '),
'dz' => array('џ'),
'gh' => array('غ'),
'kh' => array('х', 'خ'),
'lj' => array('љ'),
'nj' => array('њ'),
'oe' => array('œ'), 'oe' => array('œ'),
'ps' => array('ψ'),
'sh' => array('ш'), 'sh' => array('ш'),
'shch' => array('щ'), 'shch' => array('щ'),
'ss' => array('ß'),
'th' => array('þ', 'ث', 'ذ', 'ظ'),
'ts' => array('ц'), 'ts' => array('ц'),
'ya' => array('я'), 'ya' => array('я'),
'yu' => array('ю'), 'yu' => array('ю'),
'zh' => array('ж'), 'zh' => array('ж'),
'A' => array('Á', 'Â', 'Ä', 'Ã', 'Å', 'Ā', 'Ą', 'Ă', 'Α', 'Ά', '(c)' => array('©'),
'', '', '', '', '', '', '', '', '', '', 'A' => array('Á', 'À', '', 'Ã', '', 'Ă', '', '', '', '',
'', '', '', '', '', '', '', '', '', 'Ά', '', 'Â', '', '', '', '', '', 'Ä', 'Å', 'Ā',
'', 'А'), 'Ą', 'Α', 'Ά', 'Ἀ', 'Ἁ', 'Ἂ', '', 'Ἄ', 'Ἅ', 'Ἆ',
'B' => array('Б'), '', 'ᾈ', 'ᾉ', 'ᾊ', 'ᾋ', 'ᾌ', 'ᾍ', 'ᾎ', '', 'Ᾰ',
'Ᾱ', 'Ὰ', 'Ά', 'ᾼ', 'А'),
'B' => array('Б', 'Β'),
'C' => array('Ć', 'Č', 'Ĉ', 'Ċ'), 'C' => array('Ć', 'Č', 'Ĉ', 'Ċ'),
'D' => array('Ď', 'Ð', 'Đ', 'Ɖ', 'Ɗ', 'Ƌ', 'ᴅ', 'ᴆ', 'Д'), 'D' => array('Ď', 'Ð', 'Đ', 'Ɖ', 'Ɗ', 'Ƌ', 'ᴅ', 'ᴆ', 'Д', 'Δ'),
'E' => array('É', 'Ê', 'Ë', 'Ē', 'Ę', 'Ě', 'Ĕ', 'Ė', 'Ε', 'Έ', 'E' => array('É', 'È', '', '', '', 'Ê', '', '', '', '',
'', '', '', '', '', '', 'Έ', '', 'Е', 'Ё', '', 'Ë', 'Ē', 'Ę', 'Ě', 'Ĕ', 'Ė', 'Ε', 'Έ', '',
'Э', 'Є'), 'Ἑ', 'Ἒ', 'Ἓ', 'Ἔ', 'Ἕ', ', '', 'Е', 'Ё', 'Э',
'F' => array('Ф'), 'Є', 'Ə'),
'G' => array('Ğ', 'Ġ', 'Ģ', 'Г', '), 'F' => array('Ф', 'Φ'),
'I' => array('Í', ', 'Ï', 'Ī', 'Ĩ', 'Ĭ', 'Į', 'İ', 'Ι', 'Ί', 'G' => array('Ğ', 'Ġ', 'Ģ', 'Г', 'Ґ', 'Γ'),
'Ϊ', 'Ἰ', 'Ἱ', 'Ἳ', 'Ἴ', 'Ἵ', '', 'Ἷ', 'Ῐ', 'Ῑ', 'H' => array('Η', 'Ή'),
'', 'Ί', 'И', 'І', 'Ї'), 'I' => array('Í', 'Ì', 'Ỉ', 'Ĩ', 'Ị', 'Î', 'Ï', 'Ī', 'Ĭ', 'Į',
'K' => array('К'), 'İ', 'Ι', 'Ί', 'Ϊ', 'Ἰ', 'Ἱ', 'Ἳ', 'Ἴ', '', 'Ἶ',
'L' => array('Ĺ', 'Ł', 'Л'), 'Ἷ', 'Ῐ', 'Ῑ', 'Ὶ', 'Ί', 'И', 'І', 'Ї'),
'M' => array('М'), 'K' => array('К', 'Κ'),
'N' => array('Ń', 'Ñ', 'Ň', 'Ņ', 'Ŋ', 'Н'), 'L' => array('Ĺ', 'Ł', 'Л', 'Λ', 'Ļ'),
'O' => array('Ó', 'Ô', 'Ö', ', 'Ø', 'Ō', 'Ő', 'Ŏ', 'Ο', 'Ό', 'M' => array('М', 'Μ'),
'Ὀ', 'Ὁ', '', '', '', '', '', 'Ό', 'О'), 'N' => array('Ń', 'Ñ', 'Ň', 'Ņ', 'Ŋ', 'Н', 'Ν'),
'P' => array('П'), 'O' => array('Ó', 'Ò', 'Ỏ', 'Õ', 'Ọ', 'Ô', 'Ố', 'Ồ', 'Ổ', 'Ỗ',
'R' => array('Ř', 'Ŕ', 'Р'), 'Ộ', 'Ơ', 'Ớ', 'Ờ', 'Ở', 'Ỡ', 'Ợ', 'Ö', 'Ø', 'Ō',
'S' => array('Ş', 'Ŝ', 'Ș', 'Š', 'Ś', 'С'), 'Ő', 'Ŏ', 'Ο', 'Ό', '', '', '', '', '', '',
'T' => array('Ť', 'Ţ', 'Ŧ', 'Ț', 'Т'), '', 'Ό', 'О', 'Θ', 'Ө'),
'U' => array('Ù', 'Ú', 'Û', ', 'Ū', 'Ů', 'Ű', 'Ŭ', 'Ũ', 'Ų', 'P' => array('П', 'Π'),
'У'), 'R' => array('Ř', 'Ŕ', 'Р', 'Ρ'),
'S' => array('Ş', 'Ŝ', 'Ș', 'Š', 'Ś', 'С', 'Σ'),
'T' => array('Ť', 'Ţ', 'Ŧ', 'Ț', 'Т', 'Τ'),
'U' => array('Ú', 'Ù', 'Ủ', 'Ũ', 'Ụ', 'Ư', 'Ứ', 'Ừ', 'Ử', 'Ữ',
'Ự', 'Û', 'Ü', 'Ū', 'Ů', 'Ű', 'Ŭ', 'Ų', 'У'),
'V' => array('В'), 'V' => array('В'),
'Y' => array('Ý', 'Ÿ', 'Ῠ', 'Ῡ', 'Ὺ', 'Ύ', 'Ы', '), 'W' => array('Ω', '),
'Z' => array('Ź', 'Ž', 'Ż', 'З'), 'X' => array('Χ'),
'Y' => array('Ý', 'Ỳ', 'Ỷ', 'Ỹ', 'Ỵ', 'Ÿ', 'Ῠ', 'Ῡ', 'Ὺ', 'Ύ',
'Ы', 'Й', 'Υ', 'Ϋ'),
'Z' => array('Ź', 'Ž', 'Ż', 'З', 'Ζ'),
'AE' => array('Æ'),
'CH' => array('Ч'), 'CH' => array('Ч'),
'DJ' => array('Ђ'),
'DZ' => array('Џ'),
'KH' => array('Х'), 'KH' => array('Х'),
'LJ' => array('Љ'),
'NJ' => array('Њ'),
'PS' => array('Ψ'),
'SH' => array('Ш'), 'SH' => array('Ш'),
'SHCH' => array('Щ'), 'SHCH' => array('Щ'),
'SS' => array('ẞ'),
'TH' => array('Þ'),
'TS' => array('Ц'), 'TS' => array('Ц'),
'YA' => array('Я'), 'YA' => array('Я'),
'YU' => array('Ю'), 'YU' => array('Ю'),
'ZH' => array('Ж'), 'ZH' => array('Ж'),
' ' => array("\xC2\xA0", "\xE2\x80\x89", "\xE2\x80\xAF", ' ' => array("\xC2\xA0", "\xE2\x80\x80", "\xE2\x80\x81",
"\xE3\x80\x80"), "\xE2\x80\x82", "\xE2\x80\x83", "\xE2\x80\x84",
"\xE2\x80\x85", "\xE2\x80\x86", "\xE2\x80\x87",
"\xE2\x80\x88", "\xE2\x80\x89", "\xE2\x80\x8A",
"\xE2\x80\xAF", "\xE2\x81\x9F", "\xE3\x80\x80"),
); );
foreach ($charsArray as $key => $value) {
$str = str_replace($value, $key, $str);
}
$str = preg_replace('/[^\x20-\x7E]/u', '', $str);
return static::create($str, $this->encoding);
} }
/** /**
@@ -618,8 +672,8 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
$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)), 0, $rightPadding = mb_substr(str_repeat($padStr, ceil($right / $length)),
$right, $stringy->encoding); 0, $right, $stringy->encoding);
$stringy->str = $leftPadding . $stringy->str . $rightPadding; $stringy->str = $leftPadding . $stringy->str . $rightPadding;
@@ -755,13 +809,13 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
*/ */
public function slugify($replacement = '-') public function slugify($replacement = '-')
{ {
$stringy = static::create($this->str, $this->encoding); $stringy = $this->toAscii();
$quotedReplacement = preg_quote($replacement); $quotedReplacement = preg_quote($replacement);
$pattern = "/[^a-zA-Z\d\s-_$quotedReplacement]/u"; $pattern = "/[^a-zA-Z\d\s-_$quotedReplacement]/u";
$stringy->str = preg_replace($pattern, '', $stringy->toAscii()); $stringy->str = preg_replace($pattern, '', $stringy);
return $stringy->toLowerCase()->applyDelimeter($replacement) return $stringy->toLowerCase()->applyDelimiter($replacement)
->removeLeft($replacement)->removeRight($replacement); ->removeLeft($replacement)->removeRight($replacement);
} }
@@ -837,7 +891,8 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
* Surrounds $str with the given substring. * Surrounds $str with the given substring.
* *
* @param string $substring The substring to add to both sides * @param string $substring The substring to add to both sides
* @return Stringy Object whose $str had the substring prepended and appended * @return Stringy Object whose $str had the substring both prepended and
* appended
*/ */
public function surround($substring) public function surround($substring)
{ {
@@ -1052,7 +1107,8 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
$len = 0; $len = 0;
$end = 0; $end = 0;
$table = array_fill(0, $strLength + 1, array_fill(0, $otherLength + 1, 0)); $table = array_fill(0, $strLength + 1,
array_fill(0, $otherLength + 1, 0));
for ($i = 1; $i <= $strLength; $i++) { for ($i = 1; $i <= $strLength; $i++) {
for ($j = 1; $j <= $otherLength; $j++) { for ($j = 1; $j <= $otherLength; $j++) {
@@ -1241,6 +1297,28 @@ class Stringy implements \Countable, \IteratorAggregate, \ArrayAccess
return $match; return $match;
} }
/**
* Returns true if the string contains a lower case char, false
* otherwise.
*
* @return bool Whether or not the string contains a lower case character.
*/
public function hasLowerCase()
{
return $this->matchesPattern('.*[[:lower:]]');
}
/**
* Returns true if the string contains an upper case char, false
* otherwise.
*
* @return bool Whether or not the string contains an upper case character.
*/
public function hasUpperCase()
{
return $this->matchesPattern('.*[[:upper:]]');
}
/** /**
* Returns true if the string contains only alphabetic chars, false * Returns true if the string contains only alphabetic chars, false
* otherwise. * otherwise.

View File

@@ -174,9 +174,12 @@ abstract class CommonTest extends PHPUnit_Framework_TestCase
array('test string', 'test string'), array('test string', 'test string'),
array('Ο συγγραφέας', ' Ο συγγραφέας '), array('Ο συγγραφέας', ' Ο συγγραφέας '),
array('123', ' 123 '), array('123', ' 123 '),
array('', ' ', 'UTF-8'), // no-break space array('', ' ', 'UTF-8'), // no-break space (U+00A0)
array('1 2 3', '  1  2  3  ', 'UTF-8'), // ideographic spaces array('', ' ', 'UTF-8'), // spaces U+2000 to U+200A
array('', ' ', 'UTF-8'), // thin space and space array('', '', 'UTF-8'), // narrow no-break space (U+202F)
array('', '', 'UTF-8'), // medium mathematical space (U+205F)
array('', ' ', 'UTF-8'), // ideographic space (U+3000)
array('1 2 3', '  123  ', 'UTF-8'),
array('', ' '), array('', ' '),
array('', ''), array('', ''),
); );
@@ -187,14 +190,21 @@ abstract class CommonTest extends PHPUnit_Framework_TestCase
return array( return array(
array('foo bar', 'fòô bàř'), array('foo bar', 'fòô bàř'),
array(' TEST ', ' ŤÉŚŢ '), array(' TEST ', ' ŤÉŚŢ '),
array(' = z = 3', 'φ = ź = 3'), array('f = z = 3', 'φ = ź = 3'),
array('perevirka', 'перевірка'), array('perevirka', 'перевірка'),
array('lysaya gora', 'лысая гора'), array('lysaya gora', 'лысая гора'),
array('shchuka', 'щука'), array('shchuka', 'щука'),
array('', '漢字'), array('', '漢字'),
array(' ', ' '), // no-break space array('xin chao the gioi', 'xin chào thế giới'),
array(' 1 2 3 ', '  1  2  3  '), // ideographic spaces array('XIN CHAO THE GIOI', 'XIN CHÀO THẾ GIỚI'),
array(' ', ' '), // thin space and space array('dam phat chet luon', 'đấm phát chết luôn'),
array(' ', ' '), // no-break space (U+00A0)
array(' ', ' '), // spaces U+2000 to U+200A
array(' ', ''), // narrow no-break space (U+202F)
array(' ', ''), // medium mathematical space (U+205F)
array(' ', ' '), // ideographic space (U+3000)
array('', '𐍉'), // some uncommon, unsupported character (U+10349)
array('𐍉', '𐍉', false),
); );
} }
@@ -365,7 +375,6 @@ abstract class CommonTest extends PHPUnit_Framework_TestCase
array('foo-dbar', " Foo d'Bar "), array('foo-dbar', " Foo d'Bar "),
array('a-string-with-dashes', 'A string-with-dashes'), array('a-string-with-dashes', 'A string-with-dashes'),
array('using-strings-like-foo-bar', 'Using strings like fòô bàř'), array('using-strings-like-foo-bar', 'Using strings like fòô bàř'),
array('unrecognized-chars-like', 'unrecognized chars like συγγρ'),
array('numbers-1234', 'numbers 1234'), array('numbers-1234', 'numbers 1234'),
array('perevirka-ryadka', 'перевірка рядка'), array('perevirka-ryadka', 'перевірка рядка'),
array('bukvar-s-bukvoy-y', 'букварь с буквой ы'), array('bukvar-s-bukvoy-y', 'букварь с буквой ы'),
@@ -832,9 +841,11 @@ abstract class CommonTest extends PHPUnit_Framework_TestCase
array(false, "\n\t ' \v\f"), array(false, "\n\t ' \v\f"),
array(false, "\n\t 2 \v\f"), array(false, "\n\t 2 \v\f"),
array(true, '', 'UTF-8'), array(true, '', 'UTF-8'),
array(true, ' ', 'UTF-8'), // no-break space array(true, ' ', 'UTF-8'), // no-break space (U+00A0)
array(true, ' ', 'UTF-8'), // thin space array(true, ' ', 'UTF-8'), // spaces U+2000 to U+200A
array(true, '  ', 'UTF-8'), // ideographic spaces array(true, '', 'UTF-8'), // narrow no-break space (U+202F)
array(true, '', 'UTF-8'), // medium mathematical space (U+205F)
array(true, ' ', 'UTF-8'), // ideographic space (U+3000)
array(false, ' z', 'UTF-8'), array(false, ' z', 'UTF-8'),
array(false, ' 1', 'UTF-8'), array(false, ' 1', 'UTF-8'),
); );
@@ -874,6 +885,24 @@ abstract class CommonTest extends PHPUnit_Framework_TestCase
); );
} }
public function hasLowerCaseProvider()
{
return array(
array(false, ''),
array(true, 'foobar'),
array(false, 'FOO BAR'),
array(true, 'fOO BAR'),
array(true, 'foO BAR'),
array(true, 'FOO BAr'),
array(true, 'Foobar'),
array(false, 'FÒÔBÀŘ', 'UTF-8'),
array(true, 'fòôbàř', 'UTF-8'),
array(true, 'fòôbàř2', 'UTF-8'),
array(true, 'Fòô bàř', 'UTF-8'),
array(true, 'fòôbÀŘ', 'UTF-8'),
);
}
public function isSerializedProvider() public function isSerializedProvider()
{ {
return array( return array(
@@ -901,6 +930,24 @@ abstract class CommonTest extends PHPUnit_Framework_TestCase
); );
} }
public function hasUpperCaseProvider()
{
return array(
array(false, ''),
array(true, 'FOOBAR'),
array(false, 'foo bar'),
array(true, 'Foo bar'),
array(true, 'FOo bar'),
array(true, 'foo baR'),
array(true, 'fOOBAR'),
array(false, 'fòôbàř', 'UTF-8'),
array(true, 'FÒÔBÀŘ', 'UTF-8'),
array(true, 'FÒÔBÀŘ2', 'UTF-8'),
array(true, 'fÒÔ BÀŘ', 'UTF-8'),
array(true, 'FÒÔBàř', 'UTF-8'),
);
}
public function isHexadecimalProvider() public function isHexadecimalProvider()
{ {
return array( return array(

View File

@@ -133,9 +133,9 @@ class StaticStringyTestCase extends CommonTest
/** /**
* @dataProvider toAsciiProvider() * @dataProvider toAsciiProvider()
*/ */
public function testToAscii($expected, $str) public function testToAscii($expected, $str, $removeUnsupported = true)
{ {
$result = S::toAscii($str); $result = S::toAscii($str, $removeUnsupported);
$this->assertInternalType('string', $result); $this->assertInternalType('string', $result);
$this->assertEquals($expected, $result); $this->assertEquals($expected, $result);
} }
@@ -565,6 +565,16 @@ class StaticStringyTestCase extends CommonTest
$this->assertEquals($expected, $result); $this->assertEquals($expected, $result);
} }
/**
* @dataProvider hasLowerCaseProvider()
*/
public function testHasLowerCase($expected, $str, $encoding = null)
{
$result = S::hasLowerCase($str, $encoding);
$this->assertInternalType('boolean', $result);
$this->assertEquals($expected, $result);
}
/** /**
* @dataProvider isSerializedProvider() * @dataProvider isSerializedProvider()
*/ */
@@ -585,6 +595,16 @@ class StaticStringyTestCase extends CommonTest
$this->assertEquals($expected, $result); $this->assertEquals($expected, $result);
} }
/**
* @dataProvider hasUpperCaseProvider()
*/
public function testHasUpperCase($expected, $str, $encoding = null)
{
$result = S::hasUpperCase($str, $encoding);
$this->assertInternalType('boolean', $result);
$this->assertEquals($expected, $result);
}
/** /**
* @dataProvider isHexadecimalProvider() * @dataProvider isHexadecimalProvider()
*/ */

View File

@@ -300,10 +300,10 @@ class StringyTestCase extends CommonTest
/** /**
* @dataProvider toAsciiProvider() * @dataProvider toAsciiProvider()
*/ */
public function testToAscii($expected, $str) public function testToAscii($expected, $str, $removeUnsupported = true)
{ {
$stringy = S::create($str); $stringy = S::create($str);
$result = $stringy->toAscii(); $result = $stringy->toAscii($removeUnsupported);
$this->assertStringy($result); $this->assertStringy($result);
$this->assertEquals($expected, $result); $this->assertEquals($expected, $result);
$this->assertEquals($str, $stringy); $this->assertEquals($str, $stringy);
@@ -813,6 +813,18 @@ class StringyTestCase extends CommonTest
$this->assertEquals($str, $stringy); $this->assertEquals($str, $stringy);
} }
/**
* @dataProvider hasLowerCaseProvider()
*/
public function testHasLowerCase($expected, $str, $encoding = null)
{
$stringy = S::create($str, $encoding);
$result = $stringy->hasLowerCase();
$this->assertInternalType('boolean', $result);
$this->assertEquals($expected, $result);
$this->assertEquals($str, $stringy);
}
/** /**
* @dataProvider isSerializedProvider() * @dataProvider isSerializedProvider()
*/ */
@@ -837,6 +849,18 @@ class StringyTestCase extends CommonTest
$this->assertEquals($str, $stringy); $this->assertEquals($str, $stringy);
} }
/**
* @dataProvider hasUpperCaseProvider()
*/
public function testHasUpperCase($expected, $str, $encoding = null)
{
$stringy = S::create($str, $encoding);
$result = $stringy->hasUpperCase();
$this->assertInternalType('boolean', $result);
$this->assertEquals($expected, $result);
$this->assertEquals($str, $stringy);
}
/** /**
* @dataProvider isHexadecimalProvider() * @dataProvider isHexadecimalProvider()
*/ */