#future #fs #tokio #filesystem #fs-file

tokio-file-futures

基于tokio-fs的轮询文件操作之上的一些基本futures

1个不稳定版本

使用旧的Rust 2015

0.1.0 2018年5月2日

54#fs-file

GPL-3.0 许可证

24KB
524

文件Futures

此crate提供了对tokio-fs中提供的许多poll方法周围的Futures抽象。

使用方法

在Cargo.toml中添加依赖项

# Cargo.toml

[dependencies]
tokio-file-futures = "0.1"
tokio-fs = "0.1"
// src/main.rs

extern crate file_futures;
extern crate futures;
extern crate tokio_fs;

示例

use std::io::SeekFrom;

use file_futures::AsyncFile;
use futures::Future;
use tokio_fs::File;

fn main() {
    let future = File::create("/tmp/some-tmpfile")
        .map_err(|e| println!("Create Error {}", e))
        .and_then(|_| {
            let future1 = File::open("/tmp/some-tmpfile")
                .and_then(|file| file.metadata().and_then(|(_file, _metadata)| Ok(())))
                .map_err(|e| println!("Error1: {}", e));

            let future2 = File::open("/tmp/some-tmpfile")
                .and_then(|file| {
                    file.seek(SeekFrom::Start(30))
                        .and_then(|(_file, _from_start)| Ok(()))
                })
                .map_err(|e| println!("Error2: {}", e));

            future1.join(future2)
        });

    tokio::run(future.map(|_| ()));
}

贡献

请随时为任何发现的问题提交问题。请注意,任何贡献的代码都将根据GPLv3许可证授权。

许可证

版权所有 © 2017 Riley Trautman

Tokio File Futures是免费软件:您可以根据自由软件基金会发布的GNU通用公共许可证的条款重新分发和/或修改它,许可证版本为3,或(根据您的要求)许可证的任何后续版本。

Tokio File Futures是根据希望它将是有用的目的进行分发的,但没有任何保证;甚至没有关于其可销售性或适用于特定目的的暗示性保证。有关详细信息,请参阅GNU通用公共许可证。此文件是Tokio File Futures的一部分。

您应该已随Tokio File Futures收到GNU通用公共许可证的副本。如果没有收到,请参阅https://gnu.ac.cn/licenses/

依赖项

~1.5MB
~27K SLoC