#error-message #file-io #fs #file-path #system #operations

fs-err

A drop-in replacement for std::fs with more helpful error messages

17 stable releases (3 major)

3.0.0 Oct 23, 2024
2.11.0 Nov 20, 2023
2.9.0 Oct 31, 2022
2.7.0 Feb 19, 2022
0.1.2 Feb 10, 2020

#8 in Filesystem

Download history 279316/week @ 2024-09-27 280574/week @ 2024-10-04 283592/week @ 2024-10-11 290856/week @ 2024-10-18 278930/week @ 2024-10-25 279174/week @ 2024-11-01 296751/week @ 2024-11-08 326036/week @ 2024-11-15 284800/week @ 2024-11-22 309769/week @ 2024-11-29 319745/week @ 2024-12-06 314293/week @ 2024-12-13 194804/week @ 2024-12-20 176206/week @ 2024-12-27 390036/week @ 2025-01-03 390861/week @ 2025-01-10

1,202,048 downloads per month
Used in 993 crates (180 directly)

MIT/Apache

81KB
1.5K SLoC

fs-err

Crates.io GitHub Actions

fs-err is a drop-in replacement for std::fs that provides more helpful messages on errors. Extra information includes which operations was attempted and any involved paths.

Error Messages

Using std::fs, if this code fails:

let file = File::open("does not exist.txt")?;

The error message that Rust gives you isn't very useful:

The system cannot find the file specified. (os error 2)

...but if we use fs-err instead, our error contains more actionable information:

failed to open file `does not exist.txt`: The system cannot find the file specified. (os error 2)

Usage

fs-err's API is the same as std::fs, so migrating code to use it is easy.

// use std::fs;
use fs_err as fs;

let contents = fs::read_to_string("foo.txt")?;

println!("Read foo.txt: {}", contents);

fs-err uses std::io::Error for all errors. This helps fs-err compose well with traits from the standard library like std::io::Read and crates that use them like serde_json:

use fs_err::File;

let file = File::open("my-config.json")?;

// If an I/O error occurs inside serde_json, the error will include a file path
// as well as what operation was being performed.
let decoded: Vec<String> = serde_json::from_reader(file)?;

println!("Program config: {:?}", decoded);

Feature flags

  • expose_original_error: when enabled, the Error::source() method of errors returned by this crate return the original io::Error. To avoid duplication in error messages, this also suppresses printing its message in their Display implementation, so make sure that you are printing the full error chain.

Minimum Supported Rust Version

The oldest rust version this crate is tested on is 1.40.

This crate will generally be conservative with rust version updates. It uses the autocfg crate to allow wrapping new APIs without incrementing the MSRV.

If the tokio feature is enabled, this crate will inherit the MSRV of the selected tokio version.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0–5.5MB
~19K SLoC