From 704cb84a1196342d6b3c00da03fa5bc25783b08c Mon Sep 17 00:00:00 2001 From: Andrew Longosz Date: Wed, 24 Apr 2024 16:59:59 +0200 Subject: [PATCH] [5.0] Added strict types to Message and Plural Value Objects --- .../Repository/Values/Translation/Message.php | 15 ++++--- .../Repository/Values/Translation/Plural.php | 40 +++++++++---------- 2 files changed, 25 insertions(+), 30 deletions(-) diff --git a/src/contracts/Repository/Values/Translation/Message.php b/src/contracts/Repository/Values/Translation/Message.php index e53244b335..8b62a5eed8 100644 --- a/src/contracts/Repository/Values/Translation/Message.php +++ b/src/contracts/Repository/Values/Translation/Message.php @@ -4,6 +4,8 @@ * @copyright Copyright (C) Ibexa AS. All rights reserved. * @license For full copyright and license information view LICENSE file distributed with this source code. */ +declare(strict_types=1); + namespace Ibexa\Contracts\Core\Repository\Values\Translation; use Ibexa\Contracts\Core\Repository\Values\Translation; @@ -19,26 +21,23 @@ class Message extends Translation /** * Message string. Might use replacements like %foo%, which are replaced by * the values specified in the values array. - * - * @var string */ - protected $message; + protected string $message; /** * Translation value objects. May not contain any numbers, which might * result in requiring plural forms. Use Plural for that. * - * @var array + * @var array */ - protected $values; + protected array $values; /** * Construct singular only message from string and optional value array. * - * @param string $message - * @param array $values + * @param array $values */ - public function __construct($message, array $values = []) + public function __construct(string $message, array $values = []) { $this->message = $message; $this->values = $values; diff --git a/src/contracts/Repository/Values/Translation/Plural.php b/src/contracts/Repository/Values/Translation/Plural.php index d54134fe80..f1da181eff 100644 --- a/src/contracts/Repository/Values/Translation/Plural.php +++ b/src/contracts/Repository/Values/Translation/Plural.php @@ -15,17 +15,20 @@ * replaced by the values provided. A raw % can be escaped like %%. * * You need to provide a singular and plural variant for the string. The - * strings provided should be english and will be translated depending on the + * strings provided should be English and will be translated depending on the * environment language. * - * This interface follows the interfaces of XLiff, gettext, Symfony2 - * Translations and Zend_Translate. For singular forms you just provide a plain - * string (with optional placeholders without effects on the plural forms). For - * potential plural forms you always provide a singular variant and an english - * simple plural variant. No implementation supports multiple different plural - * forms in one single message. + * This interface follows the interfaces of XLIFF, gettext, Symfony Translations and Zend_Translate. + * For singular forms you just provide a plain string (with optional placeholders without effects on the plural forms). + * For potential plural forms you always provide a singular variant and an English simple plural variant. + * An instance of this class can be cast to a string. In such case whether to use singular or plural form is determined + * based on the value of first element of $values array (it needs to be 1 for singular, anything else for plural). + * If plurality cannot be inferred from $values, a plural form is assumed as default. To force singular form, + * use {@see \Ibexa\Contracts\Core\Repository\Values\Translation\Message} instead. * - * The singular / plural string could, for Symfony2, for example be converted + * No implementation supports multiple different plural forms in one single message. + * + * The singular / plural string could, for Symfony, for example be converted * to "$singular|$plural", and you would call gettext like: ngettext( * $singular, $plural, $count ). */ @@ -34,35 +37,28 @@ class Plural extends Translation /** * Singular string. Might use replacements like %foo%, which are replaced by * the values specified in the values array. - * - * @var string */ - protected $singular; + protected string $singular; /** * Message string. Might use replacements like %foo%, which are replaced by * the values specified in the values array. - * - * @var string */ - protected $plural; + protected string $plural; /** - * Translation value objects. May not contain any numbers, which might - * result in requiring plural forms. Use MessagePlural for that. + * Translation value objects. * - * @var array + * @var array */ - protected $values; + protected array $values; /** * Construct plural message from singular, plural and value array. * - * @param string $singular - * @param string $plural - * @param array $values + * @param array $values */ - public function __construct($singular, $plural, array $values) + public function __construct(string $singular, string $plural, array $values) { $this->singular = $singular; $this->plural = $plural;