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

#160 in Concurrency

Download history 67/week @ 2024-05-10 388/week @ 2024-05-17 389/week @ 2024-05-24 76/week @ 2024-05-31 91/week @ 2024-06-07 44/week @ 2024-06-14 37/week @ 2024-06-21 49/week @ 2024-06-28 83/week @ 2024-07-05 47/week @ 2024-07-12 39/week @ 2024-07-19 49/week @ 2024-07-26 67/week @ 2024-08-02 72/week @ 2024-08-09 60/week @ 2024-08-16 41/week @ 2024-08-23

253 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