#file-io #io-error #writers #traits #resources #drop #dropping

io-close

An extension trait for safely dropping I/O writers such as File and BufWriter

22 releases

0.3.7 Apr 3, 2021
0.3.6 Apr 2, 2021
0.3.3 Jan 1, 2021
0.3.1 Dec 2, 2020
0.1.9 Nov 22, 2020

#876 in Rust patterns

Download history 31991/week @ 2024-07-20 33578/week @ 2024-07-27 31357/week @ 2024-08-03 30655/week @ 2024-08-10 30998/week @ 2024-08-17 30453/week @ 2024-08-24 29620/week @ 2024-08-31 29901/week @ 2024-09-07 27988/week @ 2024-09-14 29141/week @ 2024-09-21 27648/week @ 2024-09-28 28573/week @ 2024-10-05 30517/week @ 2024-10-12 28856/week @ 2024-10-19 28168/week @ 2024-10-26 24480/week @ 2024-11-02

116,675 downloads per month
Used in 55 crates (4 directly)

MIT/Apache

12KB
154 lines

Please see https://docs.rs/io-close.


lib.rs:

An extension trait for safely dropping I/O writers such as File and BufWriter. Specifically, it is for I/O writers which may contain a resource handle (such as a raw file descriptor), and where the automatic process of closing this handle during drop may generate an unseen I/O error. Using this trait (called Close) these errors can be seen and dealt with.

In the case of Linux the man page for close(2) has the following to say:

Not checking the return value of close() is a common but nevertheless serious programming error. It is quite possible that errors on a previous write(2) operation are first reported at the final close(). Not checking the return value when closing the file may lead to silent loss of data. This can especially be observed with NFS and with disk quota.

Implementations of Close are provided for most standard library I/O writers and (optionally) for a selection of I/O writers defined in external crates.

BufWriter example

use std::io::{BufWriter, Result, Write};
use io_close::Close;

fn main() -> Result<()> {
    let data = b"hello world";
    let mut buffer = BufWriter::new(tempfile::tempfile()?);
    buffer.write_all(data)?;
    buffer.close()?; // safely drop buffer and its contained File
    Ok(())
}

Optional implementations

Optional implementations of Close are provided for the following I/O writers defined in external crates, enabled through cargo features:

Dependencies

~225KB