# librsyncr
[![Crates.io](https://img.shields.io/crates/v/librsyncr.svg)](https://crates.io/crates/librsyncr)
[Documentation](https://docs.rs/librsyncr/)
librsyncr is a Rust library to calculate differences between two files without having access to both files on the same system. It is a rewrite of the [librsync C library](https://github.com/librsync/librsync) (without looking at the librsync source code), and the signature and delta files are compatible with that library. The C library is 3562 lines of C (not including comments or vendored Blake2 and MD4 code), but this library is only 753.
## `strong_hash` Feature
The default hash used for looking up blocks from a signature file is not resistant to hash DoS attacks. If you are using this library in a web service to process untrusted signature files, you will likely want to enable the `strong_hash` feature.
## Performance
Testing with Wikiquote dump files (about 38 MB) on a Intel Core-i7-6700K 4.0 GHz processor:
```
# this library
./target/release/examples/rdiff signature ./enwikiquote-20170501-abstract.xml ./enwikiquote-20170501-abstract-sig.xml
85ms (447 MB/s)
# librsync
./rdiff signature ./enwikiquote-20170501-abstract.xml ./enwikiquote-20170501-abstract-sig.xml
77ms (494 MB/s)
# this library
./target/release/examples/rdiff delta ./enwikiquote-20170501-abstract-sig.xml ./enwikiquote-20170701-abstract.xml ./enwikiquote-delta.xml
115ms (330 MB/s)
# librsync
./rdiff delta ./enwikiquote-20170501-abstract-sig.xml ./enwikiquote-20170701-abstract.xml ./enwikiquote-delta.xml
118ms (322 MB/s)
# this library
./target/release/examples/rdiff patch ./enwikiquote-20170501-abstract.xml ./enwikiquote-delta.xml ./enwikiquote-new.xml
67ms (567 MB/s)
# librsync
./rdiff patch ./enwikiquote-20170501-abstract.xml ./enwikiquote-delta.xml ./enwikiquote-new.xml
24ms (1583 MB/s)
```
## File formats
The C librsync library has [documentation on the signature file format](https://github.com/librsync/librsync/blob/131447aa4b8636c8de576e27bc0736f6a5be9bc2/doc/format.md), and the .NET librsync library has [documentation on the delta file format](https://github.com/braddodson/librsync.net/blob/abcda421a74d769b2be986c0b92a41c12a4f96ce/deltaformat.md).
## License
Licensed under the Mozilla Public License Version 2.0.