21 releases
0.1.31 | Sep 3, 2024 |
---|---|
0.1.30 | Sep 2, 2024 |
0.1.29 | Aug 30, 2024 |
#197 in Internationalization (i18n)
Used in i18n-site
44KB
857 lines
ytree
use aok::{Result, OK};
use static_init::constructor;
#[constructor(0)]
extern "C" fn init() {
loginit::init()
}
#[test]
fn test() -> Result<()> {
// let paths = vec![
// "README.md#a".to_string(),
// "blog/README.md#2".to_string(),
// "blog/news/README.md#c".to_string(),
// "blog/news/begin.md#d".to_string(),
// "x/news/1.md#x".to_string(),
// "x/2/3.md#y".to_string(),
// ];
//
// // let yml = serde_yaml::to_string(&root).unwrap();
// // info!("{}", yml);
//
// let mut bitmap = roaring::RoaringBitmap::new();
// for i in [Lang::Ja, Lang::En, Lang::Zh, Lang::ZhTw] {
// bitmap.insert(i as u32);
// }
//
// let yml = ytree::sitemap::dumps(HashMap::from_iter([(lang_li_e(&bitmap), paths)]));
//
// info!("{yml}");
// let cursor = Cursor::new(yml.as_bytes());
//
// let yml = ytree::sitemap::loads(cursor.lines().map_while(Result::ok));
//
// let t = yml.sitemap("/Users/z/i18n/md")?;
// for i in &t.rel_lang_set {
// info!("{} {:?}", i.0, i.1);
// }
// // for i in t.set() {
// // println!("{i}");
// // }
// info!("{}", t.dumps());
OK
}
About
This project is an open-source component of i18n.site ⋅ Internationalization Solution.
-
i18 : MarkDown Command Line Translation Tool
The translation perfectly maintains the Markdown format.
It recognizes file changes and only translates the modified files.
The translated Markdown content is editable; if you modify the original text and translate it again, manually edited translations will not be overwritten (as long as the original text has not been changed).
-
i18n.site : MarkDown Multi-language Static Site Generator
Optimized for a better reading experience
关于
本项目为 i18n.site ⋅ 国际化解决方案 的开源组件。
-
翻译能够完美保持 Markdown 的格式。能识别文件的修改,仅翻译有变动的文件。
Markdown 翻译内容可编辑;如果你修改原文并再次机器翻译,手动修改过的翻译不会被覆盖(如果这段原文没有被修改)。
-
i18n.site : MarkDown多语言静态站点生成器 为阅读体验而优化。
Dependencies
~2–3.5MB
~72K SLoC