Documentation
# ytree

```rust
use std::io::{BufRead, Cursor};

use aok::{Result, OK};
use lang::Lang;
use static_init::constructor;
use tracing::info;
use ytree::{sitemap::lang_li_e, Li};

#[constructor(0)]
extern "C" fn init() {
  loginit::init()
}

#[test]
fn test() -> Result<()> {
  let paths = [
    "README.md#a",
    "blog/README.md#2",
    "blog/news/README.md#c",
    "blog/news/begin.md#d",
    "x/news/1.md#x",
    "x/2/3.md#y",
  ];

  let mut root = Li(Vec::new());

  for path in paths {
    root.push(path);
  }

  // root.remove(paths[1]);
  // root.remove(paths[0]);

  for i in root.iter() {
    info!("{i}");
  }

  // 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([(lang_li_e(&bitmap), root)]);

  info!("{yml}");
  let cursor = Cursor::new(yml.as_bytes());

  let yml = ytree::sitemap::loads(cursor.lines().map_while(Result::ok));

  let t = yml.rel_lang_set("/Users/z/i18n/md")?;
  for i in &t.rel_lang_set {
    info!("{} {:?}", i.0, i.1);
  }
  info!("{}", t.dumps());
  OK
}
```

## About

This project is an open-source component of [i18n.site ⋅ Internationalization Solution](https://i18n.site).

* [i18 : MarkDown Command Line Translation Tool]https://i18n.site/i18

  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]https://i18n.site/i18n.site

  Optimized for a better reading experience

## 关于

本项目为 [i18n.site ⋅ 国际化解决方案](https://i18n.site) 的开源组件。

* [i18 :  MarkDown命令行翻译工具]https://i18n.site/i18

  翻译能够完美保持 Markdown 的格式。能识别文件的修改,仅翻译有变动的文件。

  Markdown 翻译内容可编辑;如果你修改原文并再次机器翻译,手动修改过的翻译不会被覆盖(如果这段原文没有被修改)。

* [i18n.site : MarkDown多语言静态站点生成器]https://i18n.site/i18n.site 为阅读体验而优化。