Documentation
# tran_fmt

```rust
use std::borrow::Borrow;

pub use roaring::treemap::RoaringTreemap;

pub struct TranFmt {
  pub li: Vec<String>,
  pub line_pos: RoaringTreemap,
}

pub fn tran_fmt(txt: impl AsRef<str>) -> (RoaringTreemap, Vec<String>) {
  let mut line_pos = RoaringTreemap::new();
  let mut li = vec![];
  for (pos, i) in txt.as_ref().lines().enumerate() {
    let i = i.trim_end();
    if i.is_empty() {
      continue;
    }
    li.push(i.into());
    line_pos.insert(pos as _);
  }
  (line_pos, li)
}

pub fn restore<S: AsRef<str>>(
  line_pos: impl Borrow<RoaringTreemap>,
  li: impl IntoIterator<Item = S>,
) -> String {
  let mut r = String::new();
  let mut pre = 0;
  for (pos, i) in line_pos.borrow().iter().zip(li.into_iter()) {
    let pos = pos as usize;
    while pre < pos {
      r.push('\n');
      pre += 1;
    }
    r.push_str(i.as_ref());
  }
  r
}
```

## 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 为阅读体验而优化。