# lineiter
```rust
use lineiter::LineIter;
#[test]
fn test_line_iter() {
let data = b"line1\nline2\r\nline3\rline4";
let expected_lines = [
"line1".to_string(),
"line2".to_string(),
"line3".to_string(),
"line4".to_string(),
];
// let data = b"line1";
// let expected_lines = ["line1".to_string()];
let lines = LineIter::new(&data[..]);
let mut n = 0;
for (line, expected) in lines.zip(expected_lines.iter()) {
match line {
Ok(line) => {
n += 1;
dbg!(&line);
assert_eq!(line, *expected)
}
Err(e) => panic!("Error: {}", e),
}
}
assert_eq!(n, expected_lines.len());
}
```
## 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) 为阅读体验而优化。