Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dezyh/patchupcs
A library to create patches between two binary files to reduce file sizes when updating.
https://github.com/dezyh/patchupcs
binary diff files mit myers patch suffx tree ukkonens
Last synced: 26 days ago
JSON representation
A library to create patches between two binary files to reduce file sizes when updating.
- Host: GitHub
- URL: https://github.com/dezyh/patchupcs
- Owner: dezyh
- License: mit
- Created: 2019-01-08T09:54:11.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2020-07-28T09:34:05.000Z (over 4 years ago)
- Last Synced: 2024-10-28T13:30:57.999Z (2 months ago)
- Topics: binary, diff, files, mit, myers, patch, suffx, tree, ukkonens
- Language: C#
- Homepage:
- Size: 37.1 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# PatchUp [![Build Status](https://travis-ci.com/Dezyh/PatchUpCS.svg?branch=master)](https://travis-ci.com/Dezyh/PatchUpCS)
A library to create patches between two binary files, aimed at reducing file sizes when updating large but similar files.
To create a patch between two binary files, [Myers algorithm](http://www.xmailserver.org/diff2.pdf) is implemented to compute the differences in O(nd) time and O(n) space where n is the shorter of the two files and d is the number of differences between the two files.
The next part of this project is to improve the runtime complexity at the expense of space required. This is through implementing Ukkonens algorithm to construct suffix trees in O(n) time to efficiently find maximal unique matches between the two files and then compute the diff between these regions. This is useful for binary files where the same data has been moved to another location.
# Usage
Importing the library and load the files
```
using Patchup;
var source = File.ReadAllBytes("file1.txt");
var target = File.ReadAllBytes("file2.txt");
```
Create a patch
```
var patch = new Patch(source, target);
```
Save the patch to file
```
patch.Save("patch.pup");
```
Load a patch from file
```
patch.Load("patch.pup");
```
Apply a patch
```
var patched = patch.Apply(source);
```
For more examples, see the [examples file](/Source/Example/Example.cs).