Kolyunya/string-processor

View on GitHub
sources/Translit/Translator.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

namespace Kolyunya\StringProcessor\Translit;

use Kolyunya\StringProcessor\BaseProcessor;
use Kolyunya\StringProcessor\Translit\Dictionary\DictionaryInterface;
use Kolyunya\StringProcessor\Translit\TranslatorInterface;

/**
 * Translator.
 * @author Kolyunya
 */
class Translator extends BaseProcessor implements TranslatorInterface
{
    /**
     * Forward translation direction.
     */
    const DIRECTION_FORWARD = 0x00;

    /**
     * Reversed translation direction.
     */
    const DIRECTION_REVERSED = 0x01;

    /**
     * Translation dictionary.
     * @var DictionaryInterface
     */
    private $dictionary;

    /**
     * Translation direction.
     * @var integer
     */
    private $direction;

    /**
     * Constructs a translator using dictionary and direction
     * @param DictionaryInterface $dictionary Translation dictionary.
     * @param integer $direction Translation direction.
     */
    public function __construct(
        DictionaryInterface $dictionary = null,
        $direction = self::DIRECTION_FORWARD
    ) {
        $this->setDictionary($dictionary);
        $this->setDirection($direction);
    }

    /**
     * @inheritdoc
     */
    public function setDictionary(DictionaryInterface $dictionary)
    {
        $this->dictionary = $dictionary;
    }

    /**
     * @inheritdoc
     */
    public function setDirection($direction)
    {
        $this->direction = $direction;
    }

    /**
     * @inheritdoc
     */
    protected function selfProcession($string)
    {
        $string = $this->substituteCharacters($string);
        return $string;
    }

    /**
     * Substitutes characters in a string.
     * @param string $string String to substitute characters in.
     * @return string String with substituted characters.
     */
    private function substituteCharacters($string)
    {
        $substitutions = $this->dictionary->getSubstitutions();
        foreach ($substitutions as $from => $to) {
            if ($this->direction === self::DIRECTION_FORWARD) {
                $pattern = "/$from/u";
                $replacement = $to;
            } else {
                $pattern = "/$to/u";
                $replacement = $from;
            }
            $string = preg_replace($pattern, $replacement, $string);
        }
        return $string;
    }
}