| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 | /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */"use strict";module.metadata = {  "stability": "unstable"};const { Cc, Ci } = require("chrome");const { getPreferedLocales, findClosestLocale } = require("./locale");const { readURI } = require("../net/url");const { resolve } = require("../core/promise");function parseJsonURI(uri) {  return readURI(uri).    then(JSON.parse).    then(null, function (error) {      throw Error("Failed to parse locale file:\n" + uri + "\n" + error);    });}// Returns the array stored in `locales.json` manifest that list available// locales filesfunction getAvailableLocales(rootURI) {  let uri = rootURI + "locales.json";  return parseJsonURI(uri).then(function (manifest) {    return "locales" in manifest &&           Array.isArray(manifest.locales) ?           manifest.locales : [];  });}// Returns URI of the best locales file to use from the XPIfunction getBestLocale(rootURI) {  // Read localization manifest file that contains list of available languages  return getAvailableLocales(rootURI).then(function (availableLocales) {    // Retrieve list of prefered locales to use    let preferedLocales = getPreferedLocales();    // Compute the most preferable locale to use by using these two lists    return findClosestLocale(availableLocales, preferedLocales);  });}/** * Read localization files and returns a promise of data to put in `@l10n/data` * pseudo module, in order to allow l10n/core to fetch it. */exports.load = function load(rootURI) {  // First, search for a locale file:  return getBestLocale(rootURI).then(function (bestMatchingLocale) {    // It may be null if the addon doesn't have any locale file    if (!bestMatchingLocale)      return resolve(null);    let localeURI = rootURI + "locale/" + bestMatchingLocale + ".json";    // Locale files only contains one big JSON object that is used as    // an hashtable of: "key to translate" => "translated key"    // TODO: We are likely to change this in order to be able to overload    //       a specific key translation. For a specific package, module or line?    return parseJsonURI(localeURI).then(function (json) {      return {        hash: json,        bestMatchingLocale: bestMatchingLocale      };    });  });}
 |