librsync-ffi

Crates.iolibrsync-ffi
lib.rslibrsync-ffi
version0.1.0
sourcesrc
created_at2020-04-07 09:11:15.125607
updated_at2020-04-07 09:11:15.125607
descriptionopinionated bindings to librsync
homepage
repository
max_upload_size
id227213
size17,038
Kevin Velasco (kvnvelasco)

documentation

README

Rust FFI bindings for librsync2

Dynamically linked to librsync2 / librsync-dev

Features

  • Whole File API
    • Generate Signature
    • Load signature into memory
    • Create Delta
    • Apply delta onto file
  • Streaming API
  • Error handling

Usage

File API

Generating a Signature

Signatures are stored in memory even though the whole file api is used. Temporary directories are utilized to hold values until they get initialized in memory.

let path = PathBuf::from("some/file/location");
let (signature, stats) = Signature::new(&path).unwrap;

Generating a delta

Delta files are a Vec<u8> representations of rsync delta files. A delta takes a file signature and some new file to compute against

let path = PathBuf::from("some/file/location");
let (signature, stats) = Signature::new(&path).unwrap;

let some_new_path = PathBuf::from("the/file/changed/maybe");
let (delta, stats) = Delta::new(&mut signature, &some_new_path);

Applying a delta to a file

let path = PathBuf::from("some/file/location");
let (signature, stats) = Signature::new(&path).unwrap;

let some_new_path = PathBuf::from("the/file/changed/maybe");
let (delta, stats) = Delta::new(&mut signature, &some_new_path);

// will output the value of the new file as a Vec<u8> 
let new_file = patch_file(&path, delta);
Commit count: 0

cargo fmt