Symmetry
Create diffs between two values:
a = { x: 3, y: 5, z: 1 };
b = { x: 3, y: 8, z: 1 };
patch = createPatch(a, b);
// => { t: 'o', s: { y: 8 } }
a = ["one", "two", "three"];
b = ["one", "two", "two and a half"];
patch = createPatch(a, b);
// => { t: 'a', s: [ [2, 1, 'two and a half'] ] }
And apply them somewhere else:
obj = { x: 3, y: 5, z: 1 };
patch = { t: "o", s: { y: 8 } };
after = applyPatch(obj, patch);
// => { x: 3, y: 8, z: 1 }
Will diff anything with a toJSON()
method.
people = new Backbone.Collection([
{ id: 1, name: "John", age: 30 },
{ id: 2, name: "Dave", age: 34 },
]);
before = people.toJSON();
people.add({ id: 3, name: "Mark", age: 27 });
people.get(2).set("age", 35);
patch = createPatch(before, people);
// => {
// t: "a",
// p: { 1: { t: "o", s: { age: 35 } } },
// s: [[2, 0, { id: 3, name: "Mark", age: 27 }]]
// }
Installing
Install using NPM:
npm install symmetry
Patch format
Patches are one of two types of object, identified by the t
field.
Object patches have "t": "o"
, and additional fields:
-
r
for 'remove', with a list of target properties to remove. -
s
for 'set', with an object mapping target properties to values. -
p
for 'patch', with an object mapping target properties to subpatches.
Array patches have "t": "a"
, and additional fields:
-
p
for 'patch', with an object mapping target indices to subpatches. -
s
for 'splice', with a list of argument lists for the arraysplice
method to apply in order. Must be applied afterp
.
In addition, createPatch
may return the special strings:
-
"reset"
if no patch is possible between the two values, or they differ enough that a patch isn't useful. -
"none"
if the two values were identical and no patching is necessary.
Hacking the code
git clone https://github.com/Two-Screen/symmetry.git
cd symmetry
npm install
npm test