123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- <?php namespace Laravel;
- class Pluralizer {
- /**
- * The "strings" configuration array.
- *
- * @var array
- */
- protected $config;
- /**
- * The cached copies of the plural inflections.
- */
- protected $plural = array();
- /**
- * The cached copies of the singular inflections.
- *
- * @var array
- */
- protected $singular = array();
- /**
- * Create a new pluralizer instance.
- *
- * @return void
- */
- public function __construct($config)
- {
- $this->config = $config;
- }
- /**
- * Get the singular form of the given word.
- *
- * @param string $value
- * @return string
- */
- public function singular($value)
- {
- // First we'll check the cache of inflected values. We cache each word that
- // is inflected so we don't have to spin through the regular expressions
- // each time we need to inflect a given value for the developer.
- if (isset($this->singular[$value]))
- {
- return $this->singular[$value];
- }
- // English words may be automatically inflected using regular expressions.
- // If the word is english, we'll just pass off the word to the automatic
- // inflection method and return the result, which is cached.
- $irregular = $this->config['irregular'];
- $result = $this->auto($value, $this->config['singular'], $irregular);
- return $this->singular[$value] = $result ?: $value;
- }
- /**
- * Get the plural form of the given word.
- *
- * @param string $value
- * @param int $count
- * @return string
- */
- public function plural($value, $count = 2)
- {
- if ((int) $count == 1) return $value;
- // First we'll check the cache of inflected values. We cache each word that
- // is inflected so we don't have to spin through the regular expressions
- // each time we need to inflect a given value for the developer.
- if (isset($this->plural[$value]))
- {
- return $this->plural[$value];
- }
- // English words may be automatically inflected using regular expressions.
- // If the word is english, we'll just pass off the word to the automatic
- // inflection method and return the result, which is cached.
- $irregular = array_flip($this->config['irregular']);
- $result = $this->auto($value, $this->config['plural'], $irregular);
- return $this->plural[$value] = $result;
- }
- /**
- * Perform auto inflection on an English word.
- *
- * @param string $value
- * @param array $source
- * @param array $irregular
- * @return string
- */
- protected function auto($value, $source, $irregular)
- {
- // If the word hasn't been cached, we'll check the list of words that
- // that are "uncountable". This should be a quick look up since we
- // can just hit the array directly for the value.
- if (in_array(Str::lower($value), $this->config['uncountable']))
- {
- return $value;
- }
- // Next we will check the "irregular" patterns, which contains words
- // like "children" and "teeth" which can not be inflected using the
- // typically used regular expression matching approach.
- foreach ($irregular as $irregular => $pattern)
- {
- if (preg_match($pattern = '/'.$pattern.'$/i', $value))
- {
- return preg_replace($pattern, $irregular, $value);
- }
- }
- // Finally we'll spin through the array of regular expressions and
- // and look for matches for the word. If we find a match we will
- // cache and return the inflected value for quick look up.
- foreach ($source as $pattern => $inflected)
- {
- if (preg_match($pattern, $value))
- {
- return preg_replace($pattern, $inflected, $value);
- }
- }
- }
- }
|