forked from fitzgen/operational-transformation
-
Notifications
You must be signed in to change notification settings - Fork 0
/
apply.js
42 lines (38 loc) · 1.46 KB
/
apply.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// This module defines a function which applies a set of operations which span a
// document, to that document. The resulting document is returned.
/*jslint onevar: true, undef: true, eqeqeq: true, bitwise: true,
newcap: true, immed: true, nomen: false, white: false, plusplus: false,
laxbreak: true */
/*global define */
define(["./operations"], function (operations) {
return function (op, doc) {
var i,
len,
index = 0,
newDoc = "";
for ( i = 0, len = op.length; i < len; i += 1 ) {
switch ( operations.type(op[i]) ) {
case "retain":
newDoc += doc.slice(0, operations.val(op[i]));
doc = doc.slice(operations.val(op[i]));
break;
case "insert":
newDoc += operations.val(op[i]);
break;
case "delete":
if ( doc.indexOf(operations.val(op[i])) !== 0 ) {
throw new TypeError("Expected '" + operations.val(op[i])
+ "' to delete, found '" + doc.slice(0, 10)
+ "'");
} else {
doc = doc.slice(operations.val(op[i]).length);
}
break;
default:
throw new TypeError("Unknown operation: "
+ operations.type(op[i]));
}
}
return newDoc;
};
});