25ec318f3f
Fix .po updating (without the -U option, the result was written to stdout, not the .po file)
62 lines
2.0 KiB
Rust
62 lines
2.0 KiB
Rust
use std::fs::{create_dir_all, File};
|
|
use std::io::{BufReader, prelude::*};
|
|
use std::path::Path;
|
|
use std::process::Command;
|
|
|
|
fn main() {
|
|
update_po();
|
|
compile_po();
|
|
}
|
|
|
|
fn update_po() {
|
|
let pot_path = Path::new("po").join("plume.pot");
|
|
|
|
for lang in get_locales() {
|
|
let po_path = Path::new("po").join(format!("{}.po", lang.clone()));
|
|
if po_path.exists() && po_path.is_file() {
|
|
println!("Updating {}", lang.clone());
|
|
// Update it
|
|
Command::new("msgmerge")
|
|
.arg("-U")
|
|
.arg(po_path.to_str().unwrap())
|
|
.arg(pot_path.to_str().unwrap())
|
|
.spawn()
|
|
.expect("Couldn't update PO file");
|
|
} else {
|
|
println!("Creating {}", lang.clone());
|
|
// Create it from the template
|
|
Command::new("msginit")
|
|
.arg(format!("--input={}", pot_path.to_str().unwrap()))
|
|
.arg(format!("--output-file={}", po_path.to_str().unwrap()))
|
|
.arg("-l")
|
|
.arg(lang)
|
|
.arg("--no-translator")
|
|
.spawn()
|
|
.expect("Couldn't init PO file");
|
|
}
|
|
}
|
|
}
|
|
|
|
fn compile_po() {
|
|
for lang in get_locales() {
|
|
let po_path = Path::new("po").join(format!("{}.po", lang.clone()));
|
|
let mo_dir = Path::new("translations")
|
|
.join(lang.clone())
|
|
.join("LC_MESSAGES");
|
|
create_dir_all(mo_dir.clone()).expect("Couldn't create MO directory");
|
|
let mo_path = mo_dir.join("plume.mo");
|
|
|
|
Command::new("msgfmt")
|
|
.arg(format!("--output-file={}", mo_path.to_str().unwrap()))
|
|
.arg(po_path)
|
|
.spawn()
|
|
.expect("Couldn't compile translations");
|
|
}
|
|
}
|
|
|
|
fn get_locales() -> Vec<String> {
|
|
let linguas_file = File::open(Path::new("po").join("LINGUAS")).expect("Couldn't find po/LINGUAS file");
|
|
let linguas = BufReader::new(&linguas_file);
|
|
linguas.lines().map(Result::unwrap).collect()
|
|
}
|