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

#76 in Concurrency

Download history 109/week @ 2024-09-13 157/week @ 2024-09-20 1385/week @ 2024-09-27 2960/week @ 2024-10-04 4896/week @ 2024-10-11 4150/week @ 2024-10-18 6209/week @ 2024-10-25 5626/week @ 2024-11-01 7123/week @ 2024-11-08 5821/week @ 2024-11-15 6073/week @ 2024-11-22 7114/week @ 2024-11-29 7935/week @ 2024-12-06 6222/week @ 2024-12-13 1015/week @ 2024-12-20 198/week @ 2024-12-27

16,493 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

~160KB