ICanBoogie/CLDR 1.9.x
  • Namespace
  • Class

Namespaces

  • ICanBoogie
    • CLDR
      • Plurals
      • Units

Classes

  • AbstractCollection
  • AbstractSectionCollection
  • Calendar
  • CalendarCollection
  • ContextTransforms
  • Currency
  • CurrencyCollection
  • CurrencyFormatter
  • DateFormatter
  • DateTimeAccessor
  • DateTimeFormatter
  • FileProvider
  • ListFormatter
  • Locale
  • LocaleCollection
  • LocalizedCurrency
  • LocalizedCurrencyFormatter
  • LocalizedDateTime
  • LocalizedListFormatter
  • LocalizedLocale
  • LocalizedNumberFormatter
  • LocalizedObject
  • LocalizedObjectWithFormatter
  • LocalizedTerritory
  • Number
  • NumberFormatter
  • NumberPattern
  • NumberPatternParser
  • Numbers
  • Plurals
  • ProviderCollection
  • RedisProvider
  • Repository
  • RunTimeProvider
  • Supplemental
  • Territory
  • TerritoryCollection
  • TimeFormatter
  • Units
  • WebProvider

Interfaces

  • Exception
  • Formatter
  • LocalizeAwareInterface
  • Provider

Traits

  • CodePropertyTrait
  • CollectionTrait
  • LocalePropertyTrait
  • LocalizeTrait
  • ProviderStorageBinding
  • RepositoryPropertyTrait

Exceptions

  • ResourceNotFound
  • TerritoryNotDefined
  1   2   3   4   5   6   7   8   9  10  11  12  13  14  15  16  17  18  19  20  21  22  23  24  25  26  27  28  29  30  31  32  33  34  35  36  37  38  39  40  41  42  43  44  45  46  47  48  49  50  51  52  53  54  55  56  57  58  59  60  61  62  63  64  65  66  67  68  69  70  71  72  73  74  75  76  77  78  79  80  81  82  83  84  85  86  87  88  89  90  91  92  93  94  95  96  97  98  99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 
<?php

/*
 * This file is part of the ICanBoogie package.
 *
 * (c) Olivier Laviale <olivier.laviale@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace ICanBoogie\CLDR;

use ICanBoogie\Accessor\AccessorTrait;

/**
 * Formats variable-length lists of things such as "Monday, Tuesday, Friday, and Saturday".
 *
 * @see http://www.unicode.org/reports/tr35/tr35-general.html#ListPatterns
 *
 * @method LocalizedListFormatter localize($locale_code)
 */
class ListFormatter implements Formatter
{
    use AccessorTrait;
    use RepositoryPropertyTrait;
    use LocalizeTrait;

    /**
     * @param Repository $repository
     */
    public function __construct(Repository $repository = null)
    {
        $this->repository = $repository;
    }

    /**
     * Formats a variable-length lists of things.
     *
     * @param array $list The list to format.
     * @param array $list_patterns A list patterns.
     *
     * @return string
     */
    public function __invoke(array $list, array $list_patterns)
    {
        return $this->format($list, $list_patterns);
    }

    /**
     * Formats a variable-length lists of things.
     *
     * @param array $list The list to format.
     * @param array $list_patterns A list patterns.
     *
     * @return string
     */
    public function format(array $list, array $list_patterns)
    {
        $list = array_values($list);

        switch (count($list))
        {
            case 0:

                return "";

            case 1:

                return (string) current($list);

            case 2:

                return $this->format_pattern($list_patterns[2], $list[0], $list[1]);

            default:

                $n = count($list) - 1;
                $v1 = $list[$n];

                for ($i = $n - 1 ; $i > -1 ; $i--)
                {
                    $v0 = $list[$i];

                    if ($i == 0)
                    {
                        $pattern = $list_patterns['start'];
                    }
                    else if ($i + 1 == $n)
                    {
                        $pattern = $list_patterns['end'];
                    }
                    else
                    {
                        $pattern = $list_patterns['middle'];
                    }

                    $v1 = $this->format_pattern($pattern, $v0, $v1);
                }

                return $v1;
        }
    }

    /**
     * @param string $pattern
     * @param string $v0
     * @param string $v1
     *
     * @return string
     */
    private function format_pattern($pattern, $v0, $v1)
    {
        return strtr($pattern, [

            '{0}' => $v0,
            '{1}' => $v1

        ]);
    }
}
ICanBoogie/CLDR 1.9.x API documentation generated by ApiGen