Crate async_tempfile

source ·
Expand description

async-tempfile

Provides the TempFile struct, an asynchronous wrapper based on tokio::fs for temporary files that will be automatically deleted when the last reference to the struct is dropped.

use async_tempfile::TempFile;

#[tokio::main]
async fn main() {
    let parent = TempFile::new().await.unwrap();

    // The cloned reference will not delete the file when dropped.
    {
        let nested = parent.open_rw().await.unwrap();
        assert_eq!(nested.file_path(), parent.file_path());
        assert!(nested.file_path().is_file());
    }

    // The file still exists; it will be deleted when `parent` is dropped.
    assert!(parent.file_path().is_file());
}

Features

  • uuid - (Default) Enables random file name generation based on the uuid crate. Provides the new and new_in, as well as the new_with_uuid* group of methods.

Structs

  • A named temporary file that will be cleaned automatically after the last reference to it is dropped.

Enums