-
Notifications
You must be signed in to change notification settings - Fork 7
JSON diffing and patching library
License
mikolalysenko/patcher.js
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
_ _ _
| | | | (_)
_ __ __ _| |_ ___| |__ ___ _ __ _ ___
| '_ \ / _` | __|/ __| '_ \ / _ \ '__| / __|
| |_) | (_| | |_| (__| | | | __/ | _| \__ \
| .__/ \__,_|\__|\___|_| |_|\___|_|(_) |___/
| | _/ |
|_| |__/
=================================================
A JSON patching and diffing library
(c) 2011 Mikola Lysenko
=================================================
1. About
patcher.js is a simple javascript library for diffing and
patching JSON documents. This can be useful, for example,
in a networked environment where retransmitting large JSON
documents is too expensive.
2. Example:
>
> //Start with two distinct objects on the server
> // prev represents a copy of the state of the object on the client
> // next represents a copy of the state of the object on the server
> //
> //1. Compute a patch
> patch = patcher.computePatch(prev, next);
>
> //2. Send patch over the network
>
> //3. Apply the patch on the client
> patcher.applyPatch(prev, patch);
>
> //Final invariant:
> // prev represents an equivalent object to JSON.parse(JSON.stringify(next))
>
3. API
There are two functions in patcher.js:
function computePatch(prev, next, update_in_place);
The argument prev is the object which the patch targets.
* If update_in_place is set to true, then the function
will simultaneously update both prev and next at the same
time.
* If prev and next are equal, then the method returns null
* Constructing this patch requires time linear on the
size of the two documents.
* Patches are computed at the level of the objects and
arrays. String modifications are simply retransmitted
function applyPatch(obj, patch)
This function applies a patch to the JSON document obj
4. Future
* More test cases!
* Use data types cleverly
* Binary serialization
About
JSON diffing and patching library
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published