@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.
Files changed (80) hide show
  1. package/build/cjs/index.js +1 -1
  2. package/build/cjs/index.js.map +1 -1
  3. package/build/esm/index.mjs +1 -1
  4. package/build/esm/index.mjs.map +1 -1
  5. package/build/umd/index.js +1 -1
  6. package/lib/encoder/Encoder.js +1 -1
  7. package/lib/encoder/Encoder.js.map +1 -1
  8. package/lib/types/custom/MapSchema.d.ts +14 -14
  9. package/lib/types/custom/MapSchema.js.map +1 -1
  10. package/package.json +1 -1
  11. package/src/encoder/Encoder.ts +2 -3
  12. package/src/types/custom/MapSchema.ts +12 -12
  13. package/lib/Decoder.d.ts +0 -16
  14. package/lib/Decoder.js +0 -182
  15. package/lib/Decoder.js.map +0 -1
  16. package/lib/Encoder.d.ts +0 -13
  17. package/lib/Encoder.js +0 -79
  18. package/lib/Encoder.js.map +0 -1
  19. package/lib/bench_encode.d.ts +0 -1
  20. package/lib/bench_encode.js +0 -130
  21. package/lib/bench_encode.js.map +0 -1
  22. package/lib/changes/ChangeSet.d.ts +0 -12
  23. package/lib/changes/ChangeSet.js +0 -35
  24. package/lib/changes/ChangeSet.js.map +0 -1
  25. package/lib/changes/ChangeTree.d.ts +0 -53
  26. package/lib/changes/ChangeTree.js +0 -202
  27. package/lib/changes/ChangeTree.js.map +0 -1
  28. package/lib/changes/DecodeOperation.d.ts +0 -15
  29. package/lib/changes/DecodeOperation.js +0 -186
  30. package/lib/changes/DecodeOperation.js.map +0 -1
  31. package/lib/changes/EncodeOperation.d.ts +0 -18
  32. package/lib/changes/EncodeOperation.js +0 -130
  33. package/lib/changes/EncodeOperation.js.map +0 -1
  34. package/lib/changes/ReferenceTracker.d.ts +0 -14
  35. package/lib/changes/ReferenceTracker.js +0 -83
  36. package/lib/changes/ReferenceTracker.js.map +0 -1
  37. package/lib/changes/consts.d.ts +0 -14
  38. package/lib/changes/consts.js +0 -18
  39. package/lib/changes/consts.js.map +0 -1
  40. package/lib/debug.d.ts +0 -1
  41. package/lib/debug.js +0 -51
  42. package/lib/debug.js.map +0 -1
  43. package/lib/decoding/decode.d.ts +0 -48
  44. package/lib/decoding/decode.js +0 -267
  45. package/lib/decoding/decode.js.map +0 -1
  46. package/lib/ecs.d.ts +0 -11
  47. package/lib/ecs.js +0 -160
  48. package/lib/ecs.js.map +0 -1
  49. package/lib/filters/index.d.ts +0 -8
  50. package/lib/filters/index.js +0 -24
  51. package/lib/filters/index.js.map +0 -1
  52. package/lib/spec.d.ts +0 -13
  53. package/lib/spec.js +0 -42
  54. package/lib/spec.js.map +0 -1
  55. package/lib/types/ArraySchema.d.ts +0 -238
  56. package/lib/types/ArraySchema.js +0 -555
  57. package/lib/types/ArraySchema.js.map +0 -1
  58. package/lib/types/CollectionSchema.d.ts +0 -35
  59. package/lib/types/CollectionSchema.js +0 -150
  60. package/lib/types/CollectionSchema.js.map +0 -1
  61. package/lib/types/MapSchema.d.ts +0 -38
  62. package/lib/types/MapSchema.js +0 -215
  63. package/lib/types/MapSchema.js.map +0 -1
  64. package/lib/types/SetSchema.d.ts +0 -32
  65. package/lib/types/SetSchema.js +0 -162
  66. package/lib/types/SetSchema.js.map +0 -1
  67. package/lib/types/typeRegistry.d.ts +0 -5
  68. package/lib/types/typeRegistry.js +0 -13
  69. package/lib/types/typeRegistry.js.map +0 -1
  70. package/lib/usage.d.ts +0 -1
  71. package/lib/usage.js +0 -22
  72. package/lib/usage.js.map +0 -1
  73. package/lib/v3.d.ts +0 -1
  74. package/lib/v3.js +0 -427
  75. package/lib/v3.js.map +0 -1
  76. package/lib/v3_experiment.d.ts +0 -1
  77. package/lib/v3_experiment.js +0 -407
  78. package/lib/v3_experiment.js.map +0 -1
  79. package/src/bench_encode.ts +0 -108
  80. 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
@@ -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}"]}
@@ -1 +0,0 @@
1
- export {};
@@ -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
@@ -1 +0,0 @@
1
- {"version":3,"file":"bench_encode.js","sourceRoot":"","sources":["../src/bench_encode.ts"],"names":[],"mappings":"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","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
- }
@@ -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":"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","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;