Skip to content

Commit 7332e63

Browse files
author
Robin Chalas
committed
Merge branch '3.4'
* 3.4: (38 commits) Fix merge [Lock] Expose an expiringDate and isExpired method in Lock [VarDumper] fix DateCasterTest [config] Add ability to deprecate a node feature #22382 [config] Add abbitily to deprecate a node (Nyholm, fabpot, sanpii) Fix segfault in period caster Create an interface for TranslationReader and moved TranslationLoader to Translation component Always require symfony/polyfill-apcu to provide APCuIterator everywhere [Lock] Fix some tests that require pcntl_sigwaitinfo() function bumped Symfony version to 3.3.9 updated VERSION for 3.3.8 updated CHANGELOG for 3.3.8 [DI] Fix tracking env var placeholders nested in object graphs bumped Symfony version to 3.3.8 updated VERSION for 3.3.7 updated CHANGELOG for 3.3.7 Add period caster [DI] improve psr4-based service discovery with namespace option [DI] Fix tracking env vars when merging configs (bis) removed obsolete comment ...
2 parents 0ed4739 + f9448c8 commit 7332e63

File tree

6 files changed

+117
-15
lines changed

6 files changed

+117
-15
lines changed

CHANGELOG.md

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -12,8 +12,9 @@ CHANGELOG
1212
* Added `TranslationDumperPass`
1313
* Added `TranslationExtractorPass`
1414
* Added `TranslatorPass`
15-
* Added <notes> section to the Xliff 2.0 dumper.
16-
* Improved Xliff 2.0 loader to load <notes> section.
15+
* Added `TranslationReader` and `TranslationReaderInterface`
16+
* Added `<notes>` section to the Xliff 2.0 dumper.
17+
* Improved Xliff 2.0 loader to load `<notes>` section.
1718
* Added `TranslationWriterInterface`
1819
* Deprecated `TranslationWriter::writeTranslations` in favor of `TranslationWriter::write`
1920

DependencyInjection/TranslatorPass.php

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -19,13 +19,13 @@
1919
class TranslatorPass implements CompilerPassInterface
2020
{
2121
private $translatorServiceId;
22-
private $loaderServiceId;
22+
private $readerServiceId;
2323
private $loaderTag;
2424

25-
public function __construct($translatorServiceId = 'translator.default', $loaderServiceId = 'translation.loader', $loaderTag = 'translation.loader')
25+
public function __construct($translatorServiceId = 'translator.default', $readerServiceId = 'translation.reader', $loaderTag = 'translation.loader')
2626
{
2727
$this->translatorServiceId = $translatorServiceId;
28-
$this->loaderServiceId = $loaderServiceId;
28+
$this->readerServiceId = $readerServiceId;
2929
$this->loaderTag = $loaderTag;
3030
}
3131

@@ -45,8 +45,8 @@ public function process(ContainerBuilder $container)
4545
}
4646
}
4747

48-
if ($container->hasDefinition($this->loaderServiceId)) {
49-
$definition = $container->getDefinition($this->loaderServiceId);
48+
if ($container->hasDefinition($this->readerServiceId)) {
49+
$definition = $container->getDefinition($this->readerServiceId);
5050
foreach ($loaders as $id => $formats) {
5151
foreach ($formats as $format) {
5252
$definition->addMethodCall('addLoader', array($format, $loaderRefs[$id]));

Reader/TranslationReader.php

Lines changed: 63 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,63 @@
1+
<?php
2+
3+
/*
4+
* This file is part of the Symfony package.
5+
*
6+
* (c) Fabien Potencier <[email protected]>
7+
*
8+
* For the full copyright and license information, please view the LICENSE
9+
* file that was distributed with this source code.
10+
*/
11+
12+
namespace Symfony\Component\Translation\Reader;
13+
14+
use Symfony\Component\Finder\Finder;
15+
use Symfony\Component\Translation\Loader\LoaderInterface;
16+
use Symfony\Component\Translation\MessageCatalogue;
17+
18+
/**
19+
* TranslationReader reads translation messages from translation files.
20+
*
21+
* @author Michel Salib <[email protected]>
22+
*/
23+
class TranslationReader implements TranslationReaderInterface
24+
{
25+
/**
26+
* Loaders used for import.
27+
*
28+
* @var array
29+
*/
30+
private $loaders = array();
31+
32+
/**
33+
* Adds a loader to the translation extractor.
34+
*
35+
* @param string $format The format of the loader
36+
* @param LoaderInterface $loader
37+
*/
38+
public function addLoader($format, LoaderInterface $loader)
39+
{
40+
$this->loaders[$format] = $loader;
41+
}
42+
43+
/**
44+
* {@inheritdoc}
45+
*/
46+
public function read($directory, MessageCatalogue $catalogue)
47+
{
48+
if (!is_dir($directory)) {
49+
return;
50+
}
51+
52+
foreach ($this->loaders as $format => $loader) {
53+
// load any existing translation files
54+
$finder = new Finder();
55+
$extension = $catalogue->getLocale().'.'.$format;
56+
$files = $finder->files()->name('*.'.$extension)->in($directory);
57+
foreach ($files as $file) {
58+
$domain = substr($file->getFilename(), 0, -1 * strlen($extension) - 1);
59+
$catalogue->addCatalogue($loader->load($file->getPathname(), $catalogue->getLocale(), $domain));
60+
}
61+
}
62+
}
63+
}

Reader/TranslationReaderInterface.php

Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
<?php
2+
3+
/*
4+
* This file is part of the Symfony package.
5+
*
6+
* (c) Fabien Potencier <[email protected]>
7+
*
8+
* For the full copyright and license information, please view the LICENSE
9+
* file that was distributed with this source code.
10+
*/
11+
12+
namespace Symfony\Component\Translation\Reader;
13+
14+
use Symfony\Component\Translation\MessageCatalogue;
15+
16+
/**
17+
* TranslationReader reads translation messages from translation files.
18+
*
19+
* @author Tobias Nyholm <[email protected]>
20+
*/
21+
interface TranslationReaderInterface
22+
{
23+
/**
24+
* Reads translation messages from a directory to the catalogue.
25+
*
26+
* @param string $directory
27+
* @param MessageCatalogue $catalogue
28+
*/
29+
public function read($directory, MessageCatalogue $catalogue);
30+
}

Tests/DependencyInjection/TranslationPassTest.php

Lines changed: 15 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -25,26 +25,33 @@ public function testValidCollector()
2525
$loader = (new Definition())
2626
->addTag('translation.loader', array('alias' => 'xliff', 'legacy-alias' => 'xlf'));
2727

28+
$reader = new Definition();
29+
2830
$translator = (new Definition())
2931
->setArguments(array(null, null, null, null));
3032

3133
$container = new ContainerBuilder();
3234
$container->setDefinition('translator.default', $translator);
33-
$container->setDefinition('translation.loader', $loader);
35+
$container->setDefinition('translation.reader', $reader);
36+
$container->setDefinition('translation.xliff_loader', $loader);
3437

35-
$pass = new TranslatorPass();
38+
$pass = new TranslatorPass('translator.default', 'translation.reader');
3639
$pass->process($container);
3740

38-
$expected = (new Definition())
41+
$expectedReader = (new Definition())
42+
->addMethodCall('addLoader', array('xliff', new Reference('translation.xliff_loader')))
43+
->addMethodCall('addLoader', array('xlf', new Reference('translation.xliff_loader')))
44+
;
45+
$this->assertEquals($expectedReader, $reader);
46+
47+
$expectedLoader = (new Definition())
3948
->addTag('translation.loader', array('alias' => 'xliff', 'legacy-alias' => 'xlf'))
40-
->addMethodCall('addLoader', array('xliff', new Reference('translation.loader')))
41-
->addMethodCall('addLoader', array('xlf', new Reference('translation.loader')))
4249
;
43-
$this->assertEquals($expected, $loader);
50+
$this->assertEquals($expectedLoader, $loader);
4451

45-
$this->assertSame(array('translation.loader' => array('xliff', 'xlf')), $translator->getArgument(3));
52+
$this->assertSame(array('translation.xliff_loader' => array('xliff', 'xlf')), $translator->getArgument(3));
4653

47-
$expected = array('translation.loader' => new ServiceClosureArgument(new Reference('translation.loader')));
54+
$expected = array('translation.xliff_loader' => new ServiceClosureArgument(new Reference('translation.xliff_loader')));
4855
$this->assertEquals($expected, $container->getDefinition((string) $translator->getArgument(0))->getArgument(0));
4956
}
5057
}

composer.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@
2424
"symfony/dependency-injection": "~3.4|~4.0",
2525
"symfony/intl": "~3.4|~4.0",
2626
"symfony/yaml": "~3.4|~4.0",
27+
"symfony/finder": "~2.8|~3.0|~4.0",
2728
"psr/log": "~1.0"
2829
},
2930
"conflict": {

0 commit comments

Comments
 (0)