123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\Translation\Util;
- /**
- * ArrayConverter generates tree like structure from a message catalogue.
- * e.g. this
- * 'foo.bar1' => 'test1',
- * 'foo.bar2' => 'test2'
- * converts to follows:
- * foo:
- * bar1: test1
- * bar2: test2.
- *
- * @author Gennady Telegin <gtelegin@gmail.com>
- */
- class ArrayConverter
- {
- /**
- * Converts linear messages array to tree-like array.
- * For example this rray('foo.bar' => 'value') will be converted to ['foo' => ['bar' => 'value']].
- *
- * @param array $messages Linear messages array
- *
- * @return array Tree-like messages array
- */
- public static function expandToTree(array $messages)
- {
- $tree = [];
- foreach ($messages as $id => $value) {
- $referenceToElement = &self::getElementByPath($tree, explode('.', $id));
- $referenceToElement = $value;
- unset($referenceToElement);
- }
- return $tree;
- }
- private static function &getElementByPath(array &$tree, array $parts)
- {
- $elem = &$tree;
- $parentOfElem = null;
- foreach ($parts as $i => $part) {
- if (isset($elem[$part]) && \is_string($elem[$part])) {
- /* Process next case:
- * 'foo': 'test1',
- * 'foo.bar': 'test2'
- *
- * $tree['foo'] was string before we found array {bar: test2}.
- * Treat new element as string too, e.g. add $tree['foo.bar'] = 'test2';
- */
- $elem = &$elem[implode('.', \array_slice($parts, $i))];
- break;
- }
- $parentOfElem = &$elem;
- $elem = &$elem[$part];
- }
- if ($elem && \is_array($elem) && $parentOfElem) {
- /* Process next case:
- * 'foo.bar': 'test1'
- * 'foo': 'test2'
- *
- * $tree['foo'] was array = {bar: 'test1'} before we found string constant `foo`.
- * Cancel treating $tree['foo'] as array and cancel back it expansion,
- * e.g. make it $tree['foo.bar'] = 'test1' again.
- */
- self::cancelExpand($parentOfElem, $part, $elem);
- }
- return $elem;
- }
- private static function cancelExpand(array &$tree, $prefix, array $node)
- {
- $prefix .= '.';
- foreach ($node as $id => $value) {
- if (\is_string($value)) {
- $tree[$prefix.$id] = $value;
- } else {
- self::cancelExpand($tree, $prefix.$id, $value);
- }
- }
- }
- }
|