From 72ae09bc6871a187edbf1d08f2a98352d452aced Mon Sep 17 00:00:00 2001 From: Guy Sartorelli <36352093+GuySartorelli@users.noreply.github.com> Date: Wed, 8 May 2024 10:43:57 +1200 Subject: [PATCH] FIX Don't keep empty files (#28) * FIX Don't keep empty files Files can be empty if previous runs provided incorrect values (e.g. english strings inside non-english files), and subsequent runs remove the errant values. * FIX Allow committing deletion of files --- src/Translator.php | 60 +++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 59 insertions(+), 1 deletion(-) diff --git a/src/Translator.php b/src/Translator.php index f7c6b89..c6a64a9 100644 --- a/src/Translator.php +++ b/src/Translator.php @@ -62,6 +62,8 @@ public function run() $this->cleanYaml(); $this->mergeJson(); $this->removeEnglishStringsFromJsonTranslations(); + $this->removeEmptyYamlFiles(); + $this->removeEmptyJsFiles(); } if ($this->doCollectStrings) { $this->collectStrings(); @@ -531,7 +533,7 @@ private function gitCommitPushAndPullRequest(): void $langPath = $this->getYmlLangDirectory($modulePath); foreach (array_merge((array) $jsPath, (array) $langPath) as $path) { if (is_dir($path)) { - $this->exec("git add $path/*", $modulePath); + $this->exec("git add $path", $modulePath); } } $this->exec("git add .tx/config", $modulePath); @@ -729,9 +731,65 @@ private function generateJavascriptInDirectory(string $modulePath, string $jsPat file_put_contents($targetFile, $targetContents); $count++; } + // Delete any javascript files which don't have a src file + foreach (glob("{$jsPath}/*.js") as $filePath) { + $dir = dirname($filePath); + $fileName = basename($filePath); + $srcFilePath = "$dir/src/$fileName"; + // no src .js and no src .json + if (!file_exists($srcFilePath) && !file_exists($srcFilePath . 'on')) { + $this->log("Deleting empty js file: $filePath", true); + $success = unlink($filePath); + if (!$success) { + throw new RuntimeException("Couldn't delete empty yaml file: $filePath"); + } + } + } return $count; } + private function removeEmptyYamlFiles(): void + { + foreach ($this->modulePaths as $modulePath) { + foreach (glob($this->getYmlLangDirectory($modulePath) . '/*.yml') as $filePath) { + $rawYaml = file_get_contents($filePath); + $parsed = Yaml::parse($rawYaml); + $isEmpty = true; + foreach (array_keys($parsed) as $countryCode) { + if (!empty($parsed[$countryCode])) { + $isEmpty = false; + } + } + if ($isEmpty) { + $this->log("Deleting empty yaml file: $filePath", true); + $success = unlink($filePath); + if (!$success) { + throw new RuntimeException("Couldn't delete empty yaml file: $filePath"); + } + } + } + } + } + + private function removeEmptyJsFiles(): void + { + foreach ($this->modulePaths as $modulePath) { + $jsPaths = $this->getJSLangDirectories($modulePath); + foreach ((array)$jsPaths as $jsPath) { + foreach (glob("{$jsPath}/src/*.js*") as $filePath) { + $sourceContentsDecoded = $this->jsonDecode(file_get_contents($filePath)); + if (empty($sourceContentsDecoded)) { + $this->log("Deleting empty js src file: $filePath", true); + $success = unlink($filePath); + if (!$success) { + throw new RuntimeException("Couldn't delete empty json file: $filePath"); + } + } + } + } + } + } + private function jsonEncode(array $data): string { $content = json_encode($data, JSON_PRETTY_PRINT + JSON_UNESCAPED_SLASHES + JSON_UNESCAPED_UNICODE);