|Evgeny Khramtsov 18a367ef6d Update Erlang/OTP Travis CI platforms||2 months ago|
|c_src||3 years ago|
|doc||3 years ago|
|src||2 years ago|
|test||3 years ago|
|.travis.yml||2 months ago|
|LICENSE||3 years ago|
|Makefile||3 years ago|
|README.md||2 years ago|
|configure||3 years ago|
|configure.ac||3 years ago|
|rebar.config.script||3 years ago|
|vars.config.in||3 years ago|
erlang-rsync is an Erlang wrapper of librsync
library. It provides basic functions for direct file manipulations
delta/2, etc) as well as low-level functions
for fine-grained control (
The low-level interface is somewhat similar to the hashing functions
$ git clone git://github.com/zinid/erlang-rsync.git $ cd erlang-rsync $ ./configure $ make
The whole API documentation is located in the
doc directory and can be built
$ make doc
Let's say we have two files:
remote_file, and we want
to have the content of
We first generate the signature of
local_file. The signature is written in
> rsync:sig("local_file", "sig_file"). ok.
We then generate the delta from
The delta is written in
> rsync:delta("sig_file", "remote_file", "delta_file"). ok.
local_file we reconstruct
result is written in
> rsync:patch("local_file", "delta_file", "new_local_file"). ok.
new_local_file is "equal" to
> file:read_file("new_local_file") == file:read_file("remote_file"). true.
patch_init/1 functions to work the whole content of
the original file should be read into the memory.
This is due to a limitation of librsync API and Erlang's NIF API.
So don't use these functions for extremely large files.