Comments, misc

v1.18.x
Peter Jaszkowiak 8 years ago
parent e94d47976d
commit 7f2ded17ab

@ -16,6 +16,7 @@ var coreLanguagesPath = path.join(__dirname, '../../public/language');
function getTranslationTree(callback) { function getTranslationTree(callback) {
async.waterfall([ async.waterfall([
// get plugin data
function (next) { function (next) {
db.getSortedSetRange('plugins:active', 0, -1, next); db.getSortedSetRange('plugins:active', 0, -1, next);
}, },
@ -33,9 +34,12 @@ function getTranslationTree(callback) {
function (paths, next) { function (paths, next) {
async.map(paths, Plugins.loadPluginInfo, next); async.map(paths, Plugins.loadPluginInfo, next);
}, },
// generate list of languages and namespaces
function (plugins, next) { function (plugins, next) {
var languages = [], namespaces = []; var languages = [], namespaces = [];
// pull languages and namespaces from paths
function extrude(languageDir, paths) { function extrude(languageDir, paths) {
paths.forEach(function (p) { paths.forEach(function (p) {
var rel = p.split(languageDir)[1].split(/[\/\\]/).slice(1); var rel = p.split(languageDir)[1].split(/[\/\\]/).slice(1);
@ -59,6 +63,7 @@ function getTranslationTree(callback) {
return (typeof pluginData.languages === 'string'); return (typeof pluginData.languages === 'string');
}); });
async.parallel([ async.parallel([
// get core languages and namespaces
function (nxt) { function (nxt) {
utils.walk(coreLanguagesPath, function (err, paths) { utils.walk(coreLanguagesPath, function (err, paths) {
if (err) { if (err) {
@ -69,6 +74,7 @@ function getTranslationTree(callback) {
nxt(); nxt();
}); });
}, },
// get plugin languages and namespaces
function (nxt) { function (nxt) {
async.each(plugins, function (pluginData, cb) { async.each(plugins, function (pluginData, cb) {
var pathToFolder = path.join(__dirname, '../../node_modules/', pluginData.id, pluginData.languages); var pathToFolder = path.join(__dirname, '../../node_modules/', pluginData.id, pluginData.languages);
@ -94,6 +100,10 @@ function getTranslationTree(callback) {
}); });
}); });
}, },
// for each language and namespace combination,
// run through core and all plugins to generate
// a full translation hash
function (ref, next) { function (ref, next) {
var languages = ref.languages; var languages = ref.languages;
var namespaces = ref.namespaces; var namespaces = ref.namespaces;
@ -104,7 +114,9 @@ function getTranslationTree(callback) {
async.eachLimit(languages, 10, function (lang, nxt) { async.eachLimit(languages, 10, function (lang, nxt) {
async.eachLimit(namespaces, 10, function (ns, cb) { async.eachLimit(namespaces, 10, function (ns, cb) {
var translations = {}; var translations = {};
async.series([ async.series([
// core first
function (n) { function (n) {
fs.readFile(path.join(coreLanguagesPath, lang, ns + '.json'), function (err, buffer) { fs.readFile(path.join(coreLanguagesPath, lang, ns + '.json'), function (err, buffer) {
if (err) { if (err) {
@ -123,6 +135,11 @@ function getTranslationTree(callback) {
}); });
}, },
function (n) { function (n) {
// for each plugin, fallback in this order:
// 1. correct language string (en-GB)
// 2. old language string (en_GB)
// 3. plugin defaultLang (en-US)
// 4. old plugin defaultLang (en_US)
async.eachLimit(plugins, 10, function (pluginData, call) { async.eachLimit(plugins, 10, function (pluginData, call) {
var pluginLanguages = path.join(__dirname, '../../node_modules/', pluginData.id, pluginData.languages); var pluginLanguages = path.join(__dirname, '../../node_modules/', pluginData.id, pluginData.languages);
function tryLang(lang, onEnoent) { function tryLang(lang, onEnoent) {
@ -169,7 +186,9 @@ function getTranslationTree(callback) {
], callback); ], callback);
} }
// write translation hashes from the generated tree to language files
function writeLanguageFiles(tree, callback) { function writeLanguageFiles(tree, callback) {
// iterate over languages and namespaces
async.eachLimit(Object.keys(tree), 10, function (language, cb) { async.eachLimit(Object.keys(tree), 10, function (language, cb) {
var namespaces = tree[language]; var namespaces = tree[language];
async.eachLimit(Object.keys(namespaces), 100, function (namespace, next) { async.eachLimit(Object.keys(namespaces), 100, function (namespace, next) {
@ -188,17 +207,15 @@ function writeLanguageFiles(tree, callback) {
}, callback); }, callback);
} }
module.exports = { exports.build = function buildLanguages(callback) {
build: function buildLanguages(callback) { async.waterfall([
async.waterfall([ getTranslationTree,
getTranslationTree, writeLanguageFiles,
writeLanguageFiles, ], function (err) {
], function (err) { if (err) {
if (err) { winston.error('[build] Language build failed: ' + err.message);
winston.error('[build] Language build failed'); throw err;
throw err; }
} callback();
callback(); });
});
},
}; };

Loading…
Cancel
Save