#directory #libc #recursion #iterator #walk

fts

使用 libc fts 进行高性能目录遍历的 Rust 库

10 个版本

使用旧的 Rust 2015

0.3.0 2021 年 3 月 7 日
0.2.0 2018 年 5 月 6 日
0.1.7 2018 年 4 月 22 日
0.1.6 2018 年 3 月 26 日
0.1.4 2016 年 3 月 19 日

955文件系统

每月 37 次下载

MIT/Apache 许可协议

50KB
973 代码行

fts-rs

Actions Status Crates.io Docs.rs codecov

使用 libc fts 进行高性能目录遍历的 Rust 库。

文档

用法

[dependencies]
fts = "0.3.0"

示例

使用 WalkDir 进行目录遍历

use std::path::Path;
use fts::walkdir::{WalkDir, WalkDirConf};

let path = Path::new( "." );
for p in WalkDir::new( WalkDirConf::new( path ) ) {
    println!( "{:?}", p.unwrap() );
}

直接调用 fts_* 函数

use std::ffi::CString;
use fts::ffi::{fts_open, fts_read, fts_close, FTS_LOGICAL};

let path    = CString::new( "." ).unwrap();
let paths   = vec![path.as_ptr(), std::ptr::null()];
let fts     = unsafe { fts_open ( paths.as_ptr(), FTS_LOGICAL, None ) };
let _ftsent = unsafe { fts_read ( fts ) };
let _       = unsafe { fts_close( fts ) };

基准测试

以下是一个 cargo bench 结果。 fts_walkdir 是这个库,readdirstd::fs:read_dirwalkdirwalkdir::WalkDir。后缀 _metadata 表示使用 DirEntry::metadata() 调用。

test fts_walkdir          ... bench: 315,114,126 ns/iter (+/- 8,478,709)
test fts_walkdir_metadata ... bench: 480,089,245 ns/iter (+/- 11,478,335)
test readdir              ... bench: 575,856,224 ns/iter (+/- 15,021,486)
test readdir_metadata     ... bench: 790,838,218 ns/iter (+/- 12,780,010)
test walkdir              ... bench: 688,884,058 ns/iter (+/- 8,023,838)
test walkdir_metadata     ... bench: 904,379,691 ns/iter (+/- 10,212,776)

许可协议

根据您的选择,许可协议为以下之一:

贡献

除非您明确声明,否则根据 Apache-2.0 许可协议定义,您有意提交的任何贡献,都应双重许可,如上所述,无任何附加条款或条件。

依赖项

~0.6–2MB
~31K SLoC