upgraded dependencies
This commit is contained in:
		| @@ -26,6 +26,10 @@ use Symfony\Component\Translation\MessageCatalogueInterface; | ||||
|  */ | ||||
| abstract class AbstractOperation implements OperationInterface | ||||
| { | ||||
|     public const OBSOLETE_BATCH = 'obsolete'; | ||||
|     public const NEW_BATCH = 'new'; | ||||
|     public const ALL_BATCH = 'all'; | ||||
|  | ||||
|     protected $source; | ||||
|     protected $target; | ||||
|     protected $result; | ||||
| @@ -79,7 +83,18 @@ abstract class AbstractOperation implements OperationInterface | ||||
|     public function getDomains() | ||||
|     { | ||||
|         if (null === $this->domains) { | ||||
|             $this->domains = array_values(array_unique(array_merge($this->source->getDomains(), $this->target->getDomains()))); | ||||
|             $domains = []; | ||||
|             foreach ([$this->source, $this->target] as $catalogue) { | ||||
|                 foreach ($catalogue->getDomains() as $domain) { | ||||
|                     $domains[$domain] = $domain; | ||||
|  | ||||
|                     if ($catalogue->all($domainIcu = $domain.MessageCatalogueInterface::INTL_DOMAIN_SUFFIX)) { | ||||
|                         $domains[$domainIcu] = $domainIcu; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             $this->domains = array_values($domains); | ||||
|         } | ||||
|  | ||||
|         return $this->domains; | ||||
| @@ -88,49 +103,49 @@ abstract class AbstractOperation implements OperationInterface | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getMessages($domain) | ||||
|     public function getMessages(string $domain) | ||||
|     { | ||||
|         if (!\in_array($domain, $this->getDomains())) { | ||||
|             throw new InvalidArgumentException(sprintf('Invalid domain: "%s".', $domain)); | ||||
|         } | ||||
|  | ||||
|         if (!isset($this->messages[$domain]['all'])) { | ||||
|         if (!isset($this->messages[$domain][self::ALL_BATCH])) { | ||||
|             $this->processDomain($domain); | ||||
|         } | ||||
|  | ||||
|         return $this->messages[$domain]['all']; | ||||
|         return $this->messages[$domain][self::ALL_BATCH]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getNewMessages($domain) | ||||
|     public function getNewMessages(string $domain) | ||||
|     { | ||||
|         if (!\in_array($domain, $this->getDomains())) { | ||||
|             throw new InvalidArgumentException(sprintf('Invalid domain: "%s".', $domain)); | ||||
|         } | ||||
|  | ||||
|         if (!isset($this->messages[$domain]['new'])) { | ||||
|         if (!isset($this->messages[$domain][self::NEW_BATCH])) { | ||||
|             $this->processDomain($domain); | ||||
|         } | ||||
|  | ||||
|         return $this->messages[$domain]['new']; | ||||
|         return $this->messages[$domain][self::NEW_BATCH]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getObsoleteMessages($domain) | ||||
|     public function getObsoleteMessages(string $domain) | ||||
|     { | ||||
|         if (!\in_array($domain, $this->getDomains())) { | ||||
|             throw new InvalidArgumentException(sprintf('Invalid domain: "%s".', $domain)); | ||||
|         } | ||||
|  | ||||
|         if (!isset($this->messages[$domain]['obsolete'])) { | ||||
|         if (!isset($this->messages[$domain][self::OBSOLETE_BATCH])) { | ||||
|             $this->processDomain($domain); | ||||
|         } | ||||
|  | ||||
|         return $this->messages[$domain]['obsolete']; | ||||
|         return $this->messages[$domain][self::OBSOLETE_BATCH]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -147,11 +162,42 @@ abstract class AbstractOperation implements OperationInterface | ||||
|         return $this->result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param self::*_BATCH $batch | ||||
|      */ | ||||
|     public function moveMessagesToIntlDomainsIfPossible(string $batch = self::ALL_BATCH): void | ||||
|     { | ||||
|         // If MessageFormatter class does not exists, intl domains are not supported. | ||||
|         if (!class_exists(\MessageFormatter::class)) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         foreach ($this->getDomains() as $domain) { | ||||
|             $intlDomain = $domain.MessageCatalogueInterface::INTL_DOMAIN_SUFFIX; | ||||
|             switch ($batch) { | ||||
|                 case self::OBSOLETE_BATCH: $messages = $this->getObsoleteMessages($domain); break; | ||||
|                 case self::NEW_BATCH: $messages = $this->getNewMessages($domain); break; | ||||
|                 case self::ALL_BATCH: $messages = $this->getMessages($domain); break; | ||||
|                 default: throw new \InvalidArgumentException(sprintf('$batch argument must be one of ["%s", "%s", "%s"].', self::ALL_BATCH, self::NEW_BATCH, self::OBSOLETE_BATCH)); | ||||
|             } | ||||
|  | ||||
|             if (!$messages || (!$this->source->all($intlDomain) && $this->source->all($domain))) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $result = $this->getResult(); | ||||
|             $allIntlMessages = $result->all($intlDomain); | ||||
|             $currentMessages = array_diff_key($messages, $result->all($domain)); | ||||
|             $result->replace($currentMessages, $domain); | ||||
|             $result->replace($allIntlMessages + $messages, $intlDomain); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Performs operation on source and target catalogues for the given domain and | ||||
|      * stores the results. | ||||
|      * | ||||
|      * @param string $domain The domain which the operation will be performed for | ||||
|      */ | ||||
|     abstract protected function processDomain($domain); | ||||
|     abstract protected function processDomain(string $domain); | ||||
| } | ||||
|   | ||||
| @@ -27,7 +27,7 @@ class MergeOperation extends AbstractOperation | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function processDomain($domain) | ||||
|     protected function processDomain(string $domain) | ||||
|     { | ||||
|         $this->messages[$domain] = [ | ||||
|             'all' => [], | ||||
|   | ||||
| @@ -44,29 +44,23 @@ interface OperationInterface | ||||
|     /** | ||||
|      * Returns all valid messages ('all') after operation. | ||||
|      * | ||||
|      * @param string $domain | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getMessages($domain); | ||||
|     public function getMessages(string $domain); | ||||
|  | ||||
|     /** | ||||
|      * Returns new messages ('new') after operation. | ||||
|      * | ||||
|      * @param string $domain | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getNewMessages($domain); | ||||
|     public function getNewMessages(string $domain); | ||||
|  | ||||
|     /** | ||||
|      * Returns obsolete messages ('obsolete') after operation. | ||||
|      * | ||||
|      * @param string $domain | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getObsoleteMessages($domain); | ||||
|     public function getObsoleteMessages(string $domain); | ||||
|  | ||||
|     /** | ||||
|      * Returns resulting catalogue ('result'). | ||||
|   | ||||
| @@ -28,7 +28,7 @@ class TargetOperation extends AbstractOperation | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function processDomain($domain) | ||||
|     protected function processDomain(string $domain) | ||||
|     { | ||||
|         $this->messages[$domain] = [ | ||||
|             'all' => [], | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 RafficMohammed
					RafficMohammed