aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/verify-locale-strings.js
diff options
context:
space:
mode:
authorHerman Junge <herman.junge@consensys.net>2018-03-20 00:51:51 +0800
committerHerman Junge <herman.junge@consensys.net>2018-03-20 00:57:19 +0800
commit72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44 (patch)
treeaebbfa50e2fc9243c74a870ccf44158152e3ea49 /app/scripts/verify-locale-strings.js
parent424e98f6a896df6a848a92ef318464abc505d83d (diff)
downloadtangerine-wallet-browser-72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44.tar
tangerine-wallet-browser-72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44.tar.gz
tangerine-wallet-browser-72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44.tar.bz2
tangerine-wallet-browser-72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44.tar.lz
tangerine-wallet-browser-72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44.tar.xz
tangerine-wallet-browser-72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44.tar.zst
tangerine-wallet-browser-72bfe74243d2ac986f4ae8ed8fd6b58c95aaad44.zip
Add script to verify locale strings
Diffstat (limited to 'app/scripts/verify-locale-strings.js')
-rw-r--r--app/scripts/verify-locale-strings.js96
1 files changed, 96 insertions, 0 deletions
diff --git a/app/scripts/verify-locale-strings.js b/app/scripts/verify-locale-strings.js
new file mode 100644
index 000000000..b1234a43c
--- /dev/null
+++ b/app/scripts/verify-locale-strings.js
@@ -0,0 +1,96 @@
+////////////////////////////////////////////////////////////////////////////////
+//
+// Locale verification script
+//
+// usage:
+//
+// node app/scripts/verify-locale-strings.js <locale>
+//
+// will check the given locale against the strings in english
+//
+////////////////////////////////////////////////////////////////////////////////
+
+var fs = require('fs')
+var path = require('path')
+
+console.log('Locale Verification')
+
+var locale = process.argv[2]
+if (!locale || locale == '') {
+ console.log('Must enter a locale as argument. exitting')
+ process.exit(1)
+}
+
+console.log("verifying for locale " + locale)
+
+localeFilePath = path.join(process.cwd(), 'app', '_locales', locale, 'messages.json')
+try {
+ localeObj = JSON.parse(fs.readFileSync(localeFilePath, 'utf8'));
+} catch (e) {
+ if(e.code == 'ENOENT') {
+ console.log('Locale file not found')
+ } else {
+ console.log('Error opening your locale file: ', e)
+ }
+ process.exit(1)
+}
+
+englishFilePath = path.join(process.cwd(), 'app', '_locales', 'en', 'messages.json')
+try {
+ englishObj = JSON.parse(fs.readFileSync(englishFilePath, 'utf8'));
+} catch (e) {
+ if(e.code == 'ENOENT') {
+ console.log("English File not found")
+ } else {
+ console.log("Error opening english locale file: ", e)
+ }
+ process.exit(1)
+}
+
+console.log('\tverifying whether all your locale strings are contained in the english one')
+
+var counter = 0
+var foundError = false
+var notFound = [];
+Object.keys(localeObj).forEach(function(key){
+ if (!englishObj[key]) {
+ foundError = true
+ notFound.push(key)
+ }
+ counter++
+})
+
+if (foundError) {
+ console.log('\nThe following string(s) is(are) not found in the english locale:')
+ notFound.forEach(function(key) {
+ console.log(key)
+ })
+ process.exit(1)
+}
+
+console.log('\tall ' + counter +' strings declared in your locale were found in the english one')
+
+console.log('\n\tverifying whether your locale contains all english strings')
+
+var counter = 0
+var foundError = false
+var notFound = [];
+Object.keys(englishObj).forEach(function(key){
+ if (!localeObj[key]) {
+ foundError = true
+ notFound.push(key)
+ }
+ counter++
+})
+
+if (foundError) {
+ console.log('\nThe following string(s) is(are) not found in the your locale:')
+ notFound.forEach(function(key) {
+ console.log(key)
+ })
+ process.exit(1)
+}
+
+console.log('\tall ' + counter +' english strings were found in your locale!')
+
+console.log('You are good to go') \ No newline at end of file