loro-crdt 1.2.6 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +126 -0
- package/base64/index.js +213 -58
- package/base64/loro_wasm.d.ts +159 -46
- package/base64/loro_wasm_bg-faa2e3e4.js +64 -0
- package/bundler/loro_wasm.d.ts +159 -46
- package/bundler/loro_wasm_bg.js +208 -53
- package/bundler/loro_wasm_bg.wasm +0 -0
- package/bundler/loro_wasm_bg.wasm.d.ts +6 -1
- package/nodejs/loro_wasm.d.ts +159 -46
- package/nodejs/loro_wasm.js +208 -53
- package/nodejs/loro_wasm_bg.wasm +0 -0
- package/nodejs/loro_wasm_bg.wasm.d.ts +6 -1
- package/package.json +1 -1
- package/web/loro_wasm.d.ts +165 -47
- package/web/loro_wasm.js +206 -53
- package/web/loro_wasm_bg.wasm +0 -0
- package/web/loro_wasm_bg.wasm.d.ts +6 -1
- package/base64/loro_wasm_bg-982aff63.js +0 -64
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,131 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## 1.3.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- ddafb7e: feat: diff, applyDiff, and revertTo #610
|
|
8
|
+
|
|
9
|
+
Add new version-control-related primitives:
|
|
10
|
+
|
|
11
|
+
- **`diff(from, to)`**: calculate the difference between two versions. The returned results have similar structures to the differences in events.
|
|
12
|
+
- **`revertTo(targetVersion)`**: revert the document back to the target version. The difference between this and `checkout(targetVersion)` is this method will generate a series of new operations, which will transform the current doc into the same as the target version.
|
|
13
|
+
- **`applyDiff(diff)`**: you can use it to apply the differences generated from `diff(from, to)`.
|
|
14
|
+
|
|
15
|
+
You can use these primitives to implement version-control functions like `squash` and `revert`.
|
|
16
|
+
|
|
17
|
+
# Examples
|
|
18
|
+
|
|
19
|
+
`revertTo`
|
|
20
|
+
|
|
21
|
+
```ts
|
|
22
|
+
const doc = new LoroDoc();
|
|
23
|
+
doc.setPeerId("1");
|
|
24
|
+
doc.getText("text").update("Hello");
|
|
25
|
+
doc.commit();
|
|
26
|
+
doc.revertTo([{ peer: "1", counter: 1 }]);
|
|
27
|
+
expect(doc.getText("text").toString()).toBe("He");
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
`diff`
|
|
31
|
+
|
|
32
|
+
```ts
|
|
33
|
+
const doc = new LoroDoc();
|
|
34
|
+
doc.setPeerId("1");
|
|
35
|
+
// Text edits with formatting
|
|
36
|
+
const text = doc.getText("text");
|
|
37
|
+
text.update("Hello");
|
|
38
|
+
text.mark({ start: 0, end: 5 }, "bold", true);
|
|
39
|
+
doc.commit();
|
|
40
|
+
|
|
41
|
+
// Map edits
|
|
42
|
+
const map = doc.getMap("map");
|
|
43
|
+
map.set("key1", "value1");
|
|
44
|
+
map.set("key2", 42);
|
|
45
|
+
doc.commit();
|
|
46
|
+
|
|
47
|
+
// List edits
|
|
48
|
+
const list = doc.getList("list");
|
|
49
|
+
list.insert(0, "item1");
|
|
50
|
+
list.insert(1, "item2");
|
|
51
|
+
list.delete(1, 1);
|
|
52
|
+
doc.commit();
|
|
53
|
+
|
|
54
|
+
// Tree edits
|
|
55
|
+
const tree = doc.getTree("tree");
|
|
56
|
+
const a = tree.createNode();
|
|
57
|
+
a.createNode();
|
|
58
|
+
doc.commit();
|
|
59
|
+
|
|
60
|
+
const diff = doc.diff([], doc.frontiers());
|
|
61
|
+
expect(diff).toMatchSnapshot();
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
```js
|
|
65
|
+
{
|
|
66
|
+
"cid:root-list:List": {
|
|
67
|
+
"diff": [
|
|
68
|
+
{
|
|
69
|
+
"insert": [
|
|
70
|
+
"item1",
|
|
71
|
+
],
|
|
72
|
+
},
|
|
73
|
+
],
|
|
74
|
+
"type": "list",
|
|
75
|
+
},
|
|
76
|
+
"cid:root-map:Map": {
|
|
77
|
+
"type": "map",
|
|
78
|
+
"updated": {
|
|
79
|
+
"key1": "value1",
|
|
80
|
+
"key2": 42,
|
|
81
|
+
},
|
|
82
|
+
},
|
|
83
|
+
"cid:root-text:Text": {
|
|
84
|
+
"diff": [
|
|
85
|
+
{
|
|
86
|
+
"attributes": {
|
|
87
|
+
"bold": true,
|
|
88
|
+
},
|
|
89
|
+
"insert": "Hello",
|
|
90
|
+
},
|
|
91
|
+
],
|
|
92
|
+
"type": "text",
|
|
93
|
+
},
|
|
94
|
+
"cid:root-tree:Tree": {
|
|
95
|
+
"diff": [
|
|
96
|
+
{
|
|
97
|
+
"action": "create",
|
|
98
|
+
"fractionalIndex": "80",
|
|
99
|
+
"index": 0,
|
|
100
|
+
"parent": undefined,
|
|
101
|
+
"target": "12@1",
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
"action": "create",
|
|
105
|
+
"fractionalIndex": "80",
|
|
106
|
+
"index": 0,
|
|
107
|
+
"parent": "12@1",
|
|
108
|
+
"target": "13@1",
|
|
109
|
+
},
|
|
110
|
+
],
|
|
111
|
+
"type": "tree",
|
|
112
|
+
},
|
|
113
|
+
}
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
- ac51ceb: feat: add exportJsonInIdSpan and make peer compression optional
|
|
117
|
+
- 8039e44: feat: find id spans between #607
|
|
118
|
+
|
|
119
|
+
### Patch Changes
|
|
120
|
+
|
|
121
|
+
- 9c1005d: fix: should not merge remote changes due to small interval
|
|
122
|
+
|
|
123
|
+
## 1.2.7
|
|
124
|
+
|
|
125
|
+
### Patch Changes
|
|
126
|
+
|
|
127
|
+
- da24910: fix: should commit before travel_change_ancestors #599
|
|
128
|
+
|
|
3
129
|
## 1.2.6
|
|
4
130
|
|
|
5
131
|
### Patch Changes
|
package/base64/index.js
CHANGED
|
@@ -237,11 +237,11 @@ function makeMutClosure(arg0, arg1, dtor, f) {
|
|
|
237
237
|
CLOSURE_DTORS.register(real, state, state);
|
|
238
238
|
return real;
|
|
239
239
|
}
|
|
240
|
-
function
|
|
240
|
+
function __wbg_adapter_60(arg0, arg1, arg2) {
|
|
241
241
|
wasm.__wbindgen_export_3(arg0, arg1, addHeapObject(arg2));
|
|
242
242
|
}
|
|
243
243
|
|
|
244
|
-
function
|
|
244
|
+
function __wbg_adapter_63(arg0, arg1) {
|
|
245
245
|
wasm.__wbindgen_export_4(arg0, arg1);
|
|
246
246
|
}
|
|
247
247
|
|
|
@@ -971,9 +971,12 @@ class LoroDoc {
|
|
|
971
971
|
wasm.lorodoc_setRecordTimestamp(this.__wbg_ptr, auto_record);
|
|
972
972
|
}
|
|
973
973
|
/**
|
|
974
|
-
* If two continuous local changes are within the interval, they will be merged into one change.
|
|
974
|
+
* If two continuous local changes are within (<=) the interval(**in seconds**), they will be merged into one change.
|
|
975
975
|
*
|
|
976
|
-
* The default value is
|
|
976
|
+
* The default value is 1_000 seconds.
|
|
977
|
+
*
|
|
978
|
+
* By default, we record timestamps in seconds for each change. So if the merge interval is 1, and changes A and B
|
|
979
|
+
* have timestamps of 3 and 4 respectively, then they will be merged into one change
|
|
977
980
|
* @param {number} interval
|
|
978
981
|
*/
|
|
979
982
|
setChangeMergeInterval(interval) {
|
|
@@ -1237,6 +1240,72 @@ class LoroDoc {
|
|
|
1237
1240
|
}
|
|
1238
1241
|
}
|
|
1239
1242
|
/**
|
|
1243
|
+
* Find the op id spans that between the `from` version and the `to` version.
|
|
1244
|
+
*
|
|
1245
|
+
* You can combine it with `exportJsonInIdSpan` to get the changes between two versions.
|
|
1246
|
+
*
|
|
1247
|
+
* You can use it to travel all the changes from `from` to `to`. `from` and `to` are frontiers,
|
|
1248
|
+
* and they can be concurrent to each other. You can use it to find all the changes related to an event:
|
|
1249
|
+
*
|
|
1250
|
+
* @example
|
|
1251
|
+
* ```ts
|
|
1252
|
+
* import { LoroDoc } from "loro-crdt";
|
|
1253
|
+
*
|
|
1254
|
+
* const docA = new LoroDoc();
|
|
1255
|
+
* docA.setPeerId("1");
|
|
1256
|
+
* const docB = new LoroDoc();
|
|
1257
|
+
*
|
|
1258
|
+
* docA.getText("text").update("Hello");
|
|
1259
|
+
* docA.commit();
|
|
1260
|
+
* const snapshot = docA.export({ mode: "snapshot" });
|
|
1261
|
+
* let done = false;
|
|
1262
|
+
* docB.subscribe(e => {
|
|
1263
|
+
* const spans = docB.findIdSpansBetween(e.from, e.to);
|
|
1264
|
+
* const changes = docB.exportJsonInIdSpan(spans.forward[0]);
|
|
1265
|
+
* console.log(changes);
|
|
1266
|
+
* // [{
|
|
1267
|
+
* // id: "0@1",
|
|
1268
|
+
* // timestamp: expect.any(Number),
|
|
1269
|
+
* // deps: [],
|
|
1270
|
+
* // lamport: 0,
|
|
1271
|
+
* // msg: undefined,
|
|
1272
|
+
* // ops: [{
|
|
1273
|
+
* // container: "cid:root-text:Text",
|
|
1274
|
+
* // counter: 0,
|
|
1275
|
+
* // content: {
|
|
1276
|
+
* // type: "insert",
|
|
1277
|
+
* // pos: 0,
|
|
1278
|
+
* // text: "Hello"
|
|
1279
|
+
* // }
|
|
1280
|
+
* // }]
|
|
1281
|
+
* // }]
|
|
1282
|
+
* });
|
|
1283
|
+
* docB.import(snapshot);
|
|
1284
|
+
* ```
|
|
1285
|
+
* @param {({ peer: PeerID, counter: number })[]} from
|
|
1286
|
+
* @param {({ peer: PeerID, counter: number })[]} to
|
|
1287
|
+
* @returns {VersionVectorDiff}
|
|
1288
|
+
*/
|
|
1289
|
+
findIdSpansBetween(from, to) {
|
|
1290
|
+
try {
|
|
1291
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
1292
|
+
const ptr0 = passArrayJsValueToWasm0(from, wasm.__wbindgen_export_0);
|
|
1293
|
+
const len0 = WASM_VECTOR_LEN;
|
|
1294
|
+
const ptr1 = passArrayJsValueToWasm0(to, wasm.__wbindgen_export_0);
|
|
1295
|
+
const len1 = WASM_VECTOR_LEN;
|
|
1296
|
+
wasm.lorodoc_findIdSpansBetween(retptr, this.__wbg_ptr, ptr0, len0, ptr1, len1);
|
|
1297
|
+
var r0 = getInt32Memory0()[retptr / 4 + 0];
|
|
1298
|
+
var r1 = getInt32Memory0()[retptr / 4 + 1];
|
|
1299
|
+
var r2 = getInt32Memory0()[retptr / 4 + 2];
|
|
1300
|
+
if (r2) {
|
|
1301
|
+
throw takeObject(r1);
|
|
1302
|
+
}
|
|
1303
|
+
return takeObject(r0);
|
|
1304
|
+
} finally {
|
|
1305
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
1306
|
+
}
|
|
1307
|
+
}
|
|
1308
|
+
/**
|
|
1240
1309
|
* Checkout the `DocState` to a specific version.
|
|
1241
1310
|
*
|
|
1242
1311
|
* > The document becomes detached during a `checkout` operation.
|
|
@@ -1315,12 +1384,14 @@ class LoroDoc {
|
|
|
1315
1384
|
}
|
|
1316
1385
|
}
|
|
1317
1386
|
/**
|
|
1318
|
-
* Commit the cumulative auto
|
|
1387
|
+
* Commit the cumulative auto-committed transaction.
|
|
1319
1388
|
*
|
|
1320
1389
|
* You can specify the `origin`, `timestamp`, and `message` of the commit.
|
|
1321
1390
|
*
|
|
1322
1391
|
* - The `origin` is used to mark the event
|
|
1323
1392
|
* - The `message` works like a git commit message, which will be recorded and synced to peers
|
|
1393
|
+
* - The `timestamp` is the number of seconds that have elapsed since 00:00:00 UTC on January 1, 1970.
|
|
1394
|
+
* It defaults to `Date.now() / 1000` when timestamp recording is enabled
|
|
1324
1395
|
*
|
|
1325
1396
|
* The events will be emitted after a transaction is committed. A transaction is committed when:
|
|
1326
1397
|
*
|
|
@@ -1897,12 +1968,32 @@ class LoroDoc {
|
|
|
1897
1968
|
* Export updates in the given range in JSON format.
|
|
1898
1969
|
* @param {any} start_vv
|
|
1899
1970
|
* @param {any} end_vv
|
|
1971
|
+
* @param {boolean | undefined} [with_peer_compression]
|
|
1900
1972
|
* @returns {JsonSchema}
|
|
1901
1973
|
*/
|
|
1902
|
-
exportJsonUpdates(start_vv, end_vv) {
|
|
1974
|
+
exportJsonUpdates(start_vv, end_vv, with_peer_compression) {
|
|
1975
|
+
try {
|
|
1976
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
1977
|
+
wasm.lorodoc_exportJsonUpdates(retptr, this.__wbg_ptr, addHeapObject(start_vv), addHeapObject(end_vv), isLikeNone(with_peer_compression) ? 0xFFFFFF : with_peer_compression ? 1 : 0);
|
|
1978
|
+
var r0 = getInt32Memory0()[retptr / 4 + 0];
|
|
1979
|
+
var r1 = getInt32Memory0()[retptr / 4 + 1];
|
|
1980
|
+
var r2 = getInt32Memory0()[retptr / 4 + 2];
|
|
1981
|
+
if (r2) {
|
|
1982
|
+
throw takeObject(r1);
|
|
1983
|
+
}
|
|
1984
|
+
return takeObject(r0);
|
|
1985
|
+
} finally {
|
|
1986
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
1987
|
+
}
|
|
1988
|
+
}
|
|
1989
|
+
/**
|
|
1990
|
+
* @param {{ peer: PeerID, counter: number, length: number }} idSpan
|
|
1991
|
+
* @returns {any}
|
|
1992
|
+
*/
|
|
1993
|
+
exportJsonInIdSpan(idSpan) {
|
|
1903
1994
|
try {
|
|
1904
1995
|
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
1905
|
-
wasm.
|
|
1996
|
+
wasm.lorodoc_exportJsonInIdSpan(retptr, this.__wbg_ptr, addHeapObject(idSpan));
|
|
1906
1997
|
var r0 = getInt32Memory0()[retptr / 4 + 0];
|
|
1907
1998
|
var r1 = getInt32Memory0()[retptr / 4 + 1];
|
|
1908
1999
|
var r2 = getInt32Memory0()[retptr / 4 + 2];
|
|
@@ -2101,7 +2192,7 @@ class LoroDoc {
|
|
|
2101
2192
|
*
|
|
2102
2193
|
* @example
|
|
2103
2194
|
* ```ts
|
|
2104
|
-
* import { LoroDoc, LoroText } from "loro-crdt";
|
|
2195
|
+
* import { LoroDoc, LoroText, LoroMap } from "loro-crdt";
|
|
2105
2196
|
*
|
|
2106
2197
|
* const doc = new LoroDoc();
|
|
2107
2198
|
* const list = doc.getList("list");
|
|
@@ -2465,6 +2556,84 @@ class LoroDoc {
|
|
|
2465
2556
|
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
2466
2557
|
}
|
|
2467
2558
|
}
|
|
2559
|
+
/**
|
|
2560
|
+
* Revert the document to the given frontiers.
|
|
2561
|
+
*
|
|
2562
|
+
* The doc will not become detached when using this method. Instead, it will generate a series
|
|
2563
|
+
* of operations to revert the document to the given version.
|
|
2564
|
+
*
|
|
2565
|
+
* @example
|
|
2566
|
+
* ```ts
|
|
2567
|
+
* const doc = new LoroDoc();
|
|
2568
|
+
* doc.setPeerId("1");
|
|
2569
|
+
* const text = doc.getText("text");
|
|
2570
|
+
* text.insert(0, "Hello");
|
|
2571
|
+
* doc.commit();
|
|
2572
|
+
* doc.revertTo([{ peer: "1", counter: 1 }]);
|
|
2573
|
+
* expect(doc.getText("text").toString()).toBe("He");
|
|
2574
|
+
* ```
|
|
2575
|
+
* @param {({ peer: PeerID, counter: number })[]} frontiers
|
|
2576
|
+
*/
|
|
2577
|
+
revertTo(frontiers) {
|
|
2578
|
+
try {
|
|
2579
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
2580
|
+
const ptr0 = passArrayJsValueToWasm0(frontiers, wasm.__wbindgen_export_0);
|
|
2581
|
+
const len0 = WASM_VECTOR_LEN;
|
|
2582
|
+
wasm.lorodoc_revertTo(retptr, this.__wbg_ptr, ptr0, len0);
|
|
2583
|
+
var r0 = getInt32Memory0()[retptr / 4 + 0];
|
|
2584
|
+
var r1 = getInt32Memory0()[retptr / 4 + 1];
|
|
2585
|
+
if (r1) {
|
|
2586
|
+
throw takeObject(r0);
|
|
2587
|
+
}
|
|
2588
|
+
} finally {
|
|
2589
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
2590
|
+
}
|
|
2591
|
+
}
|
|
2592
|
+
/**
|
|
2593
|
+
* Apply a diff batch to the document
|
|
2594
|
+
* @param {Record<ContainerID, Diff>} diff
|
|
2595
|
+
*/
|
|
2596
|
+
applyDiff(diff) {
|
|
2597
|
+
try {
|
|
2598
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
2599
|
+
wasm.lorodoc_applyDiff(retptr, this.__wbg_ptr, addHeapObject(diff));
|
|
2600
|
+
var r0 = getInt32Memory0()[retptr / 4 + 0];
|
|
2601
|
+
var r1 = getInt32Memory0()[retptr / 4 + 1];
|
|
2602
|
+
if (r1) {
|
|
2603
|
+
throw takeObject(r0);
|
|
2604
|
+
}
|
|
2605
|
+
} finally {
|
|
2606
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
2607
|
+
}
|
|
2608
|
+
}
|
|
2609
|
+
/**
|
|
2610
|
+
* Calculate the differences between two frontiers
|
|
2611
|
+
*
|
|
2612
|
+
* The entries in the returned object are sorted by causal order: the creation of a child container will be
|
|
2613
|
+
* presented before its use.
|
|
2614
|
+
* @param {({ peer: PeerID, counter: number })[]} from
|
|
2615
|
+
* @param {({ peer: PeerID, counter: number })[]} to
|
|
2616
|
+
* @returns {Record<ContainerID, Diff>}
|
|
2617
|
+
*/
|
|
2618
|
+
diff(from, to) {
|
|
2619
|
+
try {
|
|
2620
|
+
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
|
|
2621
|
+
const ptr0 = passArrayJsValueToWasm0(from, wasm.__wbindgen_export_0);
|
|
2622
|
+
const len0 = WASM_VECTOR_LEN;
|
|
2623
|
+
const ptr1 = passArrayJsValueToWasm0(to, wasm.__wbindgen_export_0);
|
|
2624
|
+
const len1 = WASM_VECTOR_LEN;
|
|
2625
|
+
wasm.lorodoc_diff(retptr, this.__wbg_ptr, ptr0, len0, ptr1, len1);
|
|
2626
|
+
var r0 = getInt32Memory0()[retptr / 4 + 0];
|
|
2627
|
+
var r1 = getInt32Memory0()[retptr / 4 + 1];
|
|
2628
|
+
var r2 = getInt32Memory0()[retptr / 4 + 2];
|
|
2629
|
+
if (r2) {
|
|
2630
|
+
throw takeObject(r1);
|
|
2631
|
+
}
|
|
2632
|
+
return takeObject(r0);
|
|
2633
|
+
} finally {
|
|
2634
|
+
wasm.__wbindgen_add_to_stack_pointer(16);
|
|
2635
|
+
}
|
|
2636
|
+
}
|
|
2468
2637
|
}
|
|
2469
2638
|
|
|
2470
2639
|
const LoroListFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
@@ -3362,7 +3531,7 @@ class LoroMap {
|
|
|
3362
3531
|
*
|
|
3363
3532
|
* @example
|
|
3364
3533
|
* ```ts
|
|
3365
|
-
* import { LoroDoc } from "loro-crdt";
|
|
3534
|
+
* import { LoroDoc, LoroText } from "loro-crdt";
|
|
3366
3535
|
*
|
|
3367
3536
|
* const doc = new LoroDoc();
|
|
3368
3537
|
* doc.setPeerId("1");
|
|
@@ -5176,26 +5345,6 @@ class LoroTreeNode {
|
|
|
5176
5345
|
}
|
|
5177
5346
|
}
|
|
5178
5347
|
/**
|
|
5179
|
-
* Move this tree node to be a child of the parent.
|
|
5180
|
-
* If the parent is undefined, this node will be a root node.
|
|
5181
|
-
*
|
|
5182
|
-
* If the index is not provided, the node will be appended to the end.
|
|
5183
|
-
*
|
|
5184
|
-
* It's not allowed that the target is an ancestor of the parent.
|
|
5185
|
-
*
|
|
5186
|
-
* @example
|
|
5187
|
-
* ```ts
|
|
5188
|
-
* const doc = new LoroDoc();
|
|
5189
|
-
* const tree = doc.getTree("tree");
|
|
5190
|
-
* const root = tree.createNode();
|
|
5191
|
-
* const node = root.createNode();
|
|
5192
|
-
* const node2 = node.createNode();
|
|
5193
|
-
* node2.move(undefined, 0);
|
|
5194
|
-
* // node2 root
|
|
5195
|
-
* // |
|
|
5196
|
-
* // node
|
|
5197
|
-
*
|
|
5198
|
-
* ```
|
|
5199
5348
|
* @param {LoroTreeNode | undefined} parent
|
|
5200
5349
|
* @param {number | undefined} [index]
|
|
5201
5350
|
*/
|
|
@@ -5358,11 +5507,6 @@ class LoroTreeNode {
|
|
|
5358
5507
|
}
|
|
5359
5508
|
}
|
|
5360
5509
|
/**
|
|
5361
|
-
* Get the parent node of this node.
|
|
5362
|
-
*
|
|
5363
|
-
* - The parent of the root node is `undefined`.
|
|
5364
|
-
* - The object returned is a new js object each time because it need to cross
|
|
5365
|
-
* the WASM boundary.
|
|
5366
5510
|
* @returns {LoroTreeNode | undefined}
|
|
5367
5511
|
*/
|
|
5368
5512
|
parent() {
|
|
@@ -5560,6 +5704,7 @@ class UndoManager {
|
|
|
5560
5704
|
}
|
|
5561
5705
|
/**
|
|
5562
5706
|
* Set the merge interval (in ms).
|
|
5707
|
+
*
|
|
5563
5708
|
* If the interval is set to 0, the undo steps will not be merged.
|
|
5564
5709
|
* Otherwise, the undo steps will be merged if the interval between the two steps is less than the given interval.
|
|
5565
5710
|
* @param {number} interval
|
|
@@ -5832,36 +5977,36 @@ class VersionVector {
|
|
|
5832
5977
|
function __wbindgen_object_drop_ref(arg0) {
|
|
5833
5978
|
takeObject(arg0);
|
|
5834
5979
|
}
|
|
5835
|
-
function
|
|
5836
|
-
const ret =
|
|
5980
|
+
function __wbg_lorolist_new(arg0) {
|
|
5981
|
+
const ret = LoroList.__wrap(arg0);
|
|
5837
5982
|
return addHeapObject(ret);
|
|
5838
5983
|
}
|
|
5839
|
-
function
|
|
5840
|
-
const ret =
|
|
5984
|
+
function __wbg_lorocounter_new(arg0) {
|
|
5985
|
+
const ret = LoroCounter.__wrap(arg0);
|
|
5841
5986
|
return addHeapObject(ret);
|
|
5842
5987
|
}
|
|
5843
|
-
function
|
|
5844
|
-
const ret =
|
|
5988
|
+
function __wbg_loromap_new(arg0) {
|
|
5989
|
+
const ret = LoroMap.__wrap(arg0);
|
|
5845
5990
|
return addHeapObject(ret);
|
|
5846
5991
|
}
|
|
5847
|
-
function
|
|
5848
|
-
const ret =
|
|
5992
|
+
function __wbg_lorotreenode_new(arg0) {
|
|
5993
|
+
const ret = LoroTreeNode.__wrap(arg0);
|
|
5849
5994
|
return addHeapObject(ret);
|
|
5850
5995
|
}
|
|
5851
|
-
function
|
|
5852
|
-
const ret =
|
|
5996
|
+
function __wbg_lorotree_new(arg0) {
|
|
5997
|
+
const ret = LoroTree.__wrap(arg0);
|
|
5853
5998
|
return addHeapObject(ret);
|
|
5854
5999
|
}
|
|
5855
6000
|
function __wbg_loromovablelist_new(arg0) {
|
|
5856
6001
|
const ret = LoroMovableList.__wrap(arg0);
|
|
5857
6002
|
return addHeapObject(ret);
|
|
5858
6003
|
}
|
|
5859
|
-
function
|
|
5860
|
-
const ret =
|
|
6004
|
+
function __wbg_cursor_new(arg0) {
|
|
6005
|
+
const ret = Cursor.__wrap(arg0);
|
|
5861
6006
|
return addHeapObject(ret);
|
|
5862
6007
|
}
|
|
5863
|
-
function
|
|
5864
|
-
const ret =
|
|
6008
|
+
function __wbg_lorotext_new(arg0) {
|
|
6009
|
+
const ret = LoroText.__wrap(arg0);
|
|
5865
6010
|
return addHeapObject(ret);
|
|
5866
6011
|
}
|
|
5867
6012
|
function __wbg_versionvector_new(arg0) {
|
|
@@ -5957,6 +6102,10 @@ function __wbindgen_number_new(arg0) {
|
|
|
5957
6102
|
const ret = arg0;
|
|
5958
6103
|
return addHeapObject(ret);
|
|
5959
6104
|
}
|
|
6105
|
+
function __wbindgen_is_array(arg0) {
|
|
6106
|
+
const ret = Array.isArray(getObject(arg0));
|
|
6107
|
+
return ret;
|
|
6108
|
+
}
|
|
5960
6109
|
function __wbindgen_typeof(arg0) {
|
|
5961
6110
|
const ret = typeof getObject(arg0);
|
|
5962
6111
|
return addHeapObject(ret);
|
|
@@ -6052,7 +6201,7 @@ function __wbg_error_f851667af71bcfc6(arg0, arg1) {
|
|
|
6052
6201
|
wasm.__wbindgen_export_5(deferred0_0, deferred0_1, 1);
|
|
6053
6202
|
}
|
|
6054
6203
|
}
|
|
6055
|
-
const
|
|
6204
|
+
const __wbg_now_15d99db1ebc1f0b2 = typeof Date.now == 'function' ? Date.now : notDefined('Date.now');
|
|
6056
6205
|
|
|
6057
6206
|
function __wbg_crypto_1d1f22824a6a080c(arg0) {
|
|
6058
6207
|
const ret = getObject(arg0).crypto;
|
|
@@ -6159,6 +6308,10 @@ function __wbg_newwithlength_66ae46612e7f0234(arg0) {
|
|
|
6159
6308
|
function __wbg_set_d4638f722068f043(arg0, arg1, arg2) {
|
|
6160
6309
|
getObject(arg0)[arg1 >>> 0] = takeObject(arg2);
|
|
6161
6310
|
}
|
|
6311
|
+
function __wbg_from_89e3fc3ba5e6fb48(arg0) {
|
|
6312
|
+
const ret = Array.from(getObject(arg0));
|
|
6313
|
+
return addHeapObject(ret);
|
|
6314
|
+
}
|
|
6162
6315
|
function __wbg_isArray_2ab64d95e09ea0ae(arg0) {
|
|
6163
6316
|
const ret = Array.isArray(getObject(arg0));
|
|
6164
6317
|
return ret;
|
|
@@ -6312,12 +6465,12 @@ function __wbindgen_memory() {
|
|
|
6312
6465
|
const ret = wasm.memory;
|
|
6313
6466
|
return addHeapObject(ret);
|
|
6314
6467
|
}
|
|
6315
|
-
function
|
|
6316
|
-
const ret = makeMutClosure(arg0, arg1, 9,
|
|
6468
|
+
function __wbindgen_closure_wrapper491(arg0, arg1, arg2) {
|
|
6469
|
+
const ret = makeMutClosure(arg0, arg1, 9, __wbg_adapter_60);
|
|
6317
6470
|
return addHeapObject(ret);
|
|
6318
6471
|
}
|
|
6319
|
-
function
|
|
6320
|
-
const ret = makeMutClosure(arg0, arg1, 11,
|
|
6472
|
+
function __wbindgen_closure_wrapper494(arg0, arg1, arg2) {
|
|
6473
|
+
const ret = makeMutClosure(arg0, arg1, 11, __wbg_adapter_63);
|
|
6321
6474
|
return addHeapObject(ret);
|
|
6322
6475
|
}
|
|
6323
6476
|
|
|
@@ -6349,6 +6502,7 @@ var imports = /*#__PURE__*/Object.freeze({
|
|
|
6349
6502
|
__wbg_entries_ce844941d0c51880: __wbg_entries_ce844941d0c51880,
|
|
6350
6503
|
__wbg_error_c8c2cca30a630316: __wbg_error_c8c2cca30a630316,
|
|
6351
6504
|
__wbg_error_f851667af71bcfc6: __wbg_error_f851667af71bcfc6,
|
|
6505
|
+
__wbg_from_89e3fc3ba5e6fb48: __wbg_from_89e3fc3ba5e6fb48,
|
|
6352
6506
|
__wbg_getRandomValues_3aa56aa6edec874c: __wbg_getRandomValues_3aa56aa6edec874c,
|
|
6353
6507
|
__wbg_get_bd8e338fbd5f5cc8: __wbg_get_bd8e338fbd5f5cc8,
|
|
6354
6508
|
__wbg_get_e3c254076557e348: __wbg_get_e3c254076557e348,
|
|
@@ -6390,7 +6544,7 @@ var imports = /*#__PURE__*/Object.freeze({
|
|
|
6390
6544
|
__wbg_next_196c84450b364254: __wbg_next_196c84450b364254,
|
|
6391
6545
|
__wbg_next_40fc327bfc8770e6: __wbg_next_40fc327bfc8770e6,
|
|
6392
6546
|
__wbg_node_104a2ff8d6ea03a2: __wbg_node_104a2ff8d6ea03a2,
|
|
6393
|
-
|
|
6547
|
+
__wbg_now_15d99db1ebc1f0b2: __wbg_now_15d99db1ebc1f0b2,
|
|
6394
6548
|
__wbg_ownKeys_658942b7f28d1fe9: __wbg_ownKeys_658942b7f28d1fe9,
|
|
6395
6549
|
__wbg_process_4a72847cc503995b: __wbg_process_4a72847cc503995b,
|
|
6396
6550
|
__wbg_push_a5b05aedc7234f9f: __wbg_push_a5b05aedc7234f9f,
|
|
@@ -6418,11 +6572,12 @@ var imports = /*#__PURE__*/Object.freeze({
|
|
|
6418
6572
|
__wbindgen_bigint_get_as_i64: __wbindgen_bigint_get_as_i64,
|
|
6419
6573
|
__wbindgen_boolean_get: __wbindgen_boolean_get,
|
|
6420
6574
|
__wbindgen_cb_drop: __wbindgen_cb_drop,
|
|
6421
|
-
|
|
6422
|
-
|
|
6575
|
+
__wbindgen_closure_wrapper491: __wbindgen_closure_wrapper491,
|
|
6576
|
+
__wbindgen_closure_wrapper494: __wbindgen_closure_wrapper494,
|
|
6423
6577
|
__wbindgen_debug_string: __wbindgen_debug_string,
|
|
6424
6578
|
__wbindgen_error_new: __wbindgen_error_new,
|
|
6425
6579
|
__wbindgen_in: __wbindgen_in,
|
|
6580
|
+
__wbindgen_is_array: __wbindgen_is_array,
|
|
6426
6581
|
__wbindgen_is_bigint: __wbindgen_is_bigint,
|
|
6427
6582
|
__wbindgen_is_falsy: __wbindgen_is_falsy,
|
|
6428
6583
|
__wbindgen_is_function: __wbindgen_is_function,
|
|
@@ -6453,7 +6608,7 @@ var imports = /*#__PURE__*/Object.freeze({
|
|
|
6453
6608
|
// Without this patch, Cloudflare Worker would raise issue like: "Uncaught TypeError: wasm2.__wbindgen_start is not a function"
|
|
6454
6609
|
|
|
6455
6610
|
|
|
6456
|
-
import loro_wasm_bg_js from './loro_wasm_bg-
|
|
6611
|
+
import loro_wasm_bg_js from './loro_wasm_bg-faa2e3e4.js';
|
|
6457
6612
|
const instance = new WebAssembly.Instance(loro_wasm_bg_js(), {
|
|
6458
6613
|
"./loro_wasm_bg.js": imports,
|
|
6459
6614
|
});
|
|
@@ -6658,4 +6813,4 @@ LoroDoc.prototype.toJsonWithReplacer = function (replacer) {
|
|
|
6658
6813
|
return run(layer);
|
|
6659
6814
|
};
|
|
6660
6815
|
|
|
6661
|
-
export { Awareness, AwarenessWasm, Cursor, Loro, LoroCounter, LoroDoc, LoroList, LoroMap, LoroMovableList, LoroText, LoroTree, LoroTreeNode, UndoManager, VersionVector, __wbg_String_b9412f8799faab3e, __wbg_apply_0a5aa603881e6d79, __wbg_buffer_12d079cc21e14bdb, __wbg_call_27c0f87801dedf93, __wbg_call_8e7cb608789c2528, __wbg_call_938992c832f74314, __wbg_call_b3ca7c6051f9bec1, __wbg_crypto_1d1f22824a6a080c, __wbg_cursor_new, __wbg_done_298b57d23c0fc80c, __wbg_entries_95cc2c823b285a09, __wbg_entries_ce844941d0c51880, __wbg_error_c8c2cca30a630316, __wbg_error_f851667af71bcfc6, __wbg_getRandomValues_3aa56aa6edec874c, __wbg_get_bd8e338fbd5f5cc8, __wbg_get_e3c254076557e348, __wbg_getindex_03d06b4e7ea3475e, __wbg_getwithrefkey_edc2c8960f0f1191, __wbg_globalThis_d1e6af4856ba331b, __wbg_global_207b558942527489, __wbg_instanceof_ArrayBuffer_836825be07d4c9d2, __wbg_instanceof_Map_87917e0a7aaf4012, __wbg_instanceof_Object_71ca3c0a59266746, __wbg_instanceof_Uint8Array_2b3bbecd033d19f6, __wbg_isArray_2ab64d95e09ea0ae, __wbg_isSafeInteger_f7b04ef02296c4d2, __wbg_iterator_2cee6dadfd956dfa, __wbg_length_c20a40f15020d68a, __wbg_length_cd7af8117672b8b8, __wbg_log_aba5996d9bde071f, __wbg_log_c9486ca5d8e2cbe8, __wbg_log_d8fdbde28117925d, __wbg_lorocounter_new, __wbg_lorolist_new, __wbg_loromap_new, __wbg_loromovablelist_new, __wbg_lorotext_new, __wbg_lorotree_new, __wbg_lorotreenode_new, __wbg_mark_40e050a77cc39fea, __wbg_measure_aa7a73f17813f708, __wbg_msCrypto_eb05e62b530a1508, __wbg_new_16b304a2cfa7ff4a, __wbg_new_63b92bc8671ed464, __wbg_new_72fb9a18b5ae2624, __wbg_new_abda76e883ba8a5f, __wbg_new_d9bc3a0147634640, __wbg_newnoargs_e258087cd0daa0ea, __wbg_newwithbyteoffsetandlength_aa4a17c33a06e5cb, __wbg_newwithlength_66ae46612e7f0234, __wbg_newwithlength_e9b4878cebadb3d3, __wbg_next_196c84450b364254, __wbg_next_40fc327bfc8770e6, __wbg_node_104a2ff8d6ea03a2,
|
|
6816
|
+
export { Awareness, AwarenessWasm, Cursor, Loro, LoroCounter, LoroDoc, LoroList, LoroMap, LoroMovableList, LoroText, LoroTree, LoroTreeNode, UndoManager, VersionVector, __wbg_String_b9412f8799faab3e, __wbg_apply_0a5aa603881e6d79, __wbg_buffer_12d079cc21e14bdb, __wbg_call_27c0f87801dedf93, __wbg_call_8e7cb608789c2528, __wbg_call_938992c832f74314, __wbg_call_b3ca7c6051f9bec1, __wbg_crypto_1d1f22824a6a080c, __wbg_cursor_new, __wbg_done_298b57d23c0fc80c, __wbg_entries_95cc2c823b285a09, __wbg_entries_ce844941d0c51880, __wbg_error_c8c2cca30a630316, __wbg_error_f851667af71bcfc6, __wbg_from_89e3fc3ba5e6fb48, __wbg_getRandomValues_3aa56aa6edec874c, __wbg_get_bd8e338fbd5f5cc8, __wbg_get_e3c254076557e348, __wbg_getindex_03d06b4e7ea3475e, __wbg_getwithrefkey_edc2c8960f0f1191, __wbg_globalThis_d1e6af4856ba331b, __wbg_global_207b558942527489, __wbg_instanceof_ArrayBuffer_836825be07d4c9d2, __wbg_instanceof_Map_87917e0a7aaf4012, __wbg_instanceof_Object_71ca3c0a59266746, __wbg_instanceof_Uint8Array_2b3bbecd033d19f6, __wbg_isArray_2ab64d95e09ea0ae, __wbg_isSafeInteger_f7b04ef02296c4d2, __wbg_iterator_2cee6dadfd956dfa, __wbg_length_c20a40f15020d68a, __wbg_length_cd7af8117672b8b8, __wbg_log_aba5996d9bde071f, __wbg_log_c9486ca5d8e2cbe8, __wbg_log_d8fdbde28117925d, __wbg_lorocounter_new, __wbg_lorolist_new, __wbg_loromap_new, __wbg_loromovablelist_new, __wbg_lorotext_new, __wbg_lorotree_new, __wbg_lorotreenode_new, __wbg_mark_40e050a77cc39fea, __wbg_measure_aa7a73f17813f708, __wbg_msCrypto_eb05e62b530a1508, __wbg_new_16b304a2cfa7ff4a, __wbg_new_63b92bc8671ed464, __wbg_new_72fb9a18b5ae2624, __wbg_new_abda76e883ba8a5f, __wbg_new_d9bc3a0147634640, __wbg_newnoargs_e258087cd0daa0ea, __wbg_newwithbyteoffsetandlength_aa4a17c33a06e5cb, __wbg_newwithlength_66ae46612e7f0234, __wbg_newwithlength_e9b4878cebadb3d3, __wbg_next_196c84450b364254, __wbg_next_40fc327bfc8770e6, __wbg_node_104a2ff8d6ea03a2, __wbg_now_15d99db1ebc1f0b2, __wbg_ownKeys_658942b7f28d1fe9, __wbg_process_4a72847cc503995b, __wbg_push_a5b05aedc7234f9f, __wbg_randomFillSync_5c9c955aa56b6049, __wbg_require_cca90b1a94a0255b, __wbg_resolve_b0083a7967828ec8, __wbg_self_ce0dbfc45cf2f5be, __wbg_set_1f9b04f170055d33, __wbg_set_8417257aaedc936b, __wbg_set_a47bac70306a19a7, __wbg_set_d4638f722068f043, __wbg_set_f975102236d3c502, __wbg_set_wasm, __wbg_setindex_0b7ede192dc5eca8, __wbg_stack_658279fe44541cf6, __wbg_subarray_a1f73cd4b5b42fe1, __wbg_then_0c86a60e8fcfe9f6, __wbg_value_d93c65011f51a456, __wbg_versions_f686565e586dd935, __wbg_versionvector_new, __wbg_window_c6fb939a7f436783, __wbindgen_as_number, __wbindgen_bigint_from_i64, __wbindgen_bigint_from_u64, __wbindgen_bigint_get_as_i64, __wbindgen_boolean_get, __wbindgen_cb_drop, __wbindgen_closure_wrapper491, __wbindgen_closure_wrapper494, __wbindgen_debug_string, __wbindgen_error_new, __wbindgen_in, __wbindgen_is_array, __wbindgen_is_bigint, __wbindgen_is_falsy, __wbindgen_is_function, __wbindgen_is_null, __wbindgen_is_object, __wbindgen_is_string, __wbindgen_is_undefined, __wbindgen_jsval_eq, __wbindgen_jsval_loose_eq, __wbindgen_memory, __wbindgen_number_get, __wbindgen_number_new, __wbindgen_object_clone_ref, __wbindgen_object_drop_ref, __wbindgen_rethrow, __wbindgen_string_get, __wbindgen_string_new, __wbindgen_throw, __wbindgen_typeof, decodeFrontiers, decodeImportBlobMeta, encodeFrontiers, getType, isContainer, isContainerId, newContainerID, newRootContainerID, run, setDebug };
|