123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161 |
- <?php
- declare(strict_types=1);
- /**
- * This file is part of Hyperf.
- *
- * @link https://www.hyperf.io
- * @document https://hyperf.wiki
- * @contact group@hyperf.io
- * @license https://github.com/hyperf/hyperf/blob/master/LICENSE
- */
- namespace Hyperf\Utils;
- use Doctrine\Inflector\CachedWordInflector;
- use Doctrine\Inflector\Inflector;
- use Doctrine\Inflector\Rules\English;
- use Doctrine\Inflector\RulesetInflector;
- class Pluralizer
- {
- /**
- * Uncountable word forms.
- *
- * @var array
- */
- public static $uncountable
- = [
- 'audio',
- 'bison',
- 'cattle',
- 'chassis',
- 'compensation',
- 'coreopsis',
- 'data',
- 'deer',
- 'education',
- 'emoji',
- 'equipment',
- 'evidence',
- 'feedback',
- 'firmware',
- 'fish',
- 'furniture',
- 'gold',
- 'hardware',
- 'information',
- 'jedi',
- 'kin',
- 'knowledge',
- 'love',
- 'metadata',
- 'money',
- 'moose',
- 'news',
- 'nutrition',
- 'offspring',
- 'plankton',
- 'pokemon',
- 'police',
- 'rain',
- 'rice',
- 'series',
- 'sheep',
- 'software',
- 'species',
- 'swine',
- 'traffic',
- 'wheat',
- ];
- /**
- * @var null|Inflector
- */
- protected static $inflector;
- /**
- * Get the plural form of an English word.
- *
- * @param string $value
- * @param int $count
- * @return string
- */
- public static function plural($value, $count = 2)
- {
- if ((int) abs($count) === 1 || static::uncountable($value)) {
- return $value;
- }
- $plural = static::getInflector()->pluralize($value);
- return static::matchCase($plural, $value);
- }
- /**
- * Get the singular form of an English word.
- *
- * @param string $value
- * @return string
- */
- public static function singular($value)
- {
- $singular = static::getInflector()->singularize($value);
- return static::matchCase($singular, $value);
- }
- public static function setInflector(?Inflector $inflector): void
- {
- static::$inflector = $inflector;
- }
- /**
- * Get the inflector instance.
- */
- public static function getInflector(): Inflector
- {
- if (is_null(static::$inflector)) {
- static::$inflector = new Inflector(
- new CachedWordInflector(new RulesetInflector(
- English\Rules::getSingularRuleset()
- )),
- new CachedWordInflector(new RulesetInflector(
- English\Rules::getPluralRuleset()
- ))
- );
- }
- return static::$inflector;
- }
- /**
- * Determine if the given value is uncountable.
- *
- * @param string $value
- * @return bool
- */
- protected static function uncountable($value)
- {
- return in_array(strtolower($value), static::$uncountable);
- }
- /**
- * Attempt to match the case on two strings.
- *
- * @param string $value
- * @param string $comparison
- * @return string
- */
- protected static function matchCase($value, $comparison)
- {
- $functions = ['mb_strtolower', 'mb_strtoupper', 'ucfirst', 'ucwords'];
- foreach ($functions as $function) {
- if (call_user_func($function, $comparison) === $comparison) {
- return call_user_func($function, $value);
- }
- }
- return $value;
- }
- }
|