13 releases

0.2.9 May 20, 2024
0.2.8 Mar 25, 2024
0.2.7 Jan 8, 2024
0.2.6 Mar 14, 2023
0.1.1 Jul 30, 2021

#85 in Concurrency

Download history 27/week @ 2024-07-22 66/week @ 2024-07-29 70/week @ 2024-08-05 67/week @ 2024-08-12 58/week @ 2024-08-19 73/week @ 2024-08-26 44/week @ 2024-09-02 69/week @ 2024-09-09 134/week @ 2024-09-16 172/week @ 2024-09-23 2241/week @ 2024-09-30 2887/week @ 2024-10-07 4952/week @ 2024-10-14 4575/week @ 2024-10-21 5949/week @ 2024-10-28 6537/week @ 2024-11-04

22,050 downloads per month
Used in 2 crates (via assets_manager)

MIT/Apache

43KB
1K SLoC

Sync File

Crates.io Docs.rs Minimum rustc version

Files that can be read concurrently.

std::fs::File is Sync but reading concurrently from it results in race conditions, because the OS has a single cursor which is advanced and used by several threads.

SyncFile solves this problem by using platform-specific extensions to do positional I/O, so the cursor of the file is not shared.

Example

use std::io::Read;
use sync_file::SyncFile;

/// Reads a file byte by byte.
/// Don't do this in real code !
fn read_all<R: Read>(mut file: R) -> std::io::Result<Vec<u8>> {
    let mut result = Vec::new();
    let mut buf = [0];

    while file.read(&mut buf)? != 0 {
        result.extend(&buf);
    }

    Ok(result)
}

// Open a file
let f = SyncFile::open("hello.txt")?;
let f_clone = f.clone();

// Read it concurrently
let thread = std::thread::spawn(move || read_all(f_clone));
let res1 = read_all(f)?;
let res2 = thread.join().unwrap()?;

// Both clones read the whole content
// This would not work with `std::fs::File`
assert_eq!(res1, b"Hello World!\n");
assert_eq!(res2, b"Hello World!\n");

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

~175KB