forked from mirrors/gecko-dev
Bug 1895922 - Fix locale detection in the crash reporter r=cmartin
Differential Revision: https://phabricator.services.mozilla.com/D209937
This commit is contained in:
parent
2f36d75c2a
commit
4e741aa8df
1 changed files with 54 additions and 31 deletions
|
|
@ -21,18 +21,57 @@ pub fn read() -> anyhow::Result<LanguageInfo> {
|
|||
path.push("omni.ja");
|
||||
|
||||
let mut zip = read_omnijar_file(&path)?;
|
||||
let locale = {
|
||||
let locales = {
|
||||
let buf = BufReader::new(
|
||||
zip.by_name("res/multilocale.txt")
|
||||
.context("failed to read multilocale file in zip archive")?,
|
||||
);
|
||||
buf.lines()
|
||||
let line = buf
|
||||
.lines()
|
||||
.next()
|
||||
.ok_or(anyhow::anyhow!("multilocale file was empty"))?
|
||||
.context("failed to read first line of multilocale file")?
|
||||
.context("failed to read first line of multilocale file")?;
|
||||
line.split(",")
|
||||
.map(|s| s.trim().to_owned())
|
||||
.collect::<Vec<_>>()
|
||||
};
|
||||
|
||||
let mut file = zip
|
||||
let (locale, ftl_definitions) = 'defs: {
|
||||
for locale in &locales {
|
||||
match read_strings(locale, &mut zip) {
|
||||
Ok(v) => break 'defs (locale.to_string(), v),
|
||||
Err(e) => log::warn!("{e:#}"),
|
||||
}
|
||||
}
|
||||
anyhow::bail!("failed to find any usable localized strings in the omnijar")
|
||||
};
|
||||
|
||||
// The brand ftl is in the browser omnijar.
|
||||
path.pop();
|
||||
path.push("browser");
|
||||
path.push("omni.ja");
|
||||
|
||||
let ftl_branding = 'branding: {
|
||||
for locale in &locales {
|
||||
match read_branding(&locale, &mut zip) {
|
||||
Ok(v) => break 'branding v,
|
||||
Err(e) => log::warn!("failed to read branding from omnijar: {e:#}"),
|
||||
}
|
||||
}
|
||||
log::info!("using fallback branding info");
|
||||
LanguageInfo::default().ftl_branding
|
||||
};
|
||||
|
||||
Ok(LanguageInfo {
|
||||
identifier: locale,
|
||||
ftl_definitions,
|
||||
ftl_branding,
|
||||
})
|
||||
}
|
||||
|
||||
/// Read the localized strings from the given zip archive (omnijar).
|
||||
fn read_strings(locale: &str, archive: &mut ZipArchive<File>) -> anyhow::Result<String> {
|
||||
let mut file = archive
|
||||
.by_name(&format!(
|
||||
"localization/{locale}/crashreporter/crashreporter.ftl"
|
||||
))
|
||||
|
|
@ -42,34 +81,18 @@ pub fn read() -> anyhow::Result<LanguageInfo> {
|
|||
file.read_to_string(&mut ftl_definitions)
|
||||
.with_context(|| format!("failed to read localization file for {locale}"))?;
|
||||
|
||||
// The brand ftl is in the browser omnijar.
|
||||
path.pop();
|
||||
path.push("browser");
|
||||
path.push("omni.ja");
|
||||
Ok(ftl_definitions)
|
||||
}
|
||||
|
||||
let ftl_branding = read_omnijar_file(&path)
|
||||
.and_then(|mut zip| {
|
||||
let mut file = zip
|
||||
.by_name(&format!("localization/{locale}/branding/brand.ftl"))
|
||||
.with_context(|| {
|
||||
format!("failed to locate branding localization file for {locale}")
|
||||
})?;
|
||||
let mut s = String::new();
|
||||
file.read_to_string(&mut s)
|
||||
.with_context(|| format!("failed to read localization file for {locale}"))?;
|
||||
Ok(s)
|
||||
})
|
||||
.unwrap_or_else(|e| {
|
||||
log::warn!("failed to read browser omnijar: {e}");
|
||||
log::info!("using fallback branding info");
|
||||
LanguageInfo::default().ftl_branding
|
||||
});
|
||||
|
||||
Ok(LanguageInfo {
|
||||
identifier: locale,
|
||||
ftl_definitions,
|
||||
ftl_branding,
|
||||
})
|
||||
/// Read the branding information from the given zip archive (omnijar).
|
||||
fn read_branding(locale: &str, archive: &mut ZipArchive<File>) -> anyhow::Result<String> {
|
||||
let mut file = archive
|
||||
.by_name(&format!("localization/{locale}/branding/brand.ftl"))
|
||||
.with_context(|| format!("failed to locate branding localization file for {locale}"))?;
|
||||
let mut s = String::new();
|
||||
file.read_to_string(&mut s)
|
||||
.with_context(|| format!("failed to read branding localization file for {locale}"))?;
|
||||
Ok(s)
|
||||
}
|
||||
|
||||
fn read_omnijar_file(path: &Path) -> anyhow::Result<ZipArchive<File>> {
|
||||
|
|
|
|||
Loading…
Reference in a new issue