RulesetInflector.php 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. declare(strict_types=1);
  3. namespace Doctrine\Inflector;
  4. use Doctrine\Inflector\Rules\Ruleset;
  5. use function array_merge;
  6. /**
  7. * Inflects based on multiple rulesets.
  8. *
  9. * Rules:
  10. * - If the word matches any uninflected word pattern, it is not inflected
  11. * - The first ruleset that returns a different value for an irregular word wins
  12. * - The first ruleset that returns a different value for a regular word wins
  13. * - If none of the above match, the word is left as-is
  14. */
  15. class RulesetInflector implements WordInflector
  16. {
  17. /** @var Ruleset[] */
  18. private $rulesets;
  19. public function __construct(Ruleset $ruleset, Ruleset ...$rulesets)
  20. {
  21. $this->rulesets = array_merge([$ruleset], $rulesets);
  22. }
  23. public function inflect(string $word): string
  24. {
  25. if ($word === '') {
  26. return '';
  27. }
  28. foreach ($this->rulesets as $ruleset) {
  29. if ($ruleset->getUninflected()->matches($word)) {
  30. return $word;
  31. }
  32. $inflected = $ruleset->getIrregular()->inflect($word);
  33. if ($inflected !== $word) {
  34. return $inflected;
  35. }
  36. $inflected = $ruleset->getRegular()->inflect($word);
  37. if ($inflected !== $word) {
  38. return $inflected;
  39. }
  40. }
  41. return $word;
  42. }
  43. }