Completed
Push — master ( 90072e...c81959 )
by Daniel
11:23
created

YamlReader::normaliseMessages()   A

Complexity

Conditions 4
Paths 3

Size

Total Lines 18
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 4
eloc 11
nc 3
nop 1
dl 0
loc 18
rs 9.2
c 0
b 0
f 0
1
<?php
2
3
namespace SilverStripe\i18n\Messages;
4
5
use SilverStripe\Dev\Debug;
6
use Symfony\Component\Translation\Exception\InvalidResourceException;
7
use Symfony\Component\Yaml\Exception\ParseException;
8
use Symfony\Component\Yaml\Parser;
9
10
class YamlReader implements Reader
11
{
12
    /**
13
     * @var Parser
14
     */
15
    protected $parser = null;
16
17
    /**
18
     * @return Parser
19
     */
20
    protected function getParser()
21
    {
22
        if (!$this->parser) {
23
            $this->parser = new Parser();
24
        }
25
        return $this->parser;
26
    }
27
28
    public function read($locale, $path)
29
    {
30
        try {
31
            if (!file_exists($path)) {
32
                return [];
33
            }
34
            // Load
35
            $yaml = $this->getParser()->parse(file_get_contents($path));
36
            if (empty($yaml[$locale])) {
37
                return [];
38
            }
39
            // Normalise messages
40
            return $this->normaliseMessages($yaml[$locale]);
41
        } catch (ParseException $exception) {
42
            var_dump($exception);
0 ignored issues
show
Security Debugging Code introduced by
var_dump($exception); looks like debug code. Are you sure you do not want to remove it? This might expose sensitive data.
Loading history...
43
            throw new InvalidResourceException(sprintf('Error parsing YAML, invalid file "%s"', $path), 0, $exception);
44
        }
45
    }
46
47
    /**
48
     * Flatten [class => [ key1 => value1, key2 => value2]] into [class.key1 => value1, class.key2 => value2]
49
     *
50
     * Inverse of YamlWriter::denormaliseMessages()
51
     *
52
     * @param array $entities
53
     * @return mixed
54
     */
55
    protected function normaliseMessages($entities)
56
    {
57
        $messages = [];
58
        // Squash second and third levels together (class.key)
59
        foreach ($entities as $class => $keys) {
60
            // Check if namespace omits class
61
            if (!is_array($keys)) {
62
                $messages[$class] = $keys;
63
            } else {
64
                foreach ($keys as $key => $value) {
65
                    $fullKey = "{$class}.{$key}";
66
                    $messages[$fullKey] = $value;
67
                }
68
            }
69
        }
70
        ksort($messages);
71
        return $messages;
72
    }
73
}
74