@colyseus/schema 3.0.0 → 3.0.2
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/build/cjs/index.js +1 -1
- package/build/cjs/index.js.map +1 -1
- package/build/esm/index.mjs +1 -1
- package/build/esm/index.mjs.map +1 -1
- package/build/umd/index.js +1 -1
- package/lib/encoder/Encoder.js +1 -1
- package/lib/encoder/Encoder.js.map +1 -1
- package/lib/types/custom/MapSchema.d.ts +14 -14
- package/lib/types/custom/MapSchema.js.map +1 -1
- package/package.json +1 -1
- package/src/encoder/Encoder.ts +2 -3
- package/src/types/custom/MapSchema.ts +12 -12
- package/lib/Decoder.d.ts +0 -16
- package/lib/Decoder.js +0 -182
- package/lib/Decoder.js.map +0 -1
- package/lib/Encoder.d.ts +0 -13
- package/lib/Encoder.js +0 -79
- package/lib/Encoder.js.map +0 -1
- package/lib/bench_encode.d.ts +0 -1
- package/lib/bench_encode.js +0 -130
- package/lib/bench_encode.js.map +0 -1
- package/lib/changes/ChangeSet.d.ts +0 -12
- package/lib/changes/ChangeSet.js +0 -35
- package/lib/changes/ChangeSet.js.map +0 -1
- package/lib/changes/ChangeTree.d.ts +0 -53
- package/lib/changes/ChangeTree.js +0 -202
- package/lib/changes/ChangeTree.js.map +0 -1
- package/lib/changes/DecodeOperation.d.ts +0 -15
- package/lib/changes/DecodeOperation.js +0 -186
- package/lib/changes/DecodeOperation.js.map +0 -1
- package/lib/changes/EncodeOperation.d.ts +0 -18
- package/lib/changes/EncodeOperation.js +0 -130
- package/lib/changes/EncodeOperation.js.map +0 -1
- package/lib/changes/ReferenceTracker.d.ts +0 -14
- package/lib/changes/ReferenceTracker.js +0 -83
- package/lib/changes/ReferenceTracker.js.map +0 -1
- package/lib/changes/consts.d.ts +0 -14
- package/lib/changes/consts.js +0 -18
- package/lib/changes/consts.js.map +0 -1
- package/lib/debug.d.ts +0 -1
- package/lib/debug.js +0 -51
- package/lib/debug.js.map +0 -1
- package/lib/decoding/decode.d.ts +0 -48
- package/lib/decoding/decode.js +0 -267
- package/lib/decoding/decode.js.map +0 -1
- package/lib/ecs.d.ts +0 -11
- package/lib/ecs.js +0 -160
- package/lib/ecs.js.map +0 -1
- package/lib/filters/index.d.ts +0 -8
- package/lib/filters/index.js +0 -24
- package/lib/filters/index.js.map +0 -1
- package/lib/spec.d.ts +0 -13
- package/lib/spec.js +0 -42
- package/lib/spec.js.map +0 -1
- package/lib/types/ArraySchema.d.ts +0 -238
- package/lib/types/ArraySchema.js +0 -555
- package/lib/types/ArraySchema.js.map +0 -1
- package/lib/types/CollectionSchema.d.ts +0 -35
- package/lib/types/CollectionSchema.js +0 -150
- package/lib/types/CollectionSchema.js.map +0 -1
- package/lib/types/MapSchema.d.ts +0 -38
- package/lib/types/MapSchema.js +0 -215
- package/lib/types/MapSchema.js.map +0 -1
- package/lib/types/SetSchema.d.ts +0 -32
- package/lib/types/SetSchema.js +0 -162
- package/lib/types/SetSchema.js.map +0 -1
- package/lib/types/typeRegistry.d.ts +0 -5
- package/lib/types/typeRegistry.js +0 -13
- package/lib/types/typeRegistry.js.map +0 -1
- package/lib/usage.d.ts +0 -1
- package/lib/usage.js +0 -22
- package/lib/usage.js.map +0 -1
- package/lib/v3.d.ts +0 -1
- package/lib/v3.js +0 -427
- package/lib/v3.js.map +0 -1
- package/lib/v3_experiment.d.ts +0 -1
- package/lib/v3_experiment.js +0 -407
- package/lib/v3_experiment.js.map +0 -1
- package/src/bench_encode.ts +0 -108
- package/src/debug.ts +0 -55
package/lib/Encoder.js
DELETED
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Encoder = void 0;
|
|
4
|
-
const annotations_1 = require("./annotations");
|
|
5
|
-
const consts_1 = require("./changes/consts");
|
|
6
|
-
const encode = require("./encoding/encode");
|
|
7
|
-
const spec_1 = require("./spec");
|
|
8
|
-
const ChangeTree_1 = require("./changes/ChangeTree");
|
|
9
|
-
class Encoder {
|
|
10
|
-
constructor(root) {
|
|
11
|
-
this.setRoot(root);
|
|
12
|
-
//
|
|
13
|
-
// TODO: cache and restore "Context" based on root schema
|
|
14
|
-
// (to avoid creating a new context for each new room)
|
|
15
|
-
//
|
|
16
|
-
this.context = new annotations_1.TypeContext(root.constructor);
|
|
17
|
-
// console.log(">>>>>>>>>>>>>>>> Encoder types");
|
|
18
|
-
// this.context.schemas.forEach((id, schema) => {
|
|
19
|
-
// console.log("type:", id, schema.name, Object.keys(schema[Symbol.metadata]));
|
|
20
|
-
// });
|
|
21
|
-
}
|
|
22
|
-
setRoot(root) {
|
|
23
|
-
this.$root = new ChangeTree_1.Root();
|
|
24
|
-
this.root = root;
|
|
25
|
-
root[consts_1.$changes].setRoot(this.$root);
|
|
26
|
-
}
|
|
27
|
-
encode(encodeAll = false, bytes = [], useFilters = false) {
|
|
28
|
-
const rootChangeTree = this.root[consts_1.$changes];
|
|
29
|
-
// const changeTrees: ChangeTracker[] = Array.from(this.$root['currentQueue']);
|
|
30
|
-
const changeTrees = this.$root.changes;
|
|
31
|
-
const numChangeTrees = changeTrees.length;
|
|
32
|
-
// let numChangeTrees = 1;
|
|
33
|
-
// console.log("--------------------- ENCODE ----------------");
|
|
34
|
-
// console.log("Encode order:", changeTrees.map((c) => c.ref['constructor'].name));
|
|
35
|
-
for (let i = 0; i < numChangeTrees; i++) {
|
|
36
|
-
const changeTree = changeTrees[i];
|
|
37
|
-
const ref = changeTree.ref;
|
|
38
|
-
// Generate unique refId for the ChangeTree.
|
|
39
|
-
changeTree.ensureRefId();
|
|
40
|
-
// root `refId` is skipped.
|
|
41
|
-
if (changeTree !== rootChangeTree &&
|
|
42
|
-
(changeTree.changed || encodeAll)) {
|
|
43
|
-
encode.uint8(bytes, spec_1.SWITCH_TO_STRUCTURE);
|
|
44
|
-
encode.number(bytes, changeTree.refId);
|
|
45
|
-
}
|
|
46
|
-
const changes = (encodeAll)
|
|
47
|
-
? changeTree.allChanges.values()
|
|
48
|
-
: changeTree.changes.values();
|
|
49
|
-
let change;
|
|
50
|
-
while (!(change = changes.next()).done) {
|
|
51
|
-
const operation = (encodeAll)
|
|
52
|
-
? spec_1.OPERATION.ADD
|
|
53
|
-
: change.value.op;
|
|
54
|
-
const fieldIndex = (encodeAll)
|
|
55
|
-
? change.value
|
|
56
|
-
: change.value.index;
|
|
57
|
-
const encoder = ref['constructor'][consts_1.$encoder];
|
|
58
|
-
encoder(this, bytes, changeTree, fieldIndex, operation);
|
|
59
|
-
}
|
|
60
|
-
if (!encodeAll && !useFilters) {
|
|
61
|
-
changeTree.discard();
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
return bytes;
|
|
65
|
-
}
|
|
66
|
-
encodeAll(useFilters) {
|
|
67
|
-
return this.encode(true, [], useFilters);
|
|
68
|
-
}
|
|
69
|
-
tryEncodeTypeId(bytes, baseType, targetType) {
|
|
70
|
-
const baseTypeId = this.context.getTypeId(baseType);
|
|
71
|
-
const targetTypeId = this.context.getTypeId(targetType);
|
|
72
|
-
if (baseTypeId !== targetTypeId) {
|
|
73
|
-
encode.uint8(bytes, spec_1.TYPE_ID);
|
|
74
|
-
encode.number(bytes, targetTypeId);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
exports.Encoder = Encoder;
|
|
79
|
-
//# sourceMappingURL=Encoder.js.map
|
package/lib/Encoder.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Encoder.js","sourceRoot":"","sources":["../src/Encoder.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Schema } from \"./Schema\";\nimport { TypeContext } from \"./annotations\";\nimport { $changes, $encoder } from \"./changes/consts\";\n\nimport * as encode from \"./encoding/encode\";\nimport { SWITCH_TO_STRUCTURE, TYPE_ID, OPERATION } from './spec';\nimport { ChangeOperation, ChangeTracker, Root } from \"./changes/ChangeTree\";\nimport { encodeKeyValueOperation, encodeSchemaOperation } from \"./changes/EncodeOperation\";\n\nexport class Encoder<T extends Schema = any> {\n context: TypeContext;\n\n root: T;\n $root: Root;\n\n constructor(root: T) {\n this.setRoot(root);\n\n //\n // TODO: cache and restore \"Context\" based on root schema\n // (to avoid creating a new context for each new room)\n //\n this.context = new TypeContext(root.constructor as typeof Schema);\n\n // console.log(\">>>>>>>>>>>>>>>> Encoder types\");\n // this.context.schemas.forEach((id, schema) => {\n // console.log(\"type:\", id, schema.name, Object.keys(schema[Symbol.metadata]));\n // });\n }\n\n protected setRoot(root: T) {\n this.$root = new Root();\n this.root = root;\n root[$changes].setRoot(this.$root);\n }\n\n encode(\n encodeAll = false,\n bytes: number[] = [],\n useFilters: boolean = false,\n ) {\n const rootChangeTree = this.root[$changes];\n\n // const changeTrees: ChangeTracker[] = Array.from(this.$root['currentQueue']);\n const changeTrees: ChangeTracker[] = this.$root.changes;\n const numChangeTrees = changeTrees.length;\n // let numChangeTrees = 1;\n\n // console.log(\"--------------------- ENCODE ----------------\");\n // console.log(\"Encode order:\", changeTrees.map((c) => c.ref['constructor'].name));\n for (let i = 0; i < numChangeTrees; i++) {\n const changeTree = changeTrees[i];\n const ref = changeTree.ref;\n\n // Generate unique refId for the ChangeTree.\n changeTree.ensureRefId();\n\n // root `refId` is skipped.\n if (\n changeTree !== rootChangeTree &&\n (changeTree.changed || encodeAll)\n ) {\n encode.uint8(bytes, SWITCH_TO_STRUCTURE);\n encode.number(bytes, changeTree.refId);\n }\n\n const changes: IterableIterator<ChangeOperation | number> = (encodeAll)\n ? changeTree.allChanges.values()\n : changeTree.changes.values();\n\n let change: IteratorResult<ChangeOperation | number>;\n while (!(change = changes.next()).done) {\n const operation = (encodeAll)\n ? OPERATION.ADD\n : change.value.op;\n\n const fieldIndex = (encodeAll)\n ? change.value\n : change.value.index;\n\n const encoder = ref['constructor'][$encoder];\n encoder(this, bytes, changeTree, fieldIndex, operation);\n }\n\n if (!encodeAll && !useFilters) {\n changeTree.discard();\n }\n }\n\n return bytes;\n }\n\n encodeAll (useFilters?: boolean) {\n return this.encode(true, [], useFilters);\n }\n\n tryEncodeTypeId (bytes: number[], baseType: typeof Schema, targetType: typeof Schema) {\n const baseTypeId = this.context.getTypeId(baseType);\n const targetTypeId = this.context.getTypeId(targetType);\n\n if (baseTypeId !== targetTypeId) {\n encode.uint8(bytes, TYPE_ID);\n encode.number(bytes, targetTypeId);\n }\n }\n\n}"]}
|
package/lib/bench_encode.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/lib/bench_encode.js
DELETED
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
const nanoid_1 = require("nanoid");
|
|
10
|
-
const _1 = require(".");
|
|
11
|
-
class Attribute extends _1.Schema {
|
|
12
|
-
}
|
|
13
|
-
__decorate([
|
|
14
|
-
(0, _1.type)("string")
|
|
15
|
-
], Attribute.prototype, "name", void 0);
|
|
16
|
-
__decorate([
|
|
17
|
-
(0, _1.type)("number")
|
|
18
|
-
], Attribute.prototype, "value", void 0);
|
|
19
|
-
class Item extends _1.Schema {
|
|
20
|
-
constructor() {
|
|
21
|
-
super(...arguments);
|
|
22
|
-
this.attributes = new _1.ArraySchema();
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
__decorate([
|
|
26
|
-
(0, _1.type)("number")
|
|
27
|
-
], Item.prototype, "price", void 0);
|
|
28
|
-
__decorate([
|
|
29
|
-
(0, _1.type)([Attribute])
|
|
30
|
-
], Item.prototype, "attributes", void 0);
|
|
31
|
-
class Position extends _1.Schema {
|
|
32
|
-
}
|
|
33
|
-
__decorate([
|
|
34
|
-
(0, _1.type)("number")
|
|
35
|
-
], Position.prototype, "x", void 0);
|
|
36
|
-
__decorate([
|
|
37
|
-
(0, _1.type)("number")
|
|
38
|
-
], Position.prototype, "y", void 0);
|
|
39
|
-
class Player extends _1.Schema {
|
|
40
|
-
constructor() {
|
|
41
|
-
super(...arguments);
|
|
42
|
-
this.position = new Position();
|
|
43
|
-
this.items = new _1.MapSchema();
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
__decorate([
|
|
47
|
-
(0, _1.type)(Position)
|
|
48
|
-
], Player.prototype, "position", void 0);
|
|
49
|
-
__decorate([
|
|
50
|
-
(0, _1.type)({ map: Item })
|
|
51
|
-
], Player.prototype, "items", void 0);
|
|
52
|
-
class State extends _1.Schema {
|
|
53
|
-
constructor() {
|
|
54
|
-
super(...arguments);
|
|
55
|
-
this.players = new _1.MapSchema();
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
__decorate([
|
|
59
|
-
(0, _1.type)({ map: Player })
|
|
60
|
-
], State.prototype, "players", void 0);
|
|
61
|
-
__decorate([
|
|
62
|
-
(0, _1.type)("string")
|
|
63
|
-
], State.prototype, "currentTurn", void 0);
|
|
64
|
-
const state = new State();
|
|
65
|
-
_1.Encoder.BUFFER_SIZE = 4096 * 4096;
|
|
66
|
-
const encoder = new _1.Encoder(state);
|
|
67
|
-
let now = Date.now();
|
|
68
|
-
// for (let i = 0; i < 10000; i++) {
|
|
69
|
-
// const player = new Player();
|
|
70
|
-
// state.players.set(`p-${nanoid()}`, player);
|
|
71
|
-
//
|
|
72
|
-
// player.position.x = (i + 1) * 100;
|
|
73
|
-
// player.position.y = (i + 1) * 100;
|
|
74
|
-
// for (let j = 0; j < 10; j++) {
|
|
75
|
-
// const item = new Item();
|
|
76
|
-
// player.items.set(`item-${j}`, item);
|
|
77
|
-
// item.price = (i + 1) * 50;
|
|
78
|
-
// for (let k = 0; k < 5; k++) {
|
|
79
|
-
// const attr = new Attribute();
|
|
80
|
-
// attr.name = `Attribute ${k}`;
|
|
81
|
-
// attr.value = k;
|
|
82
|
-
// item.attributes.push(attr);
|
|
83
|
-
// }
|
|
84
|
-
// }
|
|
85
|
-
// }
|
|
86
|
-
// console.log("time to make changes:", Date.now() - now);
|
|
87
|
-
// measure time to .encodeAll()
|
|
88
|
-
now = Date.now();
|
|
89
|
-
// for (let i = 0; i < 1000; i++) {
|
|
90
|
-
// encoder.encodeAll();
|
|
91
|
-
// }
|
|
92
|
-
// console.log(Date.now() - now);
|
|
93
|
-
const total = 100;
|
|
94
|
-
const allEncodes = Date.now();
|
|
95
|
-
let avgTimeToEncode = 0;
|
|
96
|
-
let avgTimeToMakeChanges = 0;
|
|
97
|
-
for (let i = 0; i < total; i++) {
|
|
98
|
-
now = Date.now();
|
|
99
|
-
for (let j = 0; j < 50; j++) {
|
|
100
|
-
const player = new Player();
|
|
101
|
-
state.players.set(`p-${(0, nanoid_1.nanoid)()}`, player);
|
|
102
|
-
player.position.x = (j + 1) * 100;
|
|
103
|
-
player.position.y = (j + 1) * 100;
|
|
104
|
-
for (let k = 0; k < 10; k++) {
|
|
105
|
-
const item = new Item();
|
|
106
|
-
item.price = (j + 1) * 50;
|
|
107
|
-
for (let l = 0; l < 5; l++) {
|
|
108
|
-
const attr = new Attribute();
|
|
109
|
-
attr.name = `Attribute ${l}`;
|
|
110
|
-
attr.value = l;
|
|
111
|
-
item.attributes.push(attr);
|
|
112
|
-
}
|
|
113
|
-
player.items.set(`item-${k}`, item);
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
const timeToMakeChanges = Date.now() - now;
|
|
117
|
-
console.log("time to make changes:", timeToMakeChanges);
|
|
118
|
-
avgTimeToMakeChanges += timeToMakeChanges;
|
|
119
|
-
now = Date.now();
|
|
120
|
-
encoder.encode();
|
|
121
|
-
encoder.discardChanges();
|
|
122
|
-
const timeToEncode = Date.now() - now;
|
|
123
|
-
console.log("time to encode:", timeToEncode);
|
|
124
|
-
avgTimeToEncode += timeToEncode;
|
|
125
|
-
}
|
|
126
|
-
console.log("avg time to encode:", (avgTimeToEncode) / total);
|
|
127
|
-
console.log("avg time to make changes:", (avgTimeToMakeChanges) / total);
|
|
128
|
-
console.log("time for all encodes:", Date.now() - allEncodes);
|
|
129
|
-
console.log(Array.from(encoder.encodeAll()).length, "bytes");
|
|
130
|
-
//# sourceMappingURL=bench_encode.js.map
|
package/lib/bench_encode.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bench_encode.js","sourceRoot":"","sources":["../src/bench_encode.ts"],"names":[],"mappings":";;;;;;;;AAAA,mCAAgC;AAChC,wBAAkE;AAElE,MAAM,SAAU,SAAQ,SAAM;CAG7B;AAFmB;IAAf,IAAA,OAAI,EAAC,QAAQ,CAAC;uCAAc;AACb;IAAf,IAAA,OAAI,EAAC,QAAQ,CAAC;wCAAe;AAGlC,MAAM,IAAK,SAAQ,SAAM;IAAzB;;QAEyB,eAAU,GAAG,IAAI,cAAW,EAAa,CAAC;IACnE,CAAC;CAAA;AAFmB;IAAf,IAAA,OAAI,EAAC,QAAQ,CAAC;mCAAe;AACT;IAApB,IAAA,OAAI,EAAC,CAAE,SAAS,CAAE,CAAC;wCAA2C;AAGnE,MAAM,QAAS,SAAQ,SAAM;CAG5B;AAFmB;IAAf,IAAA,OAAI,EAAC,QAAQ,CAAC;mCAAW;AACV;IAAf,IAAA,OAAI,EAAC,QAAQ,CAAC;mCAAW;AAG9B,MAAM,MAAO,SAAQ,SAAM;IAA3B;;QACoB,aAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;QACrB,UAAK,GAAG,IAAI,YAAS,EAAQ,CAAC;IACvD,CAAC;CAAA;AAFmB;IAAf,IAAA,OAAI,EAAC,QAAQ,CAAC;wCAA2B;AACrB;IAApB,IAAA,OAAI,EAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;qCAA+B;AAGvD,MAAM,KAAM,SAAQ,SAAM;IAA1B;;QAC2B,YAAO,GAAG,IAAI,YAAS,EAAU,CAAC;IAE7D,CAAC;CAAA;AAF0B;IAAtB,IAAA,OAAI,EAAC,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC;sCAAmC;AACzC;IAAf,IAAA,OAAI,EAAC,QAAQ,CAAC;0CAAa;AAGhC,MAAM,KAAK,GAAG,IAAI,KAAK,EAAE,CAAC;AAE1B,UAAO,CAAC,WAAW,GAAG,IAAI,GAAG,IAAI,CAAC;AAClC,MAAM,OAAO,GAAG,IAAI,UAAO,CAAC,KAAK,CAAC,CAAC;AAGnC,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;AAErB,oCAAoC;AACpC,mCAAmC;AACnC,kDAAkD;AAClD,EAAE;AACF,yCAAyC;AACzC,yCAAyC;AACzC,qCAAqC;AACrC,mCAAmC;AACnC,+CAA+C;AAC/C,qCAAqC;AACrC,wCAAwC;AACxC,4CAA4C;AAC5C,4CAA4C;AAC5C,8BAA8B;AAC9B,0CAA0C;AAC1C,YAAY;AACZ,QAAQ;AACR,IAAI;AACJ,0DAA0D;AAG1D,+BAA+B;AAE/B,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;AACjB,mCAAmC;AACnC,2BAA2B;AAC3B,IAAI;AACJ,iCAAiC;AAEjC,MAAM,KAAK,GAAG,GAAG,CAAC;AAClB,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;AAE9B,IAAI,eAAe,GAAG,CAAC,CAAC;AACxB,IAAI,oBAAoB,GAAG,CAAC,CAAC;AAE7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;IAC7B,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;QAC1B,MAAM,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;QAC5B,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,IAAA,eAAM,GAAE,EAAE,EAAE,MAAM,CAAC,CAAC;QAE3C,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;QAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1B,MAAM,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;YAC1B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;gBACzB,MAAM,IAAI,GAAG,IAAI,SAAS,EAAE,CAAC;gBAC7B,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC,EAAE,CAAC;gBAC7B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;gBACf,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/B,CAAC;YACD,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QACxC,CAAC;IACL,CAAC;IACD,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,CAAC;IAC3C,OAAO,CAAC,GAAG,CAAC,uBAAuB,EAAE,iBAAiB,CAAC,CAAC;IACxD,oBAAoB,IAAI,iBAAiB,CAAC;IAE1C,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACjB,OAAO,CAAC,MAAM,EAAE,CAAC;IACjB,OAAO,CAAC,cAAc,EAAE,CAAC;IAEzB,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,CAAC;IACtC,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;IAC7C,eAAe,IAAI,YAAY,CAAC;AACpC,CAAC;AACD,OAAO,CAAC,GAAG,CAAC,qBAAqB,EAAE,CAAC,eAAe,CAAC,GAAG,KAAK,CAAC,CAAC;AAC9D,OAAO,CAAC,GAAG,CAAC,2BAA2B,EAAE,CAAC,oBAAoB,CAAC,GAAG,KAAK,CAAC,CAAC;AACzE,OAAO,CAAC,GAAG,CAAC,uBAAuB,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,UAAU,CAAC,CAAC;AAE9D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC","sourcesContent":["import { nanoid } from \"nanoid\";\nimport { Schema, type, MapSchema, ArraySchema, Encoder } from \".\";\n\nclass Attribute extends Schema {\n @type(\"string\") name: string;\n @type(\"number\") value: number;\n}\n\nclass Item extends Schema {\n @type(\"number\") price: number;\n @type([ Attribute ]) attributes = new ArraySchema<Attribute>();\n}\n\nclass Position extends Schema {\n @type(\"number\") x: number;\n @type(\"number\") y: number;\n}\n\nclass Player extends Schema {\n @type(Position) position = new Position();\n @type({ map: Item }) items = new MapSchema<Item>();\n}\n\nclass State extends Schema {\n @type({ map: Player }) players = new MapSchema<Player>();\n @type(\"string\") currentTurn;\n}\n\nconst state = new State();\n\nEncoder.BUFFER_SIZE = 4096 * 4096;\nconst encoder = new Encoder(state);\n\n\nlet now = Date.now();\n\n// for (let i = 0; i < 10000; i++) {\n// const player = new Player();\n// state.players.set(`p-${nanoid()}`, player);\n//\n// player.position.x = (i + 1) * 100;\n// player.position.y = (i + 1) * 100;\n// for (let j = 0; j < 10; j++) {\n// const item = new Item();\n// player.items.set(`item-${j}`, item);\n// item.price = (i + 1) * 50;\n// for (let k = 0; k < 5; k++) {\n// const attr = new Attribute();\n// attr.name = `Attribute ${k}`;\n// attr.value = k;\n// item.attributes.push(attr);\n// }\n// }\n// }\n// console.log(\"time to make changes:\", Date.now() - now);\n\n\n// measure time to .encodeAll()\n\nnow = Date.now();\n// for (let i = 0; i < 1000; i++) {\n// encoder.encodeAll();\n// }\n// console.log(Date.now() - now);\n\nconst total = 100;\nconst allEncodes = Date.now();\n\nlet avgTimeToEncode = 0;\nlet avgTimeToMakeChanges = 0;\n\nfor (let i = 0; i < total; i++) {\n now = Date.now();\n for (let j = 0; j < 50; j++) {\n const player = new Player();\n state.players.set(`p-${nanoid()}`, player);\n\n player.position.x = (j + 1) * 100;\n player.position.y = (j + 1) * 100;\n for (let k = 0; k < 10; k++) {\n const item = new Item();\n item.price = (j + 1) * 50;\n for (let l = 0; l < 5; l++) {\n const attr = new Attribute();\n attr.name = `Attribute ${l}`;\n attr.value = l;\n item.attributes.push(attr);\n }\n player.items.set(`item-${k}`, item);\n }\n }\n const timeToMakeChanges = Date.now() - now;\n console.log(\"time to make changes:\", timeToMakeChanges);\n avgTimeToMakeChanges += timeToMakeChanges;\n\n now = Date.now();\n encoder.encode();\n encoder.discardChanges();\n\n const timeToEncode = Date.now() - now;\n console.log(\"time to encode:\", timeToEncode);\n avgTimeToEncode += timeToEncode;\n}\nconsole.log(\"avg time to encode:\", (avgTimeToEncode) / total);\nconsole.log(\"avg time to make changes:\", (avgTimeToMakeChanges) / total);\nconsole.log(\"time for all encodes:\", Date.now() - allEncodes);\n\nconsole.log(Array.from(encoder.encodeAll()).length, \"bytes\");\n"]}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { OPERATION } from "../spec";
|
|
2
|
-
import { ChangeOperation } from "./ChangeTree";
|
|
3
|
-
export declare class ChangeSet {
|
|
4
|
-
changes: {
|
|
5
|
-
[index: number]: ChangeOperation;
|
|
6
|
-
};
|
|
7
|
-
changed: boolean;
|
|
8
|
-
allChanges: Set<number>;
|
|
9
|
-
change(index: number, operation?: OPERATION): void;
|
|
10
|
-
discardAll(): void;
|
|
11
|
-
setParent(...args: any[]): void;
|
|
12
|
-
}
|
package/lib/changes/ChangeSet.js
DELETED
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ChangeSet = void 0;
|
|
4
|
-
const spec_1 = require("../spec");
|
|
5
|
-
class ChangeSet {
|
|
6
|
-
changes = {};
|
|
7
|
-
changed = false;
|
|
8
|
-
allChanges = new Set();
|
|
9
|
-
// definition: SchemaDefinition;
|
|
10
|
-
change(index, operation = spec_1.OPERATION.ADD) {
|
|
11
|
-
const previousChange = this.changes[index];
|
|
12
|
-
if (!previousChange ||
|
|
13
|
-
previousChange.op === spec_1.OPERATION.DELETE ||
|
|
14
|
-
previousChange.op === spec_1.OPERATION.TOUCH // (mazmorra.io's BattleAction issue)
|
|
15
|
-
) {
|
|
16
|
-
this.changes[index] = {
|
|
17
|
-
op: (!previousChange)
|
|
18
|
-
? operation
|
|
19
|
-
: (previousChange.op === spec_1.OPERATION.DELETE)
|
|
20
|
-
? spec_1.OPERATION.DELETE_AND_ADD
|
|
21
|
-
: operation,
|
|
22
|
-
index
|
|
23
|
-
};
|
|
24
|
-
}
|
|
25
|
-
this.allChanges.add(index);
|
|
26
|
-
this.changed = true;
|
|
27
|
-
}
|
|
28
|
-
discardAll() {
|
|
29
|
-
this.changes = {};
|
|
30
|
-
}
|
|
31
|
-
setParent(...args) {
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
exports.ChangeSet = ChangeSet;
|
|
35
|
-
//# sourceMappingURL=ChangeSet.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ChangeSet.js","sourceRoot":"","sources":["../../src/changes/ChangeSet.ts"],"names":[],"mappings":";;;AAAA,kCAAoC;AAIpC,MAAa,SAAS;IAClB,OAAO,GAAyC,EAAE,CAAC;IACnD,OAAO,GAAY,KAAK,CAAC;IACzB,UAAU,GAAgB,IAAI,GAAG,EAAE,CAAC;IACpC,gCAAgC;IAEhC,MAAM,CAAC,KAAa,EAAE,YAAuB,gBAAS,CAAC,GAAG;QACtD,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAE3C,IACI,CAAC,cAAc;YACf,cAAc,CAAC,EAAE,KAAK,gBAAS,CAAC,MAAM;YACtC,cAAc,CAAC,EAAE,KAAK,gBAAS,CAAC,KAAK,CAAC,qCAAqC;UAC7E,CAAC;YACC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG;gBAClB,EAAE,EAAE,CAAC,CAAC,cAAc,CAAC;oBACjB,CAAC,CAAC,SAAS;oBACX,CAAC,CAAC,CAAC,cAAc,CAAC,EAAE,KAAK,gBAAS,CAAC,MAAM,CAAC;wBACtC,CAAC,CAAC,gBAAS,CAAC,cAAc;wBAC1B,CAAC,CAAC,SAAS;gBACnB,KAAK;aACR,CAAC;QACN,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAE3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACxB,CAAC;IAED,UAAU;QACN,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,SAAS,CAAC,GAAG,IAAW;IACxB,CAAC;CAEJ;AApCD,8BAoCC","sourcesContent":["import { OPERATION } from \"../spec\";\nimport { SchemaDefinition } from \"../annotations\";\nimport { ChangeOperation, Ref } from \"./ChangeTree\";\n\nexport class ChangeSet {\n changes: { [index: number]: ChangeOperation } = {};\n changed: boolean = false;\n allChanges: Set<number> = new Set();\n // definition: SchemaDefinition;\n\n change(index: number, operation: OPERATION = OPERATION.ADD) {\n const previousChange = this.changes[index];\n\n if (\n !previousChange ||\n previousChange.op === OPERATION.DELETE ||\n previousChange.op === OPERATION.TOUCH // (mazmorra.io's BattleAction issue)\n ) {\n this.changes[index] = {\n op: (!previousChange)\n ? operation\n : (previousChange.op === OPERATION.DELETE)\n ? OPERATION.DELETE_AND_ADD\n : operation,\n index\n };\n }\n\n this.allChanges.add(index);\n\n this.changed = true;\n }\n\n discardAll() {\n this.changes = {};\n }\n\n setParent(...args: any[]) {\n }\n\n}"]}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { OPERATION } from "../spec";
|
|
2
|
-
import { Schema } from "../Schema";
|
|
3
|
-
import { FilterChildrenCallback } from "../annotations";
|
|
4
|
-
import { MapSchema } from "../types/MapSchema";
|
|
5
|
-
import { ArraySchema } from "../types/ArraySchema";
|
|
6
|
-
import { CollectionSchema } from "../types/CollectionSchema";
|
|
7
|
-
import { SetSchema } from "../types/SetSchema";
|
|
8
|
-
import { ReferenceTracker } from "./ReferenceTracker";
|
|
9
|
-
export type Ref = Schema | ArraySchema | MapSchema | CollectionSchema | SetSchema;
|
|
10
|
-
export interface ChangeOperation {
|
|
11
|
-
op: OPERATION;
|
|
12
|
-
index: number;
|
|
13
|
-
}
|
|
14
|
-
export interface FieldCache {
|
|
15
|
-
beginIndex: number;
|
|
16
|
-
endIndex: number;
|
|
17
|
-
}
|
|
18
|
-
export declare class ChangeTree {
|
|
19
|
-
ref: Ref;
|
|
20
|
-
refId: number;
|
|
21
|
-
root?: ReferenceTracker;
|
|
22
|
-
parent?: Ref;
|
|
23
|
-
parentIndex?: number;
|
|
24
|
-
indexes: {
|
|
25
|
-
[index: string]: any;
|
|
26
|
-
};
|
|
27
|
-
changed: boolean;
|
|
28
|
-
changes: Map<number, ChangeOperation>;
|
|
29
|
-
allChanges: Set<number>;
|
|
30
|
-
caches: {
|
|
31
|
-
[field: number]: number[];
|
|
32
|
-
};
|
|
33
|
-
currentCustomOperation: number;
|
|
34
|
-
constructor(ref: Ref, parent?: Ref, root?: ReferenceTracker);
|
|
35
|
-
setParent(parent: Ref, root?: ReferenceTracker, parentIndex?: number): void;
|
|
36
|
-
operation(op: ChangeOperation): void;
|
|
37
|
-
change(fieldName: string | number, operation?: OPERATION): void;
|
|
38
|
-
touch(fieldName: string | number): void;
|
|
39
|
-
touchParents(): void;
|
|
40
|
-
getType(index?: number): any;
|
|
41
|
-
getChildrenFilter(): FilterChildrenCallback;
|
|
42
|
-
getValue(index: number): any;
|
|
43
|
-
delete(fieldName: string | number): void;
|
|
44
|
-
discard(changed?: boolean, discardAll?: boolean): void;
|
|
45
|
-
/**
|
|
46
|
-
* Recursively discard all changes from this, and child structures.
|
|
47
|
-
*/
|
|
48
|
-
discardAll(): void;
|
|
49
|
-
cache(field: number, cachedBytes: number[]): void;
|
|
50
|
-
clone(): ChangeTree;
|
|
51
|
-
ensureRefId(): void;
|
|
52
|
-
protected assertValidIndex(index: number, fieldName: string | number): void;
|
|
53
|
-
}
|
|
@@ -1,202 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ChangeTree = void 0;
|
|
4
|
-
const spec_1 = require("../spec");
|
|
5
|
-
const Schema_1 = require("../Schema");
|
|
6
|
-
class ChangeTree {
|
|
7
|
-
constructor(ref, parent, root) {
|
|
8
|
-
this.changed = false;
|
|
9
|
-
this.changes = new Map();
|
|
10
|
-
this.allChanges = new Set();
|
|
11
|
-
// cached indexes for filtering
|
|
12
|
-
this.caches = {};
|
|
13
|
-
this.currentCustomOperation = 0;
|
|
14
|
-
this.ref = ref;
|
|
15
|
-
this.setParent(parent, root);
|
|
16
|
-
}
|
|
17
|
-
setParent(parent, root, parentIndex) {
|
|
18
|
-
if (!this.indexes) {
|
|
19
|
-
this.indexes = (this.ref instanceof Schema_1.Schema)
|
|
20
|
-
? this.ref['_definition'].indexes
|
|
21
|
-
: {};
|
|
22
|
-
}
|
|
23
|
-
this.parent = parent;
|
|
24
|
-
this.parentIndex = parentIndex;
|
|
25
|
-
// avoid setting parents with empty `root`
|
|
26
|
-
if (!root) {
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
this.root = root;
|
|
30
|
-
//
|
|
31
|
-
// assign same parent on child structures
|
|
32
|
-
//
|
|
33
|
-
if (this.ref instanceof Schema_1.Schema) {
|
|
34
|
-
const definition = this.ref['_definition'];
|
|
35
|
-
for (let field in definition.schema) {
|
|
36
|
-
const value = this.ref[field];
|
|
37
|
-
if (value && value['$changes']) {
|
|
38
|
-
const parentIndex = definition.indexes[field];
|
|
39
|
-
value['$changes'].setParent(this.ref, root, parentIndex);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
else if (typeof (this.ref) === "object") {
|
|
44
|
-
this.ref.forEach((value, key) => {
|
|
45
|
-
if (value instanceof Schema_1.Schema) {
|
|
46
|
-
const changeTreee = value['$changes'];
|
|
47
|
-
const parentIndex = this.ref['$changes'].indexes[key];
|
|
48
|
-
changeTreee.setParent(this.ref, this.root, parentIndex);
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
operation(op) {
|
|
54
|
-
this.changes.set(--this.currentCustomOperation, op);
|
|
55
|
-
}
|
|
56
|
-
change(fieldName, operation = spec_1.OPERATION.ADD) {
|
|
57
|
-
const index = (typeof (fieldName) === "number")
|
|
58
|
-
? fieldName
|
|
59
|
-
: this.indexes[fieldName];
|
|
60
|
-
this.assertValidIndex(index, fieldName);
|
|
61
|
-
const previousChange = this.changes.get(index);
|
|
62
|
-
if (!previousChange ||
|
|
63
|
-
previousChange.op === spec_1.OPERATION.DELETE ||
|
|
64
|
-
previousChange.op === spec_1.OPERATION.TOUCH // (mazmorra.io's BattleAction issue)
|
|
65
|
-
) {
|
|
66
|
-
this.changes.set(index, {
|
|
67
|
-
op: (!previousChange)
|
|
68
|
-
? operation
|
|
69
|
-
: (previousChange.op === spec_1.OPERATION.DELETE)
|
|
70
|
-
? spec_1.OPERATION.DELETE_AND_ADD
|
|
71
|
-
: operation,
|
|
72
|
-
// : OPERATION.REPLACE,
|
|
73
|
-
index
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
this.allChanges.add(index);
|
|
77
|
-
this.changed = true;
|
|
78
|
-
this.touchParents();
|
|
79
|
-
}
|
|
80
|
-
touch(fieldName) {
|
|
81
|
-
const index = (typeof (fieldName) === "number")
|
|
82
|
-
? fieldName
|
|
83
|
-
: this.indexes[fieldName];
|
|
84
|
-
this.assertValidIndex(index, fieldName);
|
|
85
|
-
if (!this.changes.has(index)) {
|
|
86
|
-
this.changes.set(index, { op: spec_1.OPERATION.TOUCH, index });
|
|
87
|
-
}
|
|
88
|
-
this.allChanges.add(index);
|
|
89
|
-
// ensure touch is placed until the $root is found.
|
|
90
|
-
this.touchParents();
|
|
91
|
-
}
|
|
92
|
-
touchParents() {
|
|
93
|
-
if (this.parent) {
|
|
94
|
-
this.parent['$changes'].touch(this.parentIndex);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
getType(index) {
|
|
98
|
-
if (this.ref['_definition']) {
|
|
99
|
-
const definition = this.ref['_definition'];
|
|
100
|
-
return definition.schema[definition.fieldsByIndex[index]];
|
|
101
|
-
}
|
|
102
|
-
else {
|
|
103
|
-
const definition = this.parent['_definition'];
|
|
104
|
-
const parentType = definition.schema[definition.fieldsByIndex[this.parentIndex]];
|
|
105
|
-
//
|
|
106
|
-
// Get the child type from parent structure.
|
|
107
|
-
// - ["string"] => "string"
|
|
108
|
-
// - { map: "string" } => "string"
|
|
109
|
-
// - { set: "string" } => "string"
|
|
110
|
-
//
|
|
111
|
-
return Object.values(parentType)[0];
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
getChildrenFilter() {
|
|
115
|
-
const childFilters = this.parent['_definition'].childFilters;
|
|
116
|
-
return childFilters && childFilters[this.parentIndex];
|
|
117
|
-
}
|
|
118
|
-
//
|
|
119
|
-
// used during `.encode()`
|
|
120
|
-
//
|
|
121
|
-
getValue(index) {
|
|
122
|
-
return this.ref['getByIndex'](index);
|
|
123
|
-
}
|
|
124
|
-
delete(fieldName) {
|
|
125
|
-
const index = (typeof (fieldName) === "number")
|
|
126
|
-
? fieldName
|
|
127
|
-
: this.indexes[fieldName];
|
|
128
|
-
if (index === undefined) {
|
|
129
|
-
console.warn(`@colyseus/schema ${this.ref.constructor.name}: trying to delete non-existing index: ${fieldName} (${index})`);
|
|
130
|
-
return;
|
|
131
|
-
}
|
|
132
|
-
const previousValue = this.getValue(index);
|
|
133
|
-
// console.log("$changes.delete =>", { fieldName, index, previousValue });
|
|
134
|
-
this.changes.set(index, { op: spec_1.OPERATION.DELETE, index });
|
|
135
|
-
this.allChanges.delete(index);
|
|
136
|
-
// delete cache
|
|
137
|
-
delete this.caches[index];
|
|
138
|
-
// remove `root` reference
|
|
139
|
-
if (previousValue && previousValue['$changes']) {
|
|
140
|
-
previousValue['$changes'].parent = undefined;
|
|
141
|
-
}
|
|
142
|
-
this.changed = true;
|
|
143
|
-
this.touchParents();
|
|
144
|
-
}
|
|
145
|
-
discard(changed = false, discardAll = false) {
|
|
146
|
-
//
|
|
147
|
-
// Map, Array, etc:
|
|
148
|
-
// Remove cached key to ensure ADD operations is unsed instead of
|
|
149
|
-
// REPLACE in case same key is used on next patches.
|
|
150
|
-
//
|
|
151
|
-
// TODO: refactor this. this is not relevant for Collection and Set.
|
|
152
|
-
//
|
|
153
|
-
if (!(this.ref instanceof Schema_1.Schema)) {
|
|
154
|
-
this.changes.forEach((change) => {
|
|
155
|
-
if (change.op === spec_1.OPERATION.DELETE) {
|
|
156
|
-
const index = this.ref['getIndex'](change.index);
|
|
157
|
-
delete this.indexes[index];
|
|
158
|
-
}
|
|
159
|
-
});
|
|
160
|
-
}
|
|
161
|
-
this.changes.clear();
|
|
162
|
-
this.changed = changed;
|
|
163
|
-
if (discardAll) {
|
|
164
|
-
this.allChanges.clear();
|
|
165
|
-
}
|
|
166
|
-
// re-set `currentCustomOperation`
|
|
167
|
-
this.currentCustomOperation = 0;
|
|
168
|
-
}
|
|
169
|
-
/**
|
|
170
|
-
* Recursively discard all changes from this, and child structures.
|
|
171
|
-
*/
|
|
172
|
-
discardAll() {
|
|
173
|
-
this.changes.forEach((change) => {
|
|
174
|
-
const value = this.getValue(change.index);
|
|
175
|
-
if (value && value['$changes']) {
|
|
176
|
-
value['$changes'].discardAll();
|
|
177
|
-
}
|
|
178
|
-
});
|
|
179
|
-
this.discard();
|
|
180
|
-
}
|
|
181
|
-
// cache(field: number, beginIndex: number, endIndex: number) {
|
|
182
|
-
cache(field, cachedBytes) {
|
|
183
|
-
this.caches[field] = cachedBytes;
|
|
184
|
-
}
|
|
185
|
-
clone() {
|
|
186
|
-
return new ChangeTree(this.ref, this.parent, this.root);
|
|
187
|
-
}
|
|
188
|
-
ensureRefId() {
|
|
189
|
-
// skip if refId is already set.
|
|
190
|
-
if (this.refId !== undefined) {
|
|
191
|
-
return;
|
|
192
|
-
}
|
|
193
|
-
this.refId = this.root.getNextUniqueId();
|
|
194
|
-
}
|
|
195
|
-
assertValidIndex(index, fieldName) {
|
|
196
|
-
if (index === undefined) {
|
|
197
|
-
throw new Error(`ChangeTree: missing index for field "${fieldName}"`);
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
exports.ChangeTree = ChangeTree;
|
|
202
|
-
//# sourceMappingURL=ChangeTree.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ChangeTree.js","sourceRoot":"","sources":["../../src/changes/ChangeTree.ts"],"names":[],"mappings":";;;AAAA,kCAAoC;AACpC,sCAAmC;AA6BnC,MAAa,UAAU;IAoBnB,YAAY,GAAQ,EAAE,MAAY,EAAE,IAAuB;QAT3D,YAAO,GAAY,KAAK,CAAC;QACzB,YAAO,GAAG,IAAI,GAAG,EAA2B,CAAC;QAC7C,eAAU,GAAG,IAAI,GAAG,EAAU,CAAC;QAE/B,+BAA+B;QAC/B,WAAM,GAAgC,EAAE,CAAC;QAEzC,2BAAsB,GAAW,CAAC,CAAC;QAG/B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACjC,CAAC;IAED,SAAS,CACL,MAAW,EACX,IAAuB,EACvB,WAAoB;QAEpB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAChB,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,YAAY,eAAM,CAAC;gBACvC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,OAAO;gBACjC,CAAC,CAAC,EAAE,CAAC;QACb,CAAC;QAED,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAE/B,0CAA0C;QAC1C,IAAI,CAAC,IAAI,EAAE,CAAC;YAAC,OAAO;QAAC,CAAC;QACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QAEjB,EAAE;QACF,yCAAyC;QACzC,EAAE;QACF,IAAI,IAAI,CAAC,GAAG,YAAY,eAAM,EAAE,CAAC;YAC7B,MAAM,UAAU,GAAqB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;YAE7D,KAAK,IAAI,KAAK,IAAI,UAAU,CAAC,MAAM,EAAE,CAAC;gBAClC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAE9B,IAAI,KAAK,IAAI,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;oBAC7B,MAAM,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;oBAE7C,KAAK,CAAC,UAAU,CAAgB,CAAC,SAAS,CACvC,IAAI,CAAC,GAAG,EACR,IAAI,EACJ,WAAW,CACd,CAAC;gBACN,CAAC;YACL,CAAC;QAEL,CAAC;aAAM,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,QAAQ,EAAE,CAAC;YACxC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;gBAC5B,IAAI,KAAK,YAAY,eAAM,EAAE,CAAC;oBAC1B,MAAM,WAAW,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC;oBACtC,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;oBAEtD,WAAW,CAAC,SAAS,CACjB,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,IAAI,EACT,WAAW,CACd,CAAC;gBACN,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAED,SAAS,CAAC,EAAmB;QACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,sBAAsB,EAAE,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,MAAM,CAAC,SAA0B,EAAE,YAAuB,gBAAS,CAAC,GAAG;QACnE,MAAM,KAAK,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,QAAQ,CAAC;YAC3C,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAE9B,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QAExC,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAE/C,IACI,CAAC,cAAc;YACf,cAAc,CAAC,EAAE,KAAK,gBAAS,CAAC,MAAM;YACtC,cAAc,CAAC,EAAE,KAAK,gBAAS,CAAC,KAAK,CAAC,qCAAqC;UAC7E,CAAC;YACC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE;gBACpB,EAAE,EAAE,CAAC,CAAC,cAAc,CAAC;oBACjB,CAAC,CAAC,SAAS;oBACX,CAAC,CAAC,CAAC,cAAc,CAAC,EAAE,KAAK,gBAAS,CAAC,MAAM,CAAC;wBACtC,CAAC,CAAC,gBAAS,CAAC,cAAc;wBAC1B,CAAC,CAAC,SAAS;gBACX,uBAAuB;gBAC/B,KAAK;aACR,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAE3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,KAAK,CAAC,SAA0B;QAC5B,MAAM,KAAK,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,QAAQ,CAAC;YAC3C,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAE9B,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,gBAAS,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAC5D,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAE3B,mDAAmD;QACnD,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,YAAY;QACR,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACb,IAAI,CAAC,MAAM,CAAC,UAAU,CAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpE,CAAC;IACL,CAAC;IAED,OAAO,CAAC,KAAc;QAClB,IAAI,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;YAC1B,MAAM,UAAU,GAAI,IAAI,CAAC,GAAc,CAAC,aAAa,CAAC,CAAC;YACvD,OAAO,UAAU,CAAC,MAAM,CAAE,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,CAAE,CAAC;QAEhE,CAAC;aAAM,CAAC;YACJ,MAAM,UAAU,GAAI,IAAI,CAAC,MAAiB,CAAC,aAAa,CAAC,CAAC;YAC1D,MAAM,UAAU,GAAG,UAAU,CAAC,MAAM,CAAE,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAE,CAAC;YAEnF,EAAE;YACF,4CAA4C;YAC5C,2BAA2B;YAC3B,kCAAkC;YAClC,kCAAkC;YAClC,EAAE;YACF,OAAO,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC;IACL,CAAC;IAED,iBAAiB;QACb,MAAM,YAAY,GAAI,IAAI,CAAC,MAAiB,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC;QACzE,OAAO,YAAY,IAAI,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC1D,CAAC;IAED,EAAE;IACF,0BAA0B;IAC1B,EAAE;IACF,QAAQ,CAAC,KAAa;QAClB,OAAO,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,MAAM,CAAC,SAA0B;QAC7B,MAAM,KAAK,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,QAAQ,CAAC;YAC3C,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAE9B,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACtB,OAAO,CAAC,IAAI,CAAC,oBAAoB,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,0CAA0C,SAAS,KAAK,KAAK,GAAG,CAAC,CAAC;YAC5H,OAAO;QACX,CAAC;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC3C,0EAA0E;QAE1E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,gBAAS,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEzD,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAE9B,eAAe;QACf,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAE1B,0BAA0B;QAC1B,IAAI,aAAa,IAAI,aAAa,CAAC,UAAU,CAAC,EAAE,CAAC;YAC7C,aAAa,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,SAAS,CAAC;QACjD,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,OAAO,CAAC,UAAmB,KAAK,EAAE,aAAsB,KAAK;QACzD,EAAE;QACF,mBAAmB;QACnB,iEAAiE;QACjE,oDAAoD;QACpD,EAAE;QACF,oEAAoE;QACpE,EAAE;QACF,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,YAAY,eAAM,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC5B,IAAI,MAAM,CAAC,EAAE,KAAK,gBAAS,CAAC,MAAM,EAAE,CAAC;oBACjC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;oBAChD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gBAC/B,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QAEvB,IAAI,UAAU,EAAE,CAAC;YACb,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QAC5B,CAAC;QAED,kCAAkC;QAClC,IAAI,CAAC,sBAAsB,GAAG,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACH,UAAU;QACN,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAE1C,IAAI,KAAK,IAAI,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC7B,KAAK,CAAC,UAAU,CAAC,CAAC,UAAU,EAAE,CAAC;YACnC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAED,+DAA+D;IAC/D,KAAK,CAAC,KAAa,EAAE,WAAqB;QACtC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,WAAW,CAAC;IACrC,CAAC;IAED,KAAK;QACD,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED,WAAW;QACP,gCAAgC;QAChC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC3B,OAAO;QACX,CAAC;QAED,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;IAC7C,CAAC;IAES,gBAAgB,CAAC,KAAa,EAAE,SAA0B;QAChE,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,wCAAwC,SAAS,GAAG,CAAC,CAAC;QAC1E,CAAC;IACL,CAAC;CAEJ;AAxQD,gCAwQC","sourcesContent":["import { OPERATION } from \"../spec\";\nimport { Schema } from \"../Schema\";\nimport { SchemaDefinition, FilterChildrenCallback } from \"../annotations\";\n\nimport { MapSchema } from \"../types/MapSchema\";\nimport { ArraySchema } from \"../types/ArraySchema\";\nimport { CollectionSchema } from \"../types/CollectionSchema\";\nimport { SetSchema } from \"../types/SetSchema\";\nimport { ReferenceTracker } from \"./ReferenceTracker\";\n\nexport type Ref = Schema\n | ArraySchema\n | MapSchema\n | CollectionSchema\n | SetSchema;\n\nexport interface ChangeOperation {\n op: OPERATION,\n index: number,\n}\n\n//\n// FieldCache is used for @filter()\n//\nexport interface FieldCache {\n beginIndex: number;\n endIndex: number;\n}\n\n\nexport class ChangeTree {\n ref: Ref;\n refId: number;\n\n root?: ReferenceTracker;\n\n parent?: Ref;\n parentIndex?: number;\n\n indexes: {[index: string]: any};\n\n changed: boolean = false;\n changes = new Map<number, ChangeOperation>();\n allChanges = new Set<number>();\n\n // cached indexes for filtering\n caches: {[field: number]: number[]} = {};\n\n currentCustomOperation: number = 0;\n\n constructor(ref: Ref, parent?: Ref, root?: ReferenceTracker) {\n this.ref = ref;\n this.setParent(parent, root);\n }\n\n setParent(\n parent: Ref,\n root?: ReferenceTracker,\n parentIndex?: number,\n ) {\n if (!this.indexes) {\n this.indexes = (this.ref instanceof Schema)\n ? this.ref['_definition'].indexes\n : {};\n }\n\n this.parent = parent;\n this.parentIndex = parentIndex;\n\n // avoid setting parents with empty `root`\n if (!root) { return; }\n this.root = root;\n\n //\n // assign same parent on child structures\n //\n if (this.ref instanceof Schema) {\n const definition: SchemaDefinition = this.ref['_definition'];\n\n for (let field in definition.schema) {\n const value = this.ref[field];\n\n if (value && value['$changes']) {\n const parentIndex = definition.indexes[field];\n\n (value['$changes'] as ChangeTree).setParent(\n this.ref,\n root,\n parentIndex,\n );\n }\n }\n\n } else if (typeof (this.ref) === \"object\") {\n this.ref.forEach((value, key) => {\n if (value instanceof Schema) {\n const changeTreee = value['$changes'];\n const parentIndex = this.ref['$changes'].indexes[key];\n\n changeTreee.setParent(\n this.ref,\n this.root,\n parentIndex,\n );\n }\n });\n }\n }\n\n operation(op: ChangeOperation) {\n this.changes.set(--this.currentCustomOperation, op);\n }\n\n change(fieldName: string | number, operation: OPERATION = OPERATION.ADD) {\n const index = (typeof (fieldName) === \"number\")\n ? fieldName\n : this.indexes[fieldName];\n\n this.assertValidIndex(index, fieldName);\n\n const previousChange = this.changes.get(index);\n\n if (\n !previousChange ||\n previousChange.op === OPERATION.DELETE ||\n previousChange.op === OPERATION.TOUCH // (mazmorra.io's BattleAction issue)\n ) {\n this.changes.set(index, {\n op: (!previousChange)\n ? operation\n : (previousChange.op === OPERATION.DELETE)\n ? OPERATION.DELETE_AND_ADD\n : operation,\n // : OPERATION.REPLACE,\n index\n });\n }\n\n this.allChanges.add(index);\n\n this.changed = true;\n this.touchParents();\n }\n\n touch(fieldName: string | number) {\n const index = (typeof (fieldName) === \"number\")\n ? fieldName\n : this.indexes[fieldName];\n\n this.assertValidIndex(index, fieldName);\n\n if (!this.changes.has(index)) {\n this.changes.set(index, { op: OPERATION.TOUCH, index });\n }\n\n this.allChanges.add(index);\n\n // ensure touch is placed until the $root is found.\n this.touchParents();\n }\n\n touchParents() {\n if (this.parent) {\n (this.parent['$changes'] as ChangeTree).touch(this.parentIndex);\n }\n }\n\n getType(index?: number) {\n if (this.ref['_definition']) {\n const definition = (this.ref as Schema)['_definition'];\n return definition.schema[ definition.fieldsByIndex[index] ];\n\n } else {\n const definition = (this.parent as Schema)['_definition'];\n const parentType = definition.schema[ definition.fieldsByIndex[this.parentIndex] ];\n\n //\n // Get the child type from parent structure.\n // - [\"string\"] => \"string\"\n // - { map: \"string\" } => \"string\"\n // - { set: \"string\" } => \"string\"\n //\n return Object.values(parentType)[0];\n }\n }\n\n getChildrenFilter(): FilterChildrenCallback {\n const childFilters = (this.parent as Schema)['_definition'].childFilters;\n return childFilters && childFilters[this.parentIndex];\n }\n\n //\n // used during `.encode()`\n //\n getValue(index: number) {\n return this.ref['getByIndex'](index);\n }\n\n delete(fieldName: string | number) {\n const index = (typeof (fieldName) === \"number\")\n ? fieldName\n : this.indexes[fieldName];\n\n if (index === undefined) {\n console.warn(`@colyseus/schema ${this.ref.constructor.name}: trying to delete non-existing index: ${fieldName} (${index})`);\n return;\n }\n\n const previousValue = this.getValue(index);\n // console.log(\"$changes.delete =>\", { fieldName, index, previousValue });\n\n this.changes.set(index, { op: OPERATION.DELETE, index });\n\n this.allChanges.delete(index);\n\n // delete cache\n delete this.caches[index];\n\n // remove `root` reference\n if (previousValue && previousValue['$changes']) {\n previousValue['$changes'].parent = undefined;\n }\n\n this.changed = true;\n this.touchParents();\n }\n\n discard(changed: boolean = false, discardAll: boolean = false) {\n //\n // Map, Array, etc:\n // Remove cached key to ensure ADD operations is unsed instead of\n // REPLACE in case same key is used on next patches.\n //\n // TODO: refactor this. this is not relevant for Collection and Set.\n //\n if (!(this.ref instanceof Schema)) {\n this.changes.forEach((change) => {\n if (change.op === OPERATION.DELETE) {\n const index = this.ref['getIndex'](change.index)\n delete this.indexes[index];\n }\n });\n }\n\n this.changes.clear();\n this.changed = changed;\n\n if (discardAll) {\n this.allChanges.clear();\n }\n\n // re-set `currentCustomOperation`\n this.currentCustomOperation = 0;\n }\n\n /**\n * Recursively discard all changes from this, and child structures.\n */\n discardAll() {\n this.changes.forEach((change) => {\n const value = this.getValue(change.index);\n\n if (value && value['$changes']) {\n value['$changes'].discardAll();\n }\n });\n\n this.discard();\n }\n\n // cache(field: number, beginIndex: number, endIndex: number) {\n cache(field: number, cachedBytes: number[]) {\n this.caches[field] = cachedBytes;\n }\n\n clone() {\n return new ChangeTree(this.ref, this.parent, this.root);\n }\n\n ensureRefId() {\n // skip if refId is already set.\n if (this.refId !== undefined) {\n return;\n }\n\n this.refId = this.root.getNextUniqueId();\n }\n\n protected assertValidIndex(index: number, fieldName: string | number) {\n if (index === undefined) {\n throw new Error(`ChangeTree: missing index for field \"${fieldName}\"`);\n }\n }\n\n}\n"]}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { OPERATION } from "../spec";
|
|
2
|
-
import { DataChange, Schema } from "../Schema";
|
|
3
|
-
import type { Ref } from "./ChangeTree";
|
|
4
|
-
import type { Decoder } from "../Decoder";
|
|
5
|
-
import * as decode from "../encoding/decode";
|
|
6
|
-
export declare enum DecodeState {
|
|
7
|
-
DEFINITION_MISMATCH = 0
|
|
8
|
-
}
|
|
9
|
-
export type DecodeOperation<T extends Schema = any> = (decoder: Decoder<T>, bytes: number[], it: decode.Iterator, ref: Ref, allChanges: DataChange[]) => void;
|
|
10
|
-
export declare function decodeValue(decoder: Decoder, operation: OPERATION, ref: Ref, index: number, type: any, bytes: number[], it: decode.Iterator, allChanges: DataChange[]): {
|
|
11
|
-
value: any;
|
|
12
|
-
previousValue: any;
|
|
13
|
-
};
|
|
14
|
-
export declare const decodeSchemaOperation: DecodeOperation;
|
|
15
|
-
export declare const decodeKeyValueOperation: DecodeOperation;
|