Skip to content

Commit

Permalink
Fix multi-file output (martinlindhe#96)
Browse files Browse the repository at this point in the history
  • Loading branch information
murrant authored and martinlindhe committed Oct 22, 2019
1 parent 0f88ac8 commit f546c3f
Show file tree
Hide file tree
Showing 3 changed files with 139 additions and 40 deletions.
2 changes: 1 addition & 1 deletion src/Commands/GenerateInclude.php
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ public function handle()

if ($multipleFiles || $multipleLocales) {
$files = (new Generator($config))
->generateMultiple($root, $format, $multipleLocales);
->generateMultiple($root, $format);

if ($config['showOutputMessages']) {
$this->info("Written to : " . $files);
Expand Down
59 changes: 22 additions & 37 deletions src/Generator.php
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ public function generateFromPath($path, $format = 'es6', $withVendor = false, $l
}

if (isset($locales[$noExt])) {
$locales[$noExt] = array_merge($local, $locales[$noExt]);
$locales[$noExt] = array_merge_recursive($local, $locales[$noExt]);
} else {
$locales[$noExt] = $local;
}
Expand All @@ -93,22 +93,7 @@ public function generateFromPath($path, $format = 'es6', $withVendor = false, $l

$locales = $this->adjustVendor($locales);

$jsonLocales = json_encode($locales, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES) . PHP_EOL;

if (json_last_error() !== JSON_ERROR_NONE) {
throw new Exception('Could not generate JSON, error code '.json_last_error());
}

// formats other than 'es6' and 'umd' will become plain JSON
if ($format === 'es6') {
$jsBody = $this->getES6Module($jsonLocales);
} elseif ($format === 'umd') {
$jsBody = $this->getUMDModule($jsonLocales);
} else {
$jsBody = $jsonLocales;
}

return $jsBody;
return $this->encodeJson($locales, $format);
}

/**
Expand All @@ -117,7 +102,7 @@ public function generateFromPath($path, $format = 'es6', $withVendor = false, $l
* @return string
* @throws Exception
*/
public function generateMultiple($path, $format = 'es6', $multiLocales = false)
public function generateMultiple($path, $format = 'es6')
{
if (!is_dir($path)) {
throw new Exception('Directory not found: ' . $path);
Expand All @@ -142,7 +127,7 @@ public function generateMultiple($path, $format = 'es6', $multiLocales = false)
$this->availableLocales[] = $noExt;
}
if ($fileinfo->isDir()) {
$local = $this->allocateLocaleArray($fileinfo->getRealPath(), $multiLocales);
$local = $this->allocateLocaleArray($fileinfo->getRealPath());
} else {
$local = $this->allocateLocaleJSON($fileinfo->getRealPath());
if ($local === null) continue;
Expand All @@ -156,20 +141,10 @@ public function generateMultiple($path, $format = 'es6', $multiLocales = false)
}
}
}
foreach ($this->filesToCreate as $fileName => $data) {
foreach ($locales as $fileName => $data) {
$fileToCreate = $jsPath . $fileName . '.js';
$createdFiles .= $fileToCreate . PHP_EOL;
$jsonLocales = json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES) . PHP_EOL;
if (json_last_error() !== JSON_ERROR_NONE) {
throw new Exception('Could not generate JSON, error code '.json_last_error());
}
if ($format === 'es6') {
$jsBody = $this->getES6Module($jsonLocales);
} elseif ($format === 'umd') {
$jsBody = $this->getUMDModule($jsonLocales);
} else {
$jsBody = $jsonLocales;
}
$jsBody = $this->encodeJson([$fileName => $data], $format);

if (!is_dir(dirname($fileToCreate))) {
mkdir(dirname($fileToCreate), 0777, true);
Expand Down Expand Up @@ -203,7 +178,7 @@ private function allocateLocaleJSON($path)
* @param string $path
* @return array
*/
private function allocateLocaleArray($path, $multiLocales = false)
private function allocateLocaleArray($path)
{
$data = [];
$dir = new DirectoryIterator($path);
Expand Down Expand Up @@ -243,11 +218,6 @@ private function allocateLocaleArray($path, $multiLocales = false)
if($filePath[0] === DIRECTORY_SEPARATOR) {
$filePath = substr($filePath, 1);
}
if ($multiLocales) {
$this->filesToCreate[$lastLocale][$lastLocale][$filePath] = $this->adjustArray($tmp);
} else {
$this->filesToCreate[$filePath][$lastLocale] = $this->adjustArray($tmp);
}
}

$data[$noExt] = $this->adjustArray($tmp);
Expand Down Expand Up @@ -404,4 +374,19 @@ private function getES6Module($body)
{
return "export default {$body}";
}

private function encodeJson($data, $format = 'es6')
{
$jsonLocales = json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES) . PHP_EOL;
if (json_last_error() !== JSON_ERROR_NONE) {
throw new Exception('Could not generate JSON, error code '.json_last_error());
}
if ($format === 'es6') {
return $this->getES6Module($jsonLocales);
} elseif ($format === 'umd') {
return $this->getUMDModule($jsonLocales);
}

return $jsonLocales;
}
}
118 changes: 116 additions & 2 deletions tests/GenerateTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,22 @@

class GenerateTest extends \PHPUnit_Framework_TestCase
{
private function generateLocaleFilesFrom(array $arr)
/**
* @return string
*/
private function getRootDir()
{
$root = sys_get_temp_dir() . '/' . sha1(microtime(true) . mt_rand());

if (!is_dir($root)) {
mkdir($root, 0777, true);
}
return $root;
}

private function generateLocaleFilesFrom(array $arr, $root = null)
{
$root = $root ?: $this->getRootDir();

foreach ($arr as $key => $val) {

Expand All @@ -27,6 +36,18 @@ private function generateLocaleFilesFrom(array $arr)
return $root;
}

private function generateJsonLocaleFilesFrom(array $arr, $root = null)
{
$root = $root ?: $this->getRootDir();

foreach ($arr as $lang => $data) {
$outFile = $root . '/' . $lang . '.json';
file_put_contents($outFile, json_encode($data));
}

return $root;
}

private function destroyLocaleFilesFrom(array $arr, $root)
{
foreach ($arr as $key => $val) {
Expand All @@ -38,6 +59,11 @@ private function destroyLocaleFilesFrom(array $arr, $root)
}
}

$jsonFile = $root . '/'. $key . '.json';
if (file_exists($jsonFile)) {
unlink($jsonFile);
}

if (is_dir($root . '/' . $key)) {
rmdir($root . '/' . $key);
}
Expand Down Expand Up @@ -86,6 +112,43 @@ function testBasic()
$this->destroyLocaleFilesFrom($arr, $root);
}

function testBasicJsonFiles()
{
$arr = [
'en' => [
'help' => [
'yes' => 'yes',
'no' => 'no',
]
],
'sv' => [
'help' => [
'yes' => 'ja',
'no' => 'nej',
]
]
];

$root = $this->generateJsonLocaleFilesFrom($arr);
$this->assertEquals(
'export default {' . PHP_EOL
. ' "en": {' . PHP_EOL
. ' "help": {' . PHP_EOL
. ' "yes": "yes",' . PHP_EOL
. ' "no": "no"' . PHP_EOL
. ' }' . PHP_EOL
. ' },' . PHP_EOL
. ' "sv": {' . PHP_EOL
. ' "help": {' . PHP_EOL
. ' "yes": "ja",' . PHP_EOL
. ' "no": "nej"' . PHP_EOL
. ' }' . PHP_EOL
. ' }' . PHP_EOL
. '}' . PHP_EOL,
(new Generator([]))->generateFromPath($root));
$this->destroyLocaleFilesFrom($arr, $root);
}

function testBasicES6Format()
{
$format = 'es6';
Expand Down Expand Up @@ -544,4 +607,55 @@ function testPluralization()

$this->destroyLocaleFilesFrom($arr, $root);
}

function testBothJsonAndPhpFiles()
{
$root = $this->getRootDir();
$jsonArr = [
'en' => [
'help' => [
'no' => 'no',
]
],
'sv' => [
'help' => [
'no' => 'nej',
]
]
];
$this->generateJsonLocaleFilesFrom($jsonArr, $root);

$phpArr = [
'en' => [
'help' => [
'yes' => 'yes',
]
],
'sv' => [
'help' => [
'yes' => 'ja',
]
]
];
$this->generateLocaleFilesFrom($phpArr, $root);

$this->assertEquals(
'export default {' . PHP_EOL
. ' "en": {' . PHP_EOL
. ' "help": {' . PHP_EOL
. ' "no": "no",' . PHP_EOL
. ' "yes": "yes"' . PHP_EOL
. ' }' . PHP_EOL
. ' },' . PHP_EOL
. ' "sv": {' . PHP_EOL
. ' "help": {' . PHP_EOL
. ' "no": "nej",' . PHP_EOL
. ' "yes": "ja"' . PHP_EOL
. ' }' . PHP_EOL
. ' }' . PHP_EOL
. '}' . PHP_EOL,
(new Generator([]))->generateFromPath($root));

$this->destroyLocaleFilesFrom($jsonArr, $root);
}
}

0 comments on commit f546c3f

Please sign in to comment.