Crates.io | hole-punch |
lib.rs | hole-punch |
version | 0.0.3 |
source | src |
created_at | 2020-03-04 03:01:55.295988 |
updated_at | 2020-03-12 01:13:33.617654 |
description | A WIP cross platform library for extracting information about holes in sparse files. |
homepage | |
repository | https://gitlab.com/asuran-rs/hole-punch |
max_upload_size | |
id | 215199 |
size | 57,136 |
A (wip) dead simple, cross platform crate for finding the locations of holes in sparse files.
Currently supports Unix-like platforms that support the SEEK_HOLE
and SEEK_DATA
commands on lseek
, as well as windows.
The operating systems that currently support filesystem-level sparsity information are:
These are currently implemented with a compile time switch, and SparseFile::scan_chunks
will always immediately return with a ScanError::UnsupportedPlatform
error on platforms not on this list.
use std::fs::File;
use hole_punch::*;
let mut file = File::open("a big sparse file");
let segments = file.scan_chunks().expect("Unable to scan chunks");
for segment in segment {
if let SegmentType::Data = segment.segment_type {
let start = segment.start;
let end = segment.end;
let length = end - start;
do_something_with_data(&mut file, start, length);
}
}
Hole-Punch is distributed under your choice of the MIT license, or Apache 2.0.
The following features are on my "to implement" list, in order of importance: